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 do anything any other CGI program can do, such as collect form data, generate dynam

MySQL General Architecture

        MySQL operates in a networked environment using a client/server architecture. In other words, a central  program acts as a server, and various client programs connect to the server to make requests. A MySQL  installation has the following major components: MySQL Server, Client programs and MySQL non client  utilities.  MySQL Server MySQL Server, or mysqld, is the database server program. The server manages access to the actual  database (schema) on disk and in memory. MySQL Server is multi-threaded and supports many  simultaneous client connections. Clients can connect via several connection protocols. For managing  database contents, the MySQL server features a modular architecture that supports multiple storage engines  that handle different types of tables (for example, it supports both transactional and non-transactional  tables). Keep in mind the difference between a server and a host. The server is software (the MySQL server  program mysqld). Server characteristi