php 面向对象self用法,PHP面向对象编程之 this、self、parent详解

PHP5是一具备了大部分面向对象语言的特性的语言,比PHP4有了很多的面向对象的特性,但是有部分概念也比较绕人,所以今天拿出来说说,说的不好,请高手见谅. (阅读本文,需要了解PHP5的面向对象的知识)

首先我们来明白上面三个关键字: this,self,parent,从字面上比较好理解,是指这,自己,父亲,呵呵,比较好玩了,我们先建立几个概念,这三个关键字分别是用在什么地方呢?我们初步解释一下,this是指向当前对象的指针(我们姑且用C里面的指针来看吧),self是指向当前类的指针,parent是指向父类的指针。我们这里频繁使用指针来描述,是因为没有更好的语言来表达,呵呵,语文没学好。

这么说还不能很了解,那我们就根据实际的例子结合来讲讲。

(1) this

class UserName

{

//定义属性

private $name;

//定义构造函数

function __construct( $name )

{

$this->name = $name; //这里已经使用了this指针

}

//析构函数

function __destruct(){}

//打印用户名成员函数

function printName()

{

print( $this->name ); //又使用了this指针

}

}

//实例化对象

$nameObject = new UserName( "heiyeluren" );

//执行打印

$nameObject->printName(); //输出: heiyeluren

//第二次实例化对象

$nameObject2 = new UserName( "PHP5" );

//执行打印

$nameObject2->printName(); //输出:PHP5

?>

class UserName

{

//定义属性

private $name;

//定义构造函数

function __construct( $name )

{

$this->name = $name; //这里已经使用了this指针

}

//析构函数

function __destruct(){}

//打印用户名成员函数

function printName()

{

print( $this->name ); //又使用了this指针

}

}

//实例化对象

$nameObject = new UserName( "heiyeluren" );

//执行打印

$nameObject->printName(); //输出: heiyeluren

//第二次实例化对象

$nameObject2 = new UserName( "PHP5" );

//执行打印

$nameObject2->printName(); //输出:PHP5

?>

我们看,上面的类分别在两个地方使用了this指针,那么当时this是指向谁呢?其实this是在实例化的时候来确定指向谁,比如第一次实例化对象的时候,那么当时this就是指向$nameObject对象,那么执行打印的时候就把print( $this->name ),那么当然就输出了”heiyeluren”。第二个实例的时候,print( $this->name )变成了print( $nameObject2->name ),于是就输出了”PHP5″。所以说,this就是指向当前对象实例的指针,不指向任何其他对象或类。

(2) self

首先我们要明确一点,self是指向类本身,也就是self是不指向任何已经实例化的对象,一般self使用来指向类中的静态变量。

class Counter

{

//定义属性,包括一个静态变量

private static $firstCount = 0;

private $lastCount;

//构造函数

function __construct()

{

$this->lastCount = ++selft::$firstCount; //使用self来调用静态变量,使用self调用必须使用::(域运算符号)

}

//打印最次数值

function printLastCount()

{

print( $this->lastCount );

}

}

//实例化对象

$countObject = new Counter();

$countObject->printLastCount(); //输出 1

?>

class Counter

{

//定义属性,包括一个静态变量

private static $firstCount = 0;

private $lastCount;

//构造函数

function __construct()

{

$this->lastCount = ++selft::$firstCount; //使用self来调用静态变量,使用self调用必须使用::(域运算符号)

}

//打印最次数值

function printLastCount()

{

print( $this->lastCount );

}

}

//实例化对象

$countObject = new Counter();

$countObject->printLastCount(); //输出 1

?>

我们在第二行定义了一个静态变量$firstCount,并且初始值为0,那么在调用了这个值得,使用的是self来调用,并且中间使用”::”来连接,就是我们所谓的域运算符,那么这时候我们调用的就是类自己定义的静态变量$frestCount,我们的静态变量与下面对象的实例无关,它只是跟类有关,那么我调用类本身的的,那么我们就无法使用this来引用,可以使用self来引用,因为self是指向类本身,与任何对象实例无关。换句话说,假如我们的类里面静态的成员,我们也必须使用self来调用。

(3) parent

我们知道parent是指向父类的指针,一般我们使用parent来调用父类的构造函数。

//基类

class Animal

{

//基类的属性

public $name; //名字

//基类的构造函数

public function __construct( $name )

{

$this->name = $name;

}

}

//派生类

class Person extends Animal //Person类继承了Animal类

{

public $personSex; //性别

public $personAge; //年龄

//继承类的构造函数

function __construct( $personSex, $personAge )

{

parent::__construct( "heiyeluren" ); //使用parent调用了父类的构造函数

$this->personSex = $personSex;

$this->personAge = $personAge;

}

function printPerson()

{

print( $this->name. " is " .$this->personSex. ",this year " .$this->personAge );

}

}

//实例化Person对象

$personObject = new Person( "male", "21");

//执行打印

$personObject->printPerson(); //输出:heiyeluren is male,this year 21

?>

//基类

class Animal

{

//基类的属性

public $name; //名字

//基类的构造函数

public function __construct( $name )

{

$this->name = $name;

}

}

//派生类

class Person extends Animal //Person类继承了Animal类

{

public $personSex; //性别

public $personAge; //年龄

//继承类的构造函数

function __construct( $personSex, $personAge )

{

parent::__construct( "heiyeluren" ); //使用parent调用了父类的构造函数

$this->personSex = $personSex;

$this->personAge = $personAge;

}

function printPerson()

{

print( $this->name. " is " .$this->personSex. ",this year " .$this->personAge );

}

}

//实例化Person对象

$personObject = new Person( "male", "21");

//执行打印

$personObject->printPerson(); //输出:heiyeluren is male,this year 21

?>

我们注意这么几个细节:成员属性都是public的,特别是父类的,是为了供继承类通过this来访问。我们注意关键的地方 parent::__construct( “heiyeluren” ),这时候我们就使用parent来调用父类的构造函数进行对父类的初始化,因为父类的成员都是public的,于是我们就能够在继承类中直接使用 this来调用。

(本文出处不详,本博客不对文章保留任何版权)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值