1.php 接口类:interface
其实他们的作用很简单,当有很多人一起开发一个项目时,可能都会去调用别人写的一些类,那你就会问,我怎么知道他的某个功能的实现方法是怎么命名的呢,这个时候php接口类就起到作用了,当我们定义了一个接口类时,它里面的方式是下面的子类必须实现的,比如 :
{
public function buy($gid);
public function sell($gid);
public function view($gid);
}
我声明一个shop接口类,定义了三个方法:买(buy),卖(sell),看(view),那么继承此类的所有子类都必须实现这3个方法少一个都不行,如果子类没有实现这些话,就无法运行。实际上接口类说白了,就是一个类的模板,一个类的规定,如果你属于这类,你就必须遵循我的规定,少一个都不行,但是具体你怎么去做,我不管,那是你的事,如:
{
public function buy($gid)
{
echo('你购买了ID为 :'.$gid.'的商品');
}
public function sell($gid)
{
echo('你卖了ID为 :'.$gid.'的商品');
}
public function view($gid)
{
echo('你查看了ID为 :'.$gid.'的商品');
}
}
你想想,在一个多人合作的大项目里面,有了接口类是多么的方便,这样你就不用去问别人,你的某某功能的方法名是什么了,当然如果你们喜欢这样我也没有办法。
结论 : 接口类就是一个类的领导者,指明方向,子类必须完成它指定方法。
2.php 抽象类 : abstract
其实抽象类和接口类有一部分很像,记得在哪里看见这样一句话,抽象类就把类像的部分抽出来,这句看上去很搞笑,其实它说出了抽象类的真理,抽象类的作用是,当你发现你的很多类里面用很多方法你不断的在重复写,那你就可以考虑使用抽象类了,你可能会说“我不是可以重写一个类每个公共类我个实例化一个这个公共类,调用相同的方法就可以了”,这里是可以,实际上抽象类做的工作也就是这个,不过他省去了你实例化的这个步骤,让你就像直接调用本类方法一样方便,而且你还可以重载这个方法。如:
{
public function buy($gid)
{
echo('你购买了ID为 :'.$gid.'的商品');
}
public function sell($gid)
{
echo('你卖了ID为 :'.$gid.'的商品');
}
public function view($gid)
{
echo('你查看了ID为 :'.$gid.'的商品');
}
}
class BallShop extends BaseShop
{
var $itme_id = null;
public function __construct()
{
$this->itme_id = 2314;
}
public function open()
{
$this->sell($this->itme_id);
}
}
这里是一个例子,想上面一样我定义了一个商店类,抽出了它所有像的部分,买(buy),卖(sell),看(view),并且抽象类里都实现了这些方法,那么继承它的子类就自动获得了这些方法,子类就做它自己独特的东西,介绍代码的重复,提高复用性。
interface face1
{
const param = 'test';
public function show();
}
class test implements face1
{
public function show()
{
echo "interface is run<br>";
}
}
$face = new test();
echo $face->show(); //inerface is run
echo face1::param; //test
?>
说明:上面的例子要注意一点,接口的方法名是show,继承接口的类中必须有show这个方法,要不然就会报错。也就是说接口的方法是假的,真正起作用的是在继承的类中的方法,就是因为这一点,所以我觉得,接口根php的抽象类有点像。
二,对参数约束比较严
- <?php
- interface face1
- {
- public function show(show $show);
- }
- // 显示正常
- class test implements face1
- {
- public function show(show $show)
- {
- echo "asdfasdf";
- }
- }
- // 报fatal错误
- class test2 implements face1
- {
- public function show(aaa $aaa)
- {
- }
- }
- ?>
三,接口间的继承和调用接口传递参数
说明:上面的这个例子报fatal错误的,为什么会报fatal错误呢?原因就在所传参数是aaa $aaa,而不是show $show。继承接口类中,调用接口的方法时,所传参数要和接口中的参数名要一至。不然就会报错。
- <?php
- interface face1
- {
- public function show();
- }
- interface face2 extends face1
- {
- public function show1(test1 $test,$num);
- }
- class test implements face2
- {
- public function show()
- {
- echo "ok<br>";
- }
- public function show1(test1 $test,$num)
- {
- var_dump($test);
- echo $test1->aaaa."$num<br>";
- }
- }
- class test1
- {
- public $aaaa="this is a test";
- function fun(){
- echo ' ===============<br>';
- }
- }
- $show = new test1;
- $show->fun(); //显示===============
- test::show(); //显示ok
- test::show1($show,6); //object(test1)#1 (1) { ["aaaa"]=> string(14) "this is a test" } 6
- ?>
说明:上面的例子可以看到,接口face2继承了接口face1,类test继承了接口face2。不知道你发现没有,class类test当中包括有二个方法,一个是show,一个show1,并且一个也不能少,如果少一个,报fatal错误。show1(test1$test,$num)中的test1必须根继承类的名子要一样classtest1。如果不一样,也会报fatal错误。那如果一个接口被多个类继承,并且类名又不一样,怎么办呢?那就要用self了
- <?php
- interface Comparable {
- function compare(self $compare);
- }
- class String implements Comparable {
- private $string;
- function __construct($string) {
- $this->string = $string;
- }
- function compare(self $compare) {
- if($this->string == $compare->string){
- return $this->string."==".$compare->string."<br>";
- }else{
- return $this->string."!=".$compare->string."<br>";
- }
- }
- }
- class Integer implements Comparable {
- private $integer;
- function __construct($int) {
- $this->integer = $int;
- }
- function compare(self $compare) {
- if($this->integer == $compare->integer){
- return $this->integer."==".$compare->integer."<br>";
- }else{
- return $this->integer."!=".$compare->integer."<br>";
- }
- }
- }
- $first_int = new Integer(3);
- $second_int = new Integer(4);
- $first_string = new String("foo");
- $second_string = new String("bar");
- echo $first_int->compare($second_int); // 3!=4
- echo $first_int->compare($first_int); // 3==3
- echo $first_string->compare($second_string); // foo!=bar
- echo $first_string->compare($second_int); // 严重错误
- ?>