在类中的静态函数里面不能使用$this因为静态不用实例化就生成了内存空间,而类需要实例化之后才生成内存空间,两个内存不在一起所以不能互相访问。

所以下面的写法是错误的;

class Book extends Goods {
public $anthor;
public $publisher;
static public function get_author($author){
$this->author = $author;
}
}
登录后复制


也就是说只有使用对象调用非静态方法才能使用$this

非静态的方法只有确定了,对象之后才能确定$this的值

$this使用的基本原因:

1.哪个对象调用调用方法,方法内的$this就是那个对象

就像下面一样:

PHP中$this的用法和访问限定符详解-LMLPHP

这样也说明了,$this和在哪个类的位置无关,只和实例化的是哪个对象有关。

2、对象环境可以向下传递:

PHP中$this的用法和访问限定符详解-LMLPHP

如果当前方法内,已经确定了对象环境,在盖方法内如果出现了静态的调用非静态方法,那么当前的对象环境会向下传递到被静态调用的非静态方法内,

$this不是永远代表所在累的对象。

修饰限定符

public 共有的

protect 保护的

private 私有的

用于描述一个成员(属性,方法)在哪里能访问到,。

注意:

PHP是采用类的概念对成员进行修饰限定的。

PHP将访问的代码分为三个区域:类内,类外,继承链上类内。

是根据成员在哪里访问和成员在哪里定义 来决定的

以property为例

PHP中$this的用法和访问限定符详解-LMLPHP

public

公共的,指的是,成员在本类内,继承链上的类内,与类外,都可以被访问!

protect

保护的,指的是,成员在本类内,继承链(子类,父类)上的类内可以被访问

private

私有的,指的是,只有本类内,可以访问!

如何选择:

一个原则,尽量体现封装性。封装性,指的是,尽量隐藏内部实现,而仅仅开发外部操作接口!

语法上,就是,将不需要外部使用的属性,方法,都私有化(保护化),而仅仅留下一些必要的公共方法!

需要注意的是:

1、一定要先明确访问的是哪里定义的!

PHP中$this的用法和访问限定符详解-LMLPHP

2、私有成员不能被重写

只有在自己的类中才能访问到对应的私有成员

PHP中$this的用法和访问限定符详解-LMLPHP

建议是

如果需要通过继承,你就使用保护的,少用私有的!

在没有继承时,尽量使用私有的!

3、在重写时,如果重写成员的访问级别不一致。子类的级别比父类的级别,相等或者弱,可以!强,不行!

PHP中$this的用法和访问限定符详解-LMLPHP

这样是语法规定,如果想解释也是很简单的

是这样的,我简单说明
1 基类有一个方法,比如 // 我们不考虑Object作为所有类的基类啦。 呵呵呵!

public void method1(){
  method2(); // 此方法需要调用method2();
}
public void method2(){ // 如果这个方法是abstract 的话,也许会看得更清楚,不过不常见.
}
登录后复制

2 子类重写了

@Override
private void method2(){ // 当然,编译错误,我们只是用来说明这样做的问题
}
登录后复制

3 子类的子类
如果他调用 method1() 会出现什么后果呢?
a) 他能访问method1(), 因为那是他的基类,且是public
b) 但很可惜,method1()里面 却不能访问method2()了,因为在父类是private的了。

这岂不是很可笑的情况。

所以,子类不能比父类的更私有,但可以更公开。 呵呵。这样才能保证父类已经实现的代码能够使用。

另:从5.0开始,子类方法override时,可以返回与父类不同的类型。但参数必须完全相同。

4、

1, 兼容性的问题

早先的 php的面向对象不完善,没有访问控制!

在声明属性时,使用 var 关键字!

声明方法时,什么都不使用!function

为了兼容,上面的做法还是可以使用!

var, function。访问权限都是public的!

相关推荐:

详解PHP中self与$this的区别

PHP中$this指针使用实例详解

php 静态函数中$this的问题

以上就是PHP中$this的用法和访问限定符详解的详细内容,更多请关注Work网其它相关文章!

09-05 00:03