php 接口类与抽象类的实际作用

1.php 接口类:interface 
其实他们的作用很简单,当有很多人一起开发一个项目时,可能都会去调用别人写的一些类,那你就会问,我怎么知道他的某个功能的实现方法是怎么命名的呢,这个时候php接口类就起到作用了,当我们定义了一个接口类时,它里面的方式是下面的子类必须实现的,比如 :

interface Shop 

public function buy($gid); 
public function sell($gid); 
public function view($gid); 

我声明一个shop接口类,定义了三个方法:买(buy),卖(sell),看(view),那么继承此类的所有子类都必须实现这3个方法少一个都不行,如果子类没有实现这些话,就无法运行。实际上接口类说白了,就是一个类的模板,一个类的规定,如果你属于这类,你就必须遵循我的规定,少一个都不行,但是具体你怎么去做,我不管,那是你的事,如:

class BaseShop implements Shop 

public function buy($gid

echo('你购买了ID为 :'.$gid.'的商品'); 

public function sell($gid

echo('你卖了ID为 :'.$gid.'的商品'); 

public function view($gid

echo('你查看了ID为 :'.$gid.'的商品'); 

你想想,在一个多人合作的大项目里面,有了接口类是多么的方便,这样你就不用去问别人,你的某某功能的方法名是什么了,当然如果你们喜欢这样我也没有办法。 
结论 : 接口类就是一个类的领导者,指明方向,子类必须完成它指定方法。 
2.php 抽象类 : abstract 
其实抽象类和接口类有一部分很像,记得在哪里看见这样一句话,抽象类就把类像的部分抽出来,这句看上去很搞笑,其实它说出了抽象类的真理,抽象类的作用是,当你发现你的很多类里面用很多方法你不断的在重复写,那你就可以考虑使用抽象类了,你可能会说“我不是可以重写一个类每个公共类我个实例化一个这个公共类,调用相同的方法就可以了”,这里是可以,实际上抽象类做的工作也就是这个,不过他省去了你实例化的这个步骤,让你就像直接调用本类方法一样方便,而且你还可以重载这个方法。如:

abstract class BaseShop 

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),并且抽象类里都实现了这些方法,那么继承它的子类就自动获得了这些方法,子类就做它自己独特的东西,介绍代码的重复,提高复用性。 

一,接口的定义和调用
<?php  
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的抽象类有点像。

二,对参数约束比较严

  1. <?php  
  2. interface face1  
  3. {  
  4.  public function show(show $show);  
  5. }  
  6.   
  7. // 显示正常  
  8. class test implements face1  
  9. {  
  10.  public function show(show $show)  
  11.  {  
  12.  echo "asdfasdf";  
  13.  }  
  14. }  
  15.   
  16. // 报fatal错误  
  17. class test2 implements face1  
  18. {  
  19.  public function show(aaa $aaa)  
  20.  {  
  21.  }  
  22. }  
  23. ?>   

三,接口间的继承和调用接口传递参数

说明:上面的这个例子报fatal错误的,为什么会报fatal错误呢?原因就在所传参数是aaa $aaa,而不是show $show。继承接口类中,调用接口的方法时,所传参数要和接口中的参数名要一至。不然就会报错。

  1. <?php  
  2. interface face1  
  3. {  
  4.  public function show();  
  5. }  
  6.   
  7. interface face2 extends face1  
  8. {  
  9.  public function show1(test1 $test,$num);  
  10. }  
  11.   
  12. class test implements face2  
  13. {  
  14.  public function show()  
  15.  {  
  16.  echo "ok<br>";  
  17.  }  
  18.   
  19.  public function show1(test1 $test,$num)  
  20.  {  
  21.  var_dump($test);  
  22.  echo $test1->aaaa."$num<br>";  
  23.  }  
  24. }  
  25.   
  26. class test1  
  27. {  
  28.  public $aaaa="this is a test";  
  29.  function fun(){  
  30.  echo ' ===============<br>';  
  31.  }  
  32. }  
  33.   
  34. $show = new test1;  
  35. $show->fun();            //显示===============  
  36. test::show();             //显示ok  
  37. test::show1($show,6);     //object(test1)#1 (1) { ["aaaa"]=>  string(14) "this is a test" } 6  
  38. ?>  

说明:上面的例子可以看到,接口face2继承了接口face1,类test继承了接口face2。不知道你发现没有,class类test当中包括有二个方法,一个是show,一个show1,并且一个也不能少,如果少一个,报fatal错误。show1(test1$test,$num)中的test1必须根继承类的名子要一样classtest1。如果不一样,也会报fatal错误。那如果一个接口被多个类继承,并且类名又不一样,怎么办呢?那就要用self了

  1. <?php  
  2. interface Comparable {  
  3.  function compare(self $compare);  
  4. }  
  5.   
  6. class String implements Comparable {  
  7.  private $string;  
  8.  function __construct($string) {  
  9.  $this->string = $string;  
  10.  }  
  11.   
  12.  function compare(self $compare) {  
  13.  if($this->string == $compare->string){  
  14.  return $this->string."==".$compare->string."<br>";  
  15.  }else{  
  16.  return $this->string."!=".$compare->string."<br>";  
  17.  }  
  18.  }  
  19. }  
  20.   
  21. class Integer implements Comparable {  
  22.  private $integer;  
  23.  function __construct($int) {  
  24.  $this->integer = $int;  
  25.  }  
  26.   
  27.  function compare(self $compare) {  
  28.  if($this->integer == $compare->integer){  
  29.  return $this->integer."==".$compare->integer."<br>";  
  30.  }else{  
  31.  return $this->integer."!=".$compare->integer."<br>";  
  32.  }  
  33.  }  
  34. }  
  35.   
  36. $first_int = new Integer(3);  
  37. $second_int = new Integer(4);  
  38. $first_string = new String("foo");  
  39. $second_string = new String("bar");  
  40.   
  41. echo $first_int->compare($second_int);              // 3!=4  
  42. echo $first_int->compare($first_int);               // 3==3  
  43. echo $first_string->compare($second_string);        // foo!=bar  
  44. echo $first_string->compare($second_int);           // 严重错误  
  45. ?>  

原文地址:https://www.cnblogs.com/smallgo/p/3133397.html