php 高级特性,PHP面向对象高级特性初探

//实例作为函数参数传递时,在实例变量前加上类名做类型说明,因为类是一个类也是一个类型

class DomainObject() {

private $cjp;

public function getCjp() {

return $this->cjp;

}

}

class otherObject() {

function __construct(DomainObject $aObject) {

$object = $aObject;

}

}

//静态方法 static 类访问属性

//静态方法 static function 可以访问静态属性,不能访问一般属性

//不能用$this伪变量访问静态方法,可以通过self或者直接类名::

class StaticExample {

static public $sNum = 0;

static public function sayHello() {

self::$sNum++;

print "hello (".self::$sNum.")\n";

}

}

//常量属性声明  const ACOUNT

//抽象类(abstract class)定义,只定义子类需要的方法,子类继承父类具体化抽象方法

//借口 interface 纯粹的模板,子类需继承借口所有方法,一个子类可以实现任意个借口

//延迟静态绑定:static关键字

//这是在PHP5.3之后引入的。

abstract class DomainObject() {

public static function create() {

return new self();

}

}

class Document extends DomainObject {

}

Document::create();

//运行这段代码,报错:PHP Fatal error: Cannot instantiate abstract class  DomainObject in ...

//这是因为self被解析定义为create(),self是解析上下文而不是调用上下文;

//下面通过静态上下文实用继承关系:

abstract class DomainObject() {

public static function create() {

return new static();

}

}

class Document extends DomainObject {

}

print_r(Document::create());

//打印出来的是Document Object

//static 不仅仅可以用于实例化,还可以想self和parent一样作为静态方法的调用标识符

abstract class DomainObject() {

private $group;

public function __construct() {

$this->group = static::getGroup();

}

public static function create() {

return new static();

}

static function getGroup() {

return "default";

}

}

//final 终止对象的继承

final class Checkout() {

}

class secondCheck extends Checkout {

}

//运行代码报错:...may not inherit form final class...

//实用拦截器方法获取信息

class autoAction {

function __get($property) {

// 访问未定义的属性时被调用

}

function __set($property, $value) {

// 给未被定义的属性赋值时调用

}

function __isset($property) {

// 对未定义的属性调用isset()时调用

}

function __unset($property) {

// 对未定义的属性调用unset()时调用

}

function __call($method, $arg_array) {

//调用未被定义的方法是调用

}

}

//__call()方法十分有用!他可以接受两个参数,一个方法名称,一个传递给调用方法的所有参数;

//这样,__call()方法可以实现方法委托(相当于继承)和错误处理

class PersonWriter {

function writeName( Perons $p ) {

print $p->getName();

}

function writeAge( Person $p ) {

print $p->getAge();

}

}

class Person() {

private $writer;

function __construct( PersonWriter $writer ) {

$this->write = $writer;

}

function __call( $methodName, $args ) {

if ( method_exists( $this->writer, $methodName ) ) {

return $this->writer->$methodName( $this );

}

}

function getName() {

return "cjp";

}

function getAge() {

return "22";

}

}

//通过这样调用:

$person = new Person( new PersonWriter() );

$person->writeName();

//这样,person神奇的添加了两个方法,相当于继承了PersonWriter。

//委托可以节省很多时间,但代码也会变得不太清晰

//

//析构方法__construct(),当对象实例化的时候__construct()自动被执行

//析构方法__destruct(), 在对象被垃圾收集器收集之前被调用,可以做一些清理工作

?>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值