Home >Backend Development >PHP Tutorial >betty boop PHP advanced OOP technology demonstration

betty boop PHP advanced OOP technology demonstration

WBOY
WBOYOriginal
2016-07-29 08:40:40818browse

Serializing
PHP does not support persistent objects. In OOP, a persistent object is an object that can maintain state and functionality among references in multiple applications. This means having the ability to save the object to a file or database, and Objects can be loaded later. This is the so-called serialization mechanism. PHP has a serialization method that can be called on an object, and the serialization method can return a string representation of the object. However, serialization only saves the member data of the object and not the methods.
In PHP4, if you serialize the object into the string $s, then release the object, and then deserialize the object
into $obj, you can continue to use the object's methods! I don't recommend doing this because (a) there is no guarantee in the documentation that this behavior will still work in future versions. (b) This may lead to a misunderstanding when you save a serialized version to disk and exit the script. When you run this script later, you cannot expect that when you deserialize an object, the object's methods will be there, because the string representation does not include methods at all.
In summary, serialization in PHP is very useful for saving member variables of objects. (You can also serialize related arrays and arrays into a file).
Example:

Copy code The code is as follows:


<?php
$obj=new Classfoo();
$str=serialize($obj);
//Save $str to disk
/ /A few months later
//Load str from disk
$obj2=unserialize($str)


You restored the member data, but not the method (according to the documentation). This results in the only way to access member variables (you have no other way!) by something like using $obj2->x, so don't try it at home.
There are some ways to solve this problem, I'm leaving it out because they are too bad for this concise article. I would happily welcome fully serialized features in subsequent versions of PHP.
Using Classes for Data Storage One very nice thing about PHP and OOP is that you can easily define a class to do something and call the corresponding class whenever you want to use it. Suppose you have an HTML form that allows the user to select a product by selecting the product ID number. There is product information in the database, and you want to display the product, its price, etc. You have different types of products, and the same action may mean different things to different products. For example, displaying a sound might mean playing it, but for other kinds of products it might mean displaying an image stored in a database. You can use OOP or PHP to reduce coding and improve quality.
Define a product class, define the methods it should have (for example: display), and then define a class for each type of product
, derived from the product class (SoundItem class, ViewableItem class, etc.), override Methods in the product class to make them behave how you want.
Name the class according to the type field of each product in the database. A typical product table may have (id, type, price, description, etc. fields)... Then in the processing script, you can Get the type value from the database, and then instantiate an object named type:

Copy the code The code is as follows:


<?php
$obj=new $type();
$obj->action ();


This is a very good feature of PHP. You can call the display method or other methods of $obj without considering the type of object. Using this technique, you don't need to modify the script to add a new type of object, just a class to handle it.
This function is very powerful. Just define methods without considering the types of all objects. Implement them in different classes in different methods, and then use them on any object in the main script. There is no if...else, or No need for two programmers,
only joy.
Now you agree that programming is easy, maintenance is cheap, and reusability is true?
If you manage a group of programmers, assigning work is simple, each person may be responsible for a type of object and
the class that handles it.
Internationalization can be achieved through this technology, just apply the corresponding class according to the language field selected by the user, etc.
Copy and Clone
When you create an object of $obj, you can copy the object by $obj2=$obj. The new object is a copy of $obj (not a reference), so it has the value of $obj at that time. state. Sometimes, you don't want to do this. You just want to generate a new object like the obj class. You can call the constructor of the class by using the new statement. This can also be achieved in PHP through serialization and a base class, but all other classes must be derived from the base class.
Enter the Danger Zone
When you serialize an object, you will get a string in some format, if you are interested, you can investigate it, where, in the string, there is the name of the class (great!), you You can take it out, like:

Copy code The code is as follows:


<?php
$herring=serialize($obj);
$vec=explode(':',$herring);
$nam=str_replace(""",'',$vec[2]);


So assuming you create a "Universe" class and force all classes to extend from universe, you can define a clone method in universe, as follows:

Copy the code The code is as follows:


<?php
function clone() {
$herring=serialize($this);
$vec=explode(':',$herring);
$nam=str_replace(""",'',$vec[ 2]);
$ret=new $nam;
return $ret;
}
}
//Then
$obj=new Something();
//Expand from Universe
$other=$obj->clone ();


What you get is a new Something class object, which is the same as the object created by using the new method and calling the constructor. I don't know if this is useful to you, but the Universe class can know the derived class. The name is a good experience. The only limitation is that the statement is written to the current time.
The above introduces the betty boop PHP advanced OOP technology demonstration, including the content of betty boop. I hope it will be helpful to friends who are interested in PHP tutorials.

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn