Home > Lazy initialization
In computer programming, lazy initialization is the tactic of delaying the creation of an object, the calculation of a value or some other expensive process until the first time it is needed.This is typically accomplished by maintaining a flag indicating whether the process has taken place. Each time the desired thing is summoned, the flag is tested. If it's ready, it is returned. If not, it is initialized on the spot.
the "lazy factory"
In a software design pattern view, lazy initialization is often used together with a factory method pattern. This combines three ideas:
- using a factory method to get instances of a class ( factory method pattern)
- storing the instances in a map, so you get the same instance the next time you ask for an instance with some parameter (compare with a singleton pattern)
- using lazy initialization to instantiate the object the first time it is requested ( lazy initialization pattern)
Here is a dummy example (in Java).
The Fruit class itself doesn't do anything here, this is just an example to show the architecture. The class variable types is a map used to store Fruit instances by type.
public Class Fruit {
private static Map types = new HashMap();
private String type;
// using a private constructor to force use of the factory method.
private Fruit(String type){
this.type=type;
types.add(type, this);
}
// factory method, gets a fruit by type
public static Fruit getFruit(String type){
Fruit f;
if (types.containsKey(type){
f = (Fruit) types.get(type); // get the instance for that type
} else {
f = new Fruit(type); // lazy initialization
}
return f;
}
}
Note that the technique can also be used in non-object-oriented languages.
Software design patterns