近两年没有使用PHP写过程序了,今天要用PHP,就在网上查了查,看到了PHP5,一时之间兴趣又大了起来,于是翻译了这篇文章。
文章来源于http://www.php.net/。
新的对象模型
PHP中的对象处理部分已完全重写,具有更佳的性能和更多的功能。在先前的PHP版本中,对象被当做原始的简单类型
(如integer和string)来处理,这种方法的缺点是当变量被赋值或作为参数传递时,得到的是对象拷贝。而在新版本中,
对象是通过句柄来引用的,而不是通过对象的值(句柄想象为对象的标识符)。
很多PHP程序员可能未意识到老的对象模型的“copying quirks“,因此以前的大多数PHP程序将不需要做任何更改
即可运行,或只做很少的改动。
私有和保护成员
PHP 5引进了私有和保护成员变量,它们可以定义可视化的类属性。
示例
保护成员变量能在该类的子类中被访问,而私有成员变量只能在所属类中被访问。
<?php
class MyClass {
private $Hello = "Hello, World!\n";
protected $Bar = "Hello, Foo!\n";
protected $Foo = "Hello, Bar!\n";
function printHello() {
print "MyClass::printHello() " . $this->Hello;
print "MyClass::printHello() " . $this->Bar;
print "MyClass::printHello() " . $this->Foo;
}
}
class MyClass2 extends MyClass {
protected $Foo;
function printHello() {
MyClass::printHello();
print "MyClass2::printHello() " . $this->Hello;
print "MyClass2::printHello() " . $this->Bar;
print "MyClass2::printHello() " . $this->Foo;
}
}
$obj = new MyClass();
print $obj->Hello;
print $obj->Bar;
print $obj->Foo;
$obj->printHello();
$obj = new MyClass2();
print $obj->Hello;
print $obj->Bar;
print $obj->Foo;
$obj->printHello();
?>
私有和保护方法
PHP 5(ZEND引擎2)中,私有方法和保护方法也被引入。
示例:
<?php
class Foo {
private function aPrivateMethod() {
echo "Foo::aPrivateMethod() called.\n";
}
protected function aProtectedMethod() {
echo "Foo::aProtectedMethod() called.\n";
$this->aPrivateMethod();
}
}
class Bar extends Foo {
public function aPublicMethod() {
echo "Bar::aPublicMethod() called.\n";
$this->aProtectedMethod();
}
}
$o = new Bar;
$o->aPublicMethod();
?>
以前代码中的用户自定义类或方法中虽然没有定义"public," "protected" 或 "private"等关键字,但无需修改即可运行。
抽象类和方法
PHP 5还引入了抽象类和方法。抽象方法只声明方法的”符号”,而不提供它的实现。一个包含抽象方法的类需要声明为”abstract”。
例如:
<?php
abstract class AbstractClass {
abstract public function test();
}
class ImplementedClass extends AbstractClass {
public function test() {
echo "ImplementedClass::test() called.\n";
}
}
$o = new ImplementedClass;
$o->test();
?>
抽象类不能实例化。
旧的代码中的用户自定义类或方法中虽未定义"abstract”关键字,但无需修改就可以运行。
接口(Interfaces)
ZEND引擎2.0引入了接口。一个类可以实现任意的接口列表。
例如:
<?php
interface Throwable {
public function getMessage();
}
class Exception implements Throwable {
public function getMessage() {
// ...
}
?>
旧的代码中的用户定义类或方法中虽然没有定义"interface”关键字,但无需修改就可以正常运行。
类类型提示(Class Type Hints)
在保留类无需定义类型的同时,PHP 5引入了类类型提示来声明,以期望把对象的类通过参数传递给一个方法。
例如:
<?php
interface Foo {
function a(Foo $foo);
}
interface Bar {
function b(Bar $bar);
}
class FooBar implements Foo, Bar {
function a(Foo $foo) {
// ...
}
function b(Bar $bar) {
// ...
}
}
$a = new FooBar;
$b = new FooBar;
$a->a($b);
$a->b($b);
?>
这些类类型提示不是象一些需要类型定义的语言那样在编译中进行检查,而是在运行时进行检查。这就意味着:
<?php
function foo(ClassName $object) {
// ...
}
?>
is equivalent to:
<?php
function foo($object) {
if (!($object instanceof ClassName)) {
die("Argument 1 must be an instance of ClassName");
}
}
?>
这种语法只用于对象或类,不适用于内建(built-in)类型。
Final关键字(final)
PHP 5引入了“final”关键字以定义在子类中不能被覆盖的成员或方法。
例:
<?php
class Foo {
final function bar() {
}
}
?>
以前所写代码中的用户自定义类或方法中虽未定义"final"关键字,但无需修改就可以运行了。
对象克隆(Object Cloning)
PHP 4在对象被复制时,用户不能判断运行那个拷贝构造函数。在复制时,PHP 4根据对象的属性
一位一位地复制一个同样的复制品。
每次都要建立一个完全一样的复制品并不总是我们想要的。一个很好的复制构造例子是,当有
一个代表一个GTK窗口的对象,它拥有该窗口的所有资源,当你建立一个拷贝时,你可能需要一
个新的窗口,它拥有原窗口的所有属性,但需要拥有新窗口的资源。另外一个例子是你有一个
对象引用了另外一个对象,当你复制父对象时,你希望建立那个引用对象的新实例,以使复制品有一个单独的拷贝。
对一个对象的拷贝通过调用对象的__clone()方法完成:
<?php
= $object->__clone();
?>
当开发者请求建立一个对象的新的拷贝时,ZEND引擎会检查是否已经定义了__clone()方法。如果未定义
的话,它会调用一个默认的__clone()方法来复制该对象的所有属性。如果定义了该方法,该方法会负责
在拷贝中设置必要的属性。为使用方便,引擎会提供一个函数从源对象中导入所有的属性,这样它就可
以先得到一个具有值的源对象拷贝,然后只需要对需要改变的属性进行覆盖即可。
例:
<?php
class MyCloneable {
static $id = 0;
function MyCloneable() {
$this->id = self::$id++;
}
function __clone() {
$this->name = $that->name;
$this->address = "New York";
$this->id = self::$id++;
}
}
$obj = new MyCloneable();
$obj->name = "Hello";
$obj->address = "Tel-Aviv";
print $obj->id . "\n";
$obj = $obj->__clone();
print $obj->id . "\n";
print $obj->name . "\n";
print $obj->address . "\n";
?>
统一的构造方法
ZEND引擎允许开发者定义类的构造方法。具有构造方法的类在新建时会首先调用构造方法,构造
方法适用于在正式使用该类前进行的初始化。
在PHP4中,构造方法的名称与类名相同。由于在派生类中调用父类的作法比较普遍,因此导致在
PHP4中当类在一个大型的类继承中进行移动时,处理方式有点笨拙。当一个派生类被移动到一个不同
的父类中时,父类的构造方法名必然是不同的,这样的话派生类中的有关调用父类构造方法的语句需要改写。
PHP5引入了一个定义构造方法的标准方式,通过调用它们的__construct()来定义。
示例:
<?php
class BaseClass {
function __construct() {
print "In BaseClass constructor\n";
}
}
class SubClass extends BaseClass {
function __construct() {
parent::__construct();
print "In SubClass constructor\n";
}
}
$obj = new BaseClass();
$obj = new SubClass();
?>
为向后兼容,当PHP5类不能找到__construct()方法时,会通过老的方法也就是类名
来查找构造方法。这意味着唯一可能产生兼容性问题的是在以前的代码中已经使用了
一个名为__construct()的方法名。
析构方法
定义析构方法是十分有用的。析构方法可以记录调试信息,关闭数据库连接,还有做其它的扫尾
工作。PHP4中并无此机制,尽管PHP已支持注册在请求结束时需要运行的函数。
PHP5引入了与其它面向对象语言如Java语言相似的析构方法:当最后一个该对象的引用被清除时,
系统将会在该对象从内存中释放前调用名为__destruct()的析构方法。
示例:
<?php
class MyDestructableClass {
function __construct() {
print "In constructor\n";
$this->name = "MyDestructableClass";
}
function __destruct() {
print "Destroying " . $this->name . "\n";
}
}
$obj = new MyDestructableClass();
?>
和构造方法相似,引擎将不调用父类的析构方法,为调用该方法,你需要在子
类的析构方法中通过parent::__destruct()语句进行调用。
常量
PHP 5 引入了类常量(per-class constants)定义:
<?php
class Foo {
const constant = "constant";
}
echo "Foo::constant = " . Foo::constant . "\n";
?>
PHP5允许常量中包含表达式,但在编译时常量中的表达式将被计算,
因此常量不能在运行中改变它的值。
<?php
class Bar {
const a = 1<<0;
const b = 1<<1;
const c = a | b;
}
?>
以前代码中的用户自定义类或方法中虽然未定义"const”关键字,
但无需修改就可以运行。
异常(Exceptions)
PHP4中没异常处理,PHP5引入了与其它与语言相似的异常处理模型。
<?php
class MyExceptionFoo extends Exception {
function __construct($exception) {
parent::__construct($exception);
}
}
try {
throw new MyExceptionFoo("Hello");
} catch (MyExceptionFoo $exception) {
print $exception->getMessage();
}
?>
以前代码中的用户自定义类或方法中虽未定义'catch', 'throw' 和 'try'关键字,但无需修改
就可以运行。
函数返回对象值
在PHP4中,函数不可能返回对象的值并对返回的对象进行方法调用,随着Zend Engine 2
(ZEND引擎2)的出现,以下调用成为可能:
<?php
class Circle {
function draw() {
print "Circle\n";
}
}
class Square {
function draw() {
print "Square\n";
}
}
function ShapeFactoryMethod($shape) {
switch ($shape) {
case "Circle":
return new Circle();
case "Square":
return new Square();
}
}
ShapeFactoryMethod("Circle")->
分享到:
相关推荐
然后,在2004年,PHP 5发布,基于全新的Zend Engine 2.0,提供了更好的类型支持和错误处理机制,进一步增强了面向对象编程的能力。 随着时间的推移,PHP不断进化,目前的最新稳定版本是PHP 7.x系列。这个版本带来了...
PHP 5的核心是全新的Zend Engine 2.0,它带来了更多的面向对象特性,例如命名空间、异常处理和类型提示等,同时还改进了内存管理和错误处理机制。PHP 5的发布标志着PHP进入了更加成熟和强大的阶段,吸引了众多开发者...
2004年,PHP 5发布,基于Zend Engine 2.0,它引入了PDO(PHP Data Objects)库,增强了面向对象编程的支持,同时提升了性能。PHP 5的发布标志着PHP在面向对象编程领域的一大飞跃,其对错误处理和类型安全性的改进也...
1999年,Zend公司发布PHP引擎,即ZendEngine。 有了Zend引擎的PHP4具有强大的功能和优异的性能。还支持多服务器、支持Session会话、支持输入输出缓冲等。 4. PHP5 PHP4基本可以胜任绝大多数Web应用。但是PHP4面向...
- **PHP 5**:2004年,随着Zend Engine 2.0的发布,PHP进入了5.0时代,增强了面向对象编程的支持,引入了PDO等重要特性。 #### 三、Zend Engine **1. 定义** - **定义**:Zend Engine是PHP的核心组件,由Andi ...
2014年,PHP 6的开发计划被取消,转而直接开发PHP 7,这是基于全新的Zend Engine 3.0构建的。PHP 7在2015年发布,性能显著提升,错误处理和内存管理得到了改进,同时引入了更多现代编程语言的特性。 至今,PHP已经...
- **PHP4** (1999): Andi Gutmans和Zeev Suraski重写PHP核心,并发布了Zend Engine,极大地提高了PHP的性能。 - **PHP5** (2004): 引入了更完善的面向对象编程支持,增加了CLI版本,进一步增强了PHP在大型企业级...
2000年,基于Zend Engine 1.0的PHP4面世,带来了更好的性能和面向对象编程的支持。PHP5在2004年发布,引入了PDO、增强了面向对象特性,并进行了许多性能优化。PHP4之后停止更新,鼓励用户迁移到PHP5,而PHP5.3增加了...
- **PHP5**:2004年7月13日发布,使用了第二代的Zend Engine,引入了面向对象编程的新特性,如PDO等。 - **PHP5.3**:2008年发布,增加了Late static binding等功能。 - **PHP6**:开发中,预计移除一些过时的功能...
- **2000年5月22日**:PHP4.0发布,基于全新的Zend Engine,性能提升显著。 - **2003年6月29日**:PHP 5.0发布,进一步优化了性能,增强了面向对象编程能力。 ### PHP的特性 1. **开放源码**:PHP是开源的,允许...
Zend Engine是一个开放源代码脚本引擎,以其在PHP脚本语言中的作用而闻名。 通常是服务器端脚本语言。 它是一种松散类型且灵活的语言,因此对于初学者来说很容易学习,但是结果,安全漏洞可能很快在应用程序中出现...
6. **PHP 7.0**:2015年,PHP 7的发布是一个重大飞跃,基于全新的 Zend Engine 3,它显著提高了执行速度,降低了内存消耗,并引入了更严格的语法和错误处理。 7. **PHP 8.0**:2020年,PHP 8.0发布,带来了Just-In-...