PHP5面向对象增加了类成员的访问控制。但是,这一点,表面上易于理解,但很多人实际是并不理解的。究其原因,主要是没有能够明白访问控制是如何定义的。
首先,PHP定义访问控制与传统面向对象一样,定立了三个分级权限,Public:公有,Protected:保护,Private:私有。同时,还有静态成员,实际是应当算是四个权限。或者说是六种组合。
先分别介绍一下三个分级权限:
Public:公有——实际就是开放的,只要是在应用中,任一地方,通过对象的实例,均可以对其访问。
Protected:保护——仅对子类开放。这就是说,只有两个区域中能够访问到:其一,当前类的成员方法当中的代码。其二,通过继承当前类生成的子类中成员方法的代码。其它地方均是不可访问的。
Private:私有——说白了,就是自己用的。这就是说只有当前类的成员方法中的代码可以访问。
这里要注意一下:我说的是:“当前类的成员方法中的代码”。因此,并不限是普通方法,还是静态方法。所以,你在静态方法中创建一个当前类的实例,那么,此实例是能够访问到该私有方法的。
为什么要这么做?这实际上是必须的。比如,设计模式中的单件模式,它是将构造函数私有化,然后在通常名为getInstance()的方法中判断此类有没有实例化。保证该类只有单例存在。
所以,无论是:实例名->私有方法,还是$this->私有方法,均是可以访问的。但“实例名->私有方法”必须是在类的成员方法之中。这就是说:私有的访问代码只要求是在当前类的class{}之中,而不是在外面就可以访问。
不妨再看看单例的实现代码:
class phpApp{
static private $instance;
private $name;
private __contruct($name){
$this->name=$name;
}
static public getInstance($name){
if (!isset(self::$instance){
//这里实际是访问的私有的构造函数
self::$instance=new phpApp($name);
}
return self::$instance;
}
}
再说静态,静态实际上是,把数据或方法交给类。由类来掌管。上面单例模式中,由类来掌管的有两个,第一是保存类实例的变量:$instance,因为只能有一个,所以,由类来管理最合适。同样,getInstance方法也是,它要保证无论是否实例化,均能访问到。
实际开发中,我们有时,不知此方法或此属性交给类好,还是交给实例好。不妨这样想一下,这仍是访问控制。为什么这么说呢?只要是交给类管理的静态属性或方法,那么,你的应用中永远只有一个。
假如说,你做一个链表。那么,每一个节点都是一个类。链表中有一项属性,是配置数据$config,很多初学者就不清楚它要定义成静态的(static)。这就是一个基本常识错误。想一想,不管有多少节点,节点创建,或其中函数运行时,要用到的配置,当且仅当只需要一个,这就足够了。如果其配置仅希望构造函数时传入,则就可以定义为: static private $config, 也许,你会说:这样问题来了。我仍每次创建子节点时要传入配置呀。其实不是这样的。唯有根节点传入一次即可。这就是说:将这个参数设为可选参数,如果传入了,就保存,否则,就不保存。代码如下:
class node{
static private $config;
private $name;
private __contruct($config = NULL){
if ($config != NULL)
self::$config=$config;
}
}
相当简单吧。但如果没有弄明白时,可能还是不知怎么做。每个节点都保存配置,既浪费时间,也浪费空间!
分享到:
相关推荐
在PHP编程语言中,类是面向对象编程的基本组成部分之一,而成员变量与方法则是构成类的重要元素。在本文中,我们将深入探讨类中的成员变量及其访问限制符:`public`、`private` 和 `protected` 的用法及作用。 ### ...
PHP 中的访问控制修饰符 在 PHP 的面向对象编程中,访问控制修饰符是...PHP 中的访问控制修饰符(public、protected 和 private)可以控制类的成员属性和成员方法的访问范围,帮助开发者更好地管理类的成员访问权限。
PHP IP访问控制
完整的PHP访问公共类,可以执行SQL的增删改查操作!
这篇博客“面向对象设计 4 —— PHP5面向对象进阶(属性的访问控制)”着重讲解了如何在PHP5中通过访问控制来保护类的内部状态,确保代码的封装性和安全性。 在PHP5中,我们可以为类的属性设置三种访问修饰符:public...
分析了php中静态类与静态变量用法类的区别,创建对象$object = new Class(),然后使用”->”调用:$object->attribute/function,前提是该变量/方法可访问。直接调用类方法量:class::attribute/function,无论是静态/...
在Web开发中,权限控制是一个不可或缺的重要环节,它能确保用户只能访问他们被授权的资源,从而保障系统的安全性和稳定性。ThinkPHP,作为国内广泛使用的PHP框架,提供了强大的权限管理功能,特别是基于角色的访问...
在TP框架中,默认控制器是指当用户直接访问网站根目录而没有指定特定的控制器时,系统将自动加载并执行的控制器。通过设置默认控制器,可以方便地控制用户的初始访问行为,例如让用户首先看到登录页面、主页或其他...
类的成员可以用`static`关键字声明为静态,静态成员在类的实例之间共享,无需通过对象即可访问: ```php class Counter { static $count = 0; public function increment() { self::$count++; } } ``` 在...
在PHP中,这可以通过创建权限等级、角色类或者使用框架提供的安全组件来实现。 实现这一功能时,一种常见方法是在用户登录时生成一个会话(session)或令牌(token),并将用户的权限信息存储在会话或数据库中。...
在3.8.1章节,我们探讨了如何创建和使用类的拓展知识,特别是成员变量和成员方法,以及如何在类的内部访问它们。此外,还强调了`self`关键字的作用和用法。 成员变量,也称为实例变量,是属于类的实例的变量。在类...
在PHP中,属性可以声明为公有(public)、私有(private)或保护(protected),以控制其访问权限。 ```php class MyClass { public $publicVar; private $privateVar; protected $protectedVar; } ``` 3. ...
1. 连接SQL Server:PHP中可以使用mssql_connect或sqlsrv_connect函数来连接SQL Server,但这里提到的是一个类,那么它可能会封装这两个函数,提供一个更友好的连接方法,例如`connect($serverName, $username, $...
在PHP开发中,数据库访问是不可或缺的一部分,而封装数据库访问类可以提高代码的可复用性和维护性。本文将深入探讨“php数据库访问封装类集合”这一主题,它包含了多种数据库访问实现方式,旨在为开发者提供更多的...
该框架的核心设计理念是实现应用中的访问控制策略,确保只有授权的用户或服务可以访问特定的资源。PHPCasbin支持多种访问控制模型,包括传统的访问控制列表(ACL)、基于角色的访问控制(RBAC)以及属性基访问控制...
在PHP中,我们可以创建一个简单的计数器,通常存储在数据库或文本文件中。每当有新的用户访问时,我们检查他们的IP地址,如果这是他们第一次访问,计数器加一。IP地址是识别不同用户的一种方式,但要注意,由于网络...
这个习题旨在帮助学习者理解如何在PHP中定义和使用类,以及如何通过成员变量存储数据和成员方法处理这些数据。此外,它还涵盖了面向对象编程的基本概念,如封装(通过访问修饰符限制成员的访问)和对象的实例化。...
9. **属性访问器和修改器(Accessors & Mutators)**:也称为getter和setter方法,用于控制对类属性的访问,以保护数据的安全性。 10. **静态属性和方法**:使用`static`关键字声明的属性和方法属于类本身,而不是...
总之,`php Cookies 操作控制类`为开发者提供了一套完整的工具,以更高效、更安全的方式管理Cookies,确保数据的正确存储和访问,同时避免命名冲突和控制数据生命周期。通过这个类,你可以更好地组织和控制PHP应用...
而`demo.php`可能是使用这个类的一个示例代码,演示如何在实际场景中初始化RedisLock对象,调用`lock`和`unlock`方法来控制并发访问。 总结来说,这个PHP类利用Redis的特性实现了一种并发控制策略,通过获取和释放...