This is the 29th day of my participation in the August Wenwen Challenge.More challenges in August

Definition and characteristics of archetypal patterns

The Prototype pattern is defined as follows: Use an already created instance as a Prototype and create a new object that is identical or similar to the Prototype by copying the Prototype object. Here, the prototype instance specifies the kind of object to be created. Creating objects this way is very efficient, and you don’t need to know the details of object creation at all.

Advantages of the prototype pattern:

  • The built-in prototype pattern is based on copying an in-memory binary stream and is better for performance than simply new an object.
  • You can use the deep clone mode to save the state of an object. You can use the prototype mode to make a copy of an object and save its state, simplifying the process of creating an object, so that it can be used when needed (such as restoring to a historical state) to assist in the undo operation.

Disadvantages of the prototype pattern:

  • You need to configure a Clone method for each class
  • The Clone method is located inside the class. When modifying an existing class, the code needs to be modified, which violates the open and closed principle.
  • When implementing deep cloning, complex code needs to be written, and when there are multiple nested references between objects, in order to implement deep cloning, the corresponding classes of each layer of objects must support deep cloning, which can be quite troublesome to implement. Therefore, deep cloning, shallow cloning needs to be used properly.

The example code

public class DemoBase implements Cloneable{ public String base; public DemoBase(String base) { this.base = base; System.out.println("yes?" ); } @Override protected Object clone() throws CloneNotSupportedException { System.out.println("let's clone!" ); return super.clone(); } public static void main(String[] args) throws CloneNotSupportedException { DemoBase obj1 = new DemoBase("RU1? yes"); DemoBase obj2 = (DemoBase) obj1.clone(); obj2.base = "RU1? NO!" ; System.out.println(obj1.base); System.out.println(obj2.base); }}Copy the code

Console output

yes? let's clone! RU1? yes RU1? NO!Copy the code

As you can see, the front and back objects are deeply copied.

Usage scenarios

For example: A person corresponds to many records, which do not contain information about the person. For example, to write related records into DB, you can first:

1. Initialize records with human information

2. There is no need to repeatedly initialize the human information, saving operation steps.

Pseudocode presentation

Person person = getPerson()
Identity id = getIdentity()
...
Record2Db r2d = formatData(person,id)
List<Record> rawRecords = getRawRecord()
List<Record2Db> list
for(record in rawRecords){
    Record2Db entity = r2d.clone()
    list.add(entity)
}
write2DB(list)
Copy the code

Summary of usage scenarios

  • Objects are the same or similar, that is, only with different attributes.
  • For example, creating an object takes a long time to initialize, consumes too much CPU, or consumes too many network resources. Therefore, you need to optimize resources.
  • Creating an object requires a lot of data preparation or access rights to improve performance or security.
  • This class object is used extensively in the system, and each caller needs to reassign its properties.

Relevant extension

  1. Prototype patterns in Spring
  2. Multiple prototype assembly Map objects (MAPS) are used for management, and the corresponding prototype is obtained from the managed object for initialization.

\