php面向对象相关技术

  • step1 一个经典类的设计和实例化

<?php
class mycoach
{
  public $_name='';
  public $_age='';
  public $_expert=array();
  public function __construct($name,$age,array $expert)

       {
    $this->_name=$name;
    $this->_age=$age;
    $this->_expert=implode("、",$expert);
  }
  public function self_introduce()
  {
    echo sprintf("大家好!我是%s,职业拳手,今年%s,我会%s,快来找我训练吧%s",$this->_name,$this->_age,$this->_expert,"<br/>");
  }
}

$cpc = new mycoach('陈培昌',21,array("散打","泰拳"));
$cpc->self_introduce();
$cj = new mycoach('程劲',19,array('散打','泰拳','巴西柔术'));
$cj->self_introduce();
?>

关键点一:函数传参的时候如果是个数组要声明数据类型为array :public function __construct($name,$age,array $expert)

关键点二:要获取数组里的值,要使用implode方法把数组炸开implode("、",$expert),第一个参数是指明用什么符号分割这些值

结果:

类公有变量访问方式 $this->变量名 = xxxx;

类常量的访问方式 类名::常量名,注意常量名之前不能带$,那是变量的作法

 

<?php
class cpcsalary
{
    const basepoint = 2000;
    public function workall($salesbonus,$coursebonus)
    {
        echo sprintf("小松鼠这个月的工资是:%f",(cpcsalary::basepoint+$salesbonus+$coursebonus));
    }
}

$cpc = new cpcsalary();
echo "小松鼠的基本工资是:".(cpcsalary::basepoint)."<br/>";
$cpc->workall(68.8,2500);
?>
结果
  •  _destruct析构方法,类实例化之后
<?php
class imcj{
    public $_name;
    public $_age;
    const nickname="小烤肠";
    public function __construct($name,$age){
        $this->_name=$name;
        $this->_age=$age;
    }
    
    public function self_construct()
    {
        echo sprintf("我是%s,昵称是%s,今年%s",$this->_name,imcj::nickname,$this->_age)."<br/>";
    }
    
    public function __destruct(){
        echo "训练这么辛苦,还要干活,馆主又不给钱,拜拜了您呐"."<br/>";
    }
}
$cj = new imcj('程劲',19);
$cj->self_construct();
?>
结果:
  •  私有属性,私有方法的类外访问
<?php
class tornado
{
    private $name="gaoyixuan";
    protected $name2="gaoyixuan我艹你妈";
    public function getname()
    {
        return $this->name;
    }
    
    private function comments($words)
    {
        echo $words;
    }
    
    public function addcomments($words)
    {
        $this->comments($words);
    }
}

$wenwa = new tornado();
echo sprintf("带人犯%s",$wenwa->getname())."<br/>";
$wenwa->addcomments("视频里人摸狗样儿的,其实他妈的不是个东西!!")
?>
结果是:
  •  演示一下子类能否调用父类的private和protected类型变量
class subtornado extends tornado
{
    public function showname()
    {
        echo "你说能打印出来么".$this->name2."<br/>";
    }
    
    public function tellthesecret() {
       echo "我觉得够呛能打印出来".$this->name."<br/>";
    }
}

$wenheichouwa = new subtornado();
$wenheichouwa->showname();
echo "============================";
$wenheichouwa->tellthesecret();
?>
打印结果:显然作为private类型的变量$name无法被子类调用,而protected类型的$name2则可以
  •  抽象类  无法被实例化,可以被继承,是一种规定好了的类的模子
  • 单一继承和多继承:注意44行那个红叉子,由于php只支持单一继承,所以多继承必须用到接口技术

某个类实现(implements)了某个接口和继承(extends)了某个类的区别?

实现接口和继承很类似,但接口不能直接创建自己的对象

继承的父类必须有该方法的具体实现,子类可以重写父类的方法,也可以不写

接口里面的方法是不需要具体实现的,只要定义了方法的名称和参数即可,具体的实现必须在实现类中定义

一句话概括: 类的方法必须有实现,接口的方法必须为空。

<?php


interface ritz{
function trainning();
function teaching();
}


interface mybf extends ritz {
function judging();
}


class mycoach implements mybf{

public $_name="";

public function __construct($name){
$this->_name = $name;
}

public function trainning()
{
printf ("%s正在训练",$this->_name);
}

public function teaching()
{
printf ("%s正在教课",$this->_name);
}

public function judging(){

printf ("%s正在裁判比赛",$this->_name);
}
}


$cpc = new mycoach('帅厉猴儿');
$cpc->trainning();
echo "<br/>";
$cpc->teaching();
echo "<br/>";
$cpc->judging();
echo "<br/>";

?>

执行结果:
  •  abstract 抽象类:无法被实例化,至少要包含一个抽象方法(其实没有也行嘿嘿嘿),没有方法体
//常规形式
abstract Class AbstractClass
{
    abstract public function A();//这里不要携带body
    abstract protected function B();//这里不要携带body
    public function C(){}//这里要携带body
}
<?php
abstract class mycoach
{
    public function sayhi(){}
    //abstract function wenwa();
}
class tianheiwa extends mycoach
{
    public $_name ="";
    public function __construct($name){
        $this->_name=$name;
    }
    public function sayhi(){
        printf( "大家好,我是%s",$this->_name);
    }
}
$cj = new tianheiwa("程劲");
$cj->sayhi();
?>
结果是:
  •  final类

final关键字,如果父类中的方法被声明为final,则子类无法覆盖该方法,如果一个类被声明为final,则不能被继承。

  •  静态类
静态方法:
从程序运行开始 就实例生成内存 ,所以可以直接调用,效率会高很多,但是静态内存是有限制的,实例太多,程序直接启动不了,静态内存会常驻
非静态方法:
实例方法开始生成内存,在调用时申请零散的内存,所以效率会慢很多 ,非静态的用完就释放了
总体来讲都各有优势,什么时候用,都视情况而定

<?php
class coachsalary
{
private static $home = "三里屯酒吧一条街";
public static $_names = array();
public function __construct(array $allname){
self::$_names = implode(",",$allname);
}
public static function whichhome()
{
printf("小伙子们原来住在%s",self::$home);
echo "<br/>";
self::$home = "仿颐园搏击公寓";
printf("%s现在住在%s",static::$_names,self::$home);
echo "<br/>";
}
}
$sniffsocks = new coachsalary(array('厉智','陈培昌','程劲'));
coachsalary::whichhome();
?>

 

posted @ 2018-11-14 16:55  saintdingtheGreat  阅读(307)  评论(0编辑  收藏  举报