• php抽象类和接口


    接口


    使用接口,你可以指定某个类必须实现那些方法,但是不需要定义这些方法的具体内容,我们可以通过interface来定义一个接口,就像定义标准类一样,但其中定义所有的方法都是空的,接口中定义的所有的方法都必须是public

    实现一个接口,可以使用implement操作符,类中必须实现接口中定义的所用的方法,如果实现多个接口,可以用逗号来分割多个接口的名称

    注意

    1. 实现多个接口时,接口中的方法不能有重名
    2. 接口也可以继承,通过使用extends操作符
    3. 接口中可以定义常量,接口常量和类常量的使用完全相同,他们都是定值,不能被子类或子接口修改

    例子:

    //声明接口
    interface Itemplate{
        public function setVariable($name,$var);
        public function getHtml($template);
    }
    //实现接口
    class Template implements Itemplate{
        private $vars=array();
        public function setVariable($name,$var){
            $this->vars[$name]=$var;
        }
        public function getHtml($template){
            foreach($this->vars as $names=>$value){
                $template=str_replace('{'.$names.'}',$value,$template);
            }
            return $template;
        }
    }

      例子2:

    interface a{
        public function foo();
    }
    interface b{
        public function bar();
    }
    //继承接口
    interface c extends a,b{
        public function baz();
    }
    //实现接口
    class d implements c{
        public function foo(){
             
        }
     
        public function bar(){
             
        }
        public function baz(){
             
        }
    }
     
    interface a{
        const b="hello";
    }

     

     

    抽象类

    php5支持抽象类和抽象方法。抽象类不能直接被实例化,必须先继承该抽象类,然后再实例化子类,任何一个类,如果他里面至少有一个方法是被声明为抽象的,那这个类就必须被声明为抽象的,如果类方法被声明为抽象的,那么其中就不能包括具体的功能实现

    继承一个抽象类的时候,子类必须实现抽象类中的所有的抽象方法,另外,这些方法的可见性必须和抽象类中一样(或更轻松),如果抽象类中的某个抽象方法被声明为proteected,那么子类中实现的方法应该声明为pritected或者public 

    例子:

    abstract class AbstractClass{
        //抽象方法
        abstract protected function getValue();
        abstract protected function prefieValue($p);
         
        //普通方法(非抽象方法)
        public function printOut(){
            print $this->getValue();
        }
    }
     
    class ConcreteClass1 extends AbstractClass{
        protected function getValue(){
            return "ConcreteClass1";
        }
     
        public function prefieValue($p){
            return "{$p}concreteclass1";
        }
    }
     
    class ConcreteClass2 extends AbstractClass{
        protected function getValue(){
            return "ConcreteClass2";
        }
     
        public function prefieValue($p){
            return "{$p}concreteclass2";
        }
    }
     
    $class1=new ConcreteClass1();
    $class1->printOut();
    echo $class1->prefieValue('FOO_');
    /*

      

    打印结果:ConcreteClass1

    FOO_concreteclass1

    2. 调用静态方法的抽象类仍然可行的 类常量不可以的

    abstract class Foo
    {   const a="hello";
        static function bar()
        {
            echo "test ";
        }
    }
    Foo::a;//没有输出
    Foo::bar();//test
  • 相关阅读:
    fork安全的gettid高效实现
    TCP_DEFER_ACCEPT的坑
    TCP Linger的坑
    Blade和其他构建工具有什么不同
    在Blade中结合gperftools检查内存泄露
    GraphViz web版
    用户场景分析
    java-二维数组——with 刘童格
    java-四则运算-五-网页版--with刘童格
    java-四则运算-四
  • 原文地址:https://www.cnblogs.com/aipiaoborensheng/p/4867708.html
Copyright © 2020-2023  润新知