zoukankan      html  css  js  c++  java
  • 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. ?>  

  • 相关阅读:
    Go 单元测试、基准测试、并发基准测试
    Go url编码和字符转码
    ssh 登录进入 docker container
    Python 开发
    Ethereum 源码分析之 accounts
    Ethereum 源码分析之框架
    数据库视图
    共识算法:PBFT、RAFT
    JQuery Mobile
    Android Studio
  • 原文地址:https://www.cnblogs.com/smallgo/p/3133397.html
Copyright © 2011-2022 走看看