当前位置: 编程技术>php
本页文章导读:
▪探讨方法的重写(覆载)详解
代码如下:<?php class Cart{ public function Cart(){ echo "正在调用Cart()<br />"; } public function doSomething(){ echo "正在调用doSomethimg()<br />"; } } class Named_Cart extends Cart{ function N.........
▪php类常量的使用详解
注意:不像其他的面向对象编程语言,在php中,类不能对某个属性变量使用final修饰符。如果要声明某个属性为常量,可以使用const关键字,并且无需使用美元符号作为变量名前缀,也无需使.........
▪深入分析php中接口与抽象类的区别
接口和抽象类真的很难区分开,引文他们很相似,方法都没有定义逻辑,都是供子类是想或继承的。区分二者只要记住一句话:接口是规范,类是实现。接口的目的是定义一个规范,大家都.........
[1]探讨方法的重写(覆载)详解
来源: 互联网 发布时间: 2013-11-30
代码如下:
<?php
class Cart{
public function Cart(){
echo "正在调用Cart()<br />";
}
public function doSomething(){
echo "正在调用doSomethimg()<br />";
}
}
class Named_Cart extends Cart{
function Named_Cart(){
echo "正在调用Named_Cart()<br />";
}
function doSomething(){
echo "正在调用Named_Cart::doSomething()<br />";
}
}
$myCart=new Cart();
$myCart->doSomething();
$myNamed_Cart=new Named_Cart();
$myNamed_Cart->doSomething();
?>
在方法覆盖时,务必要使用与原始方法相同的约定,包括参数要一致。属性覆盖也遵循相同的约定。
在覆盖基类的方法后,使用parent关键字仍然可以调用基类的doSomething()方法,而非当前类中的doSomething()方法。
[2]php类常量的使用详解
来源: 互联网 发布时间: 2013-11-30
注意:不像其他的面向对象编程语言,在php中,类不能对某个属性变量使用final修饰符。
如果要声明某个属性为常量,可以使用const关键字,并且无需使用美元符号作为变量名前缀,也无需使用访问权限修饰符。常量意味着虽然可以访问该变量,但不能修改该变量的值。例如下边的代码声明了常量属性con_var:
<?php
class Foo{
const con_var="常量属性的值不能被修改<br />";
public function method_a(){
echo (self::con_var);
}
}
echo(Foo::con_var);
$myFoo=new Foo();
echo ($myFoo->method_a());
?>
常量属性不能使用对象访问,仅能使用类访问,在类本体内,可以使用“self::常量名”,在类本体外可以使用“类名::常量名”。
如果要声明某个属性为常量,可以使用const关键字,并且无需使用美元符号作为变量名前缀,也无需使用访问权限修饰符。常量意味着虽然可以访问该变量,但不能修改该变量的值。例如下边的代码声明了常量属性con_var:
代码如下:
<?php
class Foo{
const con_var="常量属性的值不能被修改<br />";
public function method_a(){
echo (self::con_var);
}
}
echo(Foo::con_var);
$myFoo=new Foo();
echo ($myFoo->method_a());
?>
常量属性不能使用对象访问,仅能使用类访问,在类本体内,可以使用“self::常量名”,在类本体外可以使用“类名::常量名”。
[3]深入分析php中接口与抽象类的区别
来源: 互联网 发布时间: 2013-11-30
接口和抽象类真的很难区分开,引文他们很相似,方法都没有定义逻辑,都是供子类是想或继承的。区分二者只要记住一句话:接口是规范,类是实现。接口的目的是定义一个规范,大家都遵守这个规范。
也就是说,从目的上可以很清楚地区分接口和抽象类。那么还是有疑问,既然有了借口,那么为什么还必须有抽象类呢?
加入我们要定义一个名为Animal的类,该类有两个子集Dog和Cattle,二者都有两个方法:run()方法和speak()方法。
假定Dog和Cattle的“跑(run)”是相同的,因此run()方法具有相同的业务逻辑;而“叫(speak)”是不同的,因此speak()方法的业务逻辑不同。而且,有一个IAnimal的接口规定必须有这两个方法,这意味着Animal类必须实现这两个方法,同样,Dog和Cattle这两个子类也必须有这两个方法吗,那么我们可以这样定义:
<?php
interface IAnimal{
public function run();
public function speak();
}
class Animal implements IAnimal{
public function run(){
//在这里可以添加一些相同的run逻辑
return "same run<br />";
}
public function speak(){
//这里可以添加一些相同的speak逻辑
return "same speak<br />";
}
}
class Dog extends Animal{
public function speak(){
//在这里可以添加一些Dog逻辑
return "Dog speak<br />";
}
}
class Cattle extends Animal{
public function speak(){
//在这里可以添加一些Cattle逻辑
return "Cattle speak<br />";
}
}
$oDog=new Dog();
echo($oDog->run());
echo($oDog->speak());
$oCattle=new Cattle();
echo($oCattle->run());
echo($oCattle->speak());
?>
也就是说,从目的上可以很清楚地区分接口和抽象类。那么还是有疑问,既然有了借口,那么为什么还必须有抽象类呢?
加入我们要定义一个名为Animal的类,该类有两个子集Dog和Cattle,二者都有两个方法:run()方法和speak()方法。
假定Dog和Cattle的“跑(run)”是相同的,因此run()方法具有相同的业务逻辑;而“叫(speak)”是不同的,因此speak()方法的业务逻辑不同。而且,有一个IAnimal的接口规定必须有这两个方法,这意味着Animal类必须实现这两个方法,同样,Dog和Cattle这两个子类也必须有这两个方法吗,那么我们可以这样定义:
代码如下:
<?php
interface IAnimal{
public function run();
public function speak();
}
class Animal implements IAnimal{
public function run(){
//在这里可以添加一些相同的run逻辑
return "same run<br />";
}
public function speak(){
//这里可以添加一些相同的speak逻辑
return "same speak<br />";
}
}
class Dog extends Animal{
public function speak(){
//在这里可以添加一些Dog逻辑
return "Dog speak<br />";
}
}
class Cattle extends Animal{
public function speak(){
//在这里可以添加一些Cattle逻辑
return "Cattle speak<br />";
}
}
$oDog=new Dog();
echo($oDog->run());
echo($oDog->speak());
$oCattle=new Cattle();
echo($oCattle->run());
echo($oCattle->speak());
?>
最新技术文章: