php面向对象精要(1)
1、静态属性与方法
每一个类的实例拥有自己的属性和方法,每一个类也可以包含静态属性,静态属性不属于类的任何实例,可以把静态属性理解成存储在类中的全局变量,可以在任何地方通过类名引用静态属性。
<?php
class MyClass {
static $a = 0;
function getValue(){
return self::$a;
}
} $obj = new MyClass();
echo $obj->getValue() . PHP_EOL; echo MyClass::$a . PHP_EOL;
?>
2,静态属性的应用-----把一个唯一的id传递到类的所有实例中
<?php
class MyClass {
static $count = 0;
public $unique_id;
function __construct(){
self::$count++;
$this->unique_id = self::$count;
}
} $obj1 = new MyClass();
echo $obj1->unique_id . PHP_EOL;
$obj2 = new MyClass();
echo $obj2->unique_id . PHP_EOL;
?>
3,静态方法
<?php
class HelloWorld {
static function sayHello(){
print "Hello World";
self::printNewLine();
} static function printNewLine(){
echo PHP_EOL;
}
}
HelloWorld::sayHello();
HelloWorld::sayHello();
?>
4,类的常量
>全局常量用 define函数定义
>类的常量与静态成员类似,他们属于类本身,而不是类的实例
>类的常量对大小写敏感
<?php
class MyColorEnumClass {
const RED = "red";
const GREEN = "green";
const BLUE = "blue"; static function printColor(){
print self::RED . PHP_EOL;
print self::GREEN . PHP_EOL;
print self::BLUE . PHP_EOL;
}
} MyColorEnumClass::printColor();
?>
5,对象克隆
在php5中,对象赋值,其实是引用 , 如果需要拷贝对象,用克隆关键字clone
<?php
class MyClass {
public $var = 1;
} $obj1 = new MyClass();
//$obj2 = $obj1;
$obj2 = clone $obj1;
$obj2->var = 2;
//使用$obj2 = $obj1, 下面输出2
//使用$obj2 = clone $obj1, 下面输出1
echo $obj1->var . PHP_EOL; ?>
6,多态
下面这个实例,如果想要再增加一种动物,那么需要改动2处,需要增加动物类和方法,而且需要在printTheRightSound方法中增加一个elseif分支,这种设计对于代码维护和分离非常不友好
<?php
class Cat{
function miao(){
echo "cat";
}
} class Dog{
function wang(){
echo "dog";
}
} function printTheRightSound( $obj ){
if( $obj instanceof Cat ) {
$obj->miao();
}else if ( $obj instanceof Dog ) {
$obj->wang();
}else {
echo "传递了错误的对象类型";
}
echo PHP_EOL;
} printTheRightSound( new Cat() );
printTheRightSound( new Dog() );
?>
我们可以用继承的优势,改造上面的缺点
<?php
abstract class Animal {
abstract function makeSound();
}
class Cat extends Animal{
function makeSound(){
echo "cat";
}
}
class Dog extends Animal{
function makeSound(){
echo "dog";
}
}
class Chicken extends Animal {
function makeSound(){
echo "chicken";
}
} function printTheRightSound( $obj ){
if( $obj instanceof Animal ) {
$obj->makeSound();
}else {
echo "传递了错误的对象类型";
}
echo PHP_EOL;
} printTheRightSound( new Cat() );
printTheRightSound( new Dog() );
printTheRightSound( new Chicken() );
?>
这样改造之后,printTheRightSound就不需要改动,只需要添加对应的动物类和方法即可
php面向对象精要(1)的更多相关文章
- 《javascript面向对象精要》读书笔记
<javascript面向对象精要> 买这本书的原因主要是因为作者,Nicholas C. Zakas 牛X闪闪的js专家,读过js高程的应该都知道他,而这本书是他的最新力作,感觉也是js ...
- 03.JavaScript 面向对象精要--理解对象
JavaScript 面向对象精要--理解对象 尽管JavaScript里有大量内建引用类型,很可能你还是会频繁的创建自己的对象.JavaScript中的对象是动态的. 一.定义属性 当一个属性第1次 ...
- javascript面向对象精要第三章对象整理精要
什么是对象的数据属性?什么是对象的访问器属性?[put]方法是默认创建数据属性的,访 问器属性不包含值而是定义了一个单属性被读取时调用的函数(getter)和当一个属性被写入时 调用的函数(sette ...
- 02.JavaScript 面向对象精要--函数
在JavaScript中,函数其实也是对象.是函数不同于其他对象的特点是:函数存在一个被称为[[Call]]的内部属性.[[Call]]属性是函数独有的,表明该对象可以被执行.ECMAScript 定 ...
- 01.JavaScript 面向对象精要--原始类型和引用类型
一.什么是类型 JavaScript 虽然没有类的概念.但依然存在两种类型:原始类型和应用类型. 原始类型保存为简单的数据值,引用类型则保存为对象,其本质是指向内存位置 的引用.也就是说:原始值被直接 ...
- JavaScript面向对象精要(一)
数据类型 在JavaScript中,数据类型分为两类: 原始类型:保存一些简单数据,如true.5等.JavaScript共同拥有5中原始类型: boolean:布尔.值为true或false num ...
- JavaScript面向对象精要
来自:淡忘~浅思. 链接:http://www.ido321.com/1585.html 和 http://www.ido321.com/1586.html 数据类型 在JavaScript中,数 ...
- javascript面向对象精要第六章对象模式整理精要
混入是一种给对象添加功能同时避免继承的强有力的方式,混入时将一个属性从一个对象 复制到另一个,从而使得接收者在不需要继承的情况下获得其功能.和继承不同,混入之后 对象无法检查属性来源.因此混入最适宜用 ...
- javascript面向对象精要第五章继承整理精要
javascript中使用原型链支持继承,当一个对象的[prototype]设置为另一个对象时, 就在这两个对象之间创建了一条原型对象链.如果要创建一个继承自其它对象的对象, 使用Object.cre ...
- javascript面向对象精要第四章构造函数和原型对象整理精要
随机推荐
- [学习笔记]后缀自动机SAM
好抽象啊,早上看了两个多小时才看懂,\(\%\%\%Fading\) 早就懂了 讲解就算了吧--可以去看看其他人的博客 1.[模板]后缀自动机 \(siz\) 为该串出现的次数,\(l\) 为子串长度 ...
- matlab中元胞数组的创建与内容读取
一.创建元胞数组 1.用cell命令创建规格为2*2的空元胞 >> a=cell(2,2) a = [] [] [] [] 2.用大括号"{}"创建元胞数组并赋值 &g ...
- gdb调试正在运行的程序
1.ps aux | grep mxx.exe 查找可执行程序的进程id 2.gdb attach pid attach可执行程序的进程pid 3.continue/c 或者continue or c ...
- ASP.NET状态管理的总结
阅读目录 开始 hidden-input QueryString Cookie ApplicationState ViewState,ControlState Session Profile 各种状态 ...
- JavaScript --Window-对话框
-----038-Window-对话框.html----- <!DOCTYPE html> <html> <head> <meta http-equiv=&q ...
- .net 中 C# 简单自定义事件实现
个人认为事件处理机制是一种很好的机制 特别是可以方便安全的实现窗口间(子窗口对父窗口,子窗口间等)的消息传递.功能调用 下面展现的源自以前论坛上看到的一套方法,可能记得不大准确,所以可能不规范,我的理 ...
- C/C++求职宝典21个重点笔记(常考笔试面试点)
这是我之前准备找工作时看<C/C++求职宝典>一书做的笔记,都是一些笔试面试中常考的重点难点问题,但比较基础,适合初学者看. 1. char c = '\72'; 中的\72代表一个字符, ...
- Tomcat学习总结(11)——Linux下的Tomcat安全优化
1.web.xml配置及修改: 站点默认主页: <welcome-file-list> <welcome-file>index.html</welcome-file> ...
- 使用Unicode字符实现换行
要让inline元素换行可以使用Unicode字符实现: <!DOCTYPE html> <html lang="en"> <head> < ...
- es6学习笔记3--解构和对象
1.解构 在接收数据的地方(比如赋值的左边),解构使你使用模式去获取部分数据. 下面的代码是解构的一个例子: let obj = { first: 'Jane', last: 'Doe' }; let ...