Skip to main content

New Object-Oriented Features


The new OO features are too numerous to give a detailed description in this section. Chapter 3, “PHP 5 OO Language,” details each feature.The following list provides the main new features:

public/private/protectedaccess modifiers for methods and properties.Allows the use of common OO access modifiers to control access tomethods and properties:




class MyClass {
private $id = 18;
public function getId() {
return $this->id;
}
}


Unified constructor name__construct().
Instead of the constructor being the name of the class, it is now declared as __construct(), which makes it easier to shift classes inside class hierarchies:


class MyClass {
function __construct() {
print "Inside constructor";
}
}

Object destructor support by defining a __destructor() method.Allows defining a destructor function that runs when an object is destroyed:




class MyClass {
function __destruct() {
print ”Destroying object”;
}

}

Interfaces.

Gives the ability for a class to fulfill more than one is-a relationships. A class can inherit only from one class, but may implement as many interfaces as it wants:


interface Display {
function display();
}
class Circle implements Display {
function display() {
print "Displaying circle\n";
}
}




instance of operator.


Language-level support for is-a relationship checking. The PHP 4 is_a() function is now deprecated:




if ($obj instanceof Circle) {
print '$obj is a Circle';
}


Final methods.

The final keyword allows you to mark methods so that an inheriting class cannot overload them:


class MyClass {
final function getBaseClassName() {
return __CLASS__;
}
}


Final classes.

After declaring a class as final , it cannot be inherited. The following example would error out.


final class FinalClass {
}
class BogusClass extends FinalClass {
}


Explicit object cloning.

To clone an object, you must use the clone keyword. You may declare a __clone() method, which will be called during the clone process (after the properties have been copied from the original object):

Comments

Popular posts from this blog

PHP INTRODUCTION

                     PHP  (recursive acronym for  PHP: Hypertext Preprocessor ) is a widely-used open source general-purpose scripting language that is especially suited for web development and can be embedded into HTML. PHP stands for  P HP:  H ypertext  P reprocessor PHP is a server-side scripting language, like ASP PHP scripts are executed on the server PHP supports many databases (MySQL, Informix, Oracle, Sybase, Solid, PostgreSQL, Generic ODBC, etc.) PHP is an open source software PHP is free to download and use Why PHP? PHP runs on different platforms (Windows, Linux, Unix, etc.) PHP is compatible with almost all servers used today (Apache, IIS, etc.) PHP is FREE to download from the official PHP resource:  www.php.net PHP is easy to learn and runs efficiently on the server side What can PHP do? Anything. PHP is mainly focused on server-side scripting, so you can...

Storage Engine Breakdown

The following diagram represents a simplified view of the MySQL server and its interaction with the  storage engines. The following properties are storage engine dependant: • Storage Medium – Each table uses its own method of storing the data it contains. • Transactional Capabilities – Certain storage engines handle transactional processing which ensures that integrity of a database is maintained during the processing of multiple SQL statements.

Outer Joins

Whereas an INNER JOIN will find combinations of matching rows from joined tables, the OUTER JOIN also finds the instances where a row in one table has no match in another table. An OUTER JOIN find matches (just like an INNER JOIN), but also identifies mismatches. Two forms of outer joins are LEFT JOIN and RIGHT JOIN . These do not use the comma separator or the INNER JOIN keywords. They each answer the same kinds of questions, but differ slightly in their syntax. That is a LEFT JOIN can always be re-written into a equivalent RIGHT JOIN. (In the following sections, the terms left table and right table refer to the tables named first and second in the FROM clause, respectively.)  Left Outer Join A left join is a type of outer join, written using the LEFT JOIN keywords. A left join treats the left table (the first one named) as a reference table and produces output for each row selected from it, whether or not the row is matched by rows in the right table. Like a join w...