Heim  >  Artikel  >  Backend-Entwicklung  >  PHP 类的一些知识点_PHP教程

PHP 类的一些知识点_PHP教程

WBOY
WBOYOriginal
2016-07-13 09:47:16864Durchsuche

PHP 类的一些知识点

1.类的定义

<code class="hljs" xml=""><!--?php
class Cart{
   var $items;
   function add_item($artnr,$num){
      $this--->items[$artnr += $num;
   }
}</code>

不能将一个类分开定义在多个文件,也不能将类定义分到多个PHP块(函数内部可以分)。
不能定义名为以下的类:
stdClass
__sleep
__wakeup
事实上不要以__开头定义类。

2.构造函数

<code class="hljs" php="">class Cart {
    var $todays_date;
    var $name;
    var $owner;
    var $items = array(VCR, TV);
    function Cart() {
        $this->todays_date = date(Y-m-d);
        $this->name = $GLOBALS[&#39;firstname&#39;];
        /* etc. . . */
    }
}</code>

类如果没有构造函数,将调用基类构造函数。
构造函数参数可以赋默认值

<code class="hljs" xml=""><!--?php
class Constructor_Cart extends Cart {
    function Constructor_Cart($item = 10, $num = 1) {
        $this--->add_item ($item, $num);
    }
}

// 买些同样的无聊老货
$default_cart = new Constructor_Cart;
// 买些实在货...
$different_cart = new Constructor_Cart(20, 17);
?></code>

@new 可以抑制发生在构造函数中的错误。

3.类的使用

<code class="hljs" lasso="">$cart = new Cart;
$cart->add_item(10, 1);</code>

类内部使用$this代表自身。

4.类相关函数

__autoload — 尝试加载未定义的类
call_user_method_array — 调用一个用户方法,同时传递参数数组(已废弃)
call_user_method — 对特定对象调用用户方法(已废弃)
class_alias — 为一个类创建别名
class_exists — 检查类是否已定义
get_called_class — 后期静态绑定(”Late Static Binding”)类的名称
get_class_methods — 返回由类的方法名组成的数组
get_class_vars — 返回由类的默认属性组成的数组
get_class — 返回对象的类名
get_declared_classes — 返回由已定义类的名字所组成的数组
get_declared_interfaces — 返回一个数组包含所有已声明的接口
get_declared_traits — 返回所有已定义的 traits 的数组
get_object_vars — 返回由对象属性组成的关联数组
get_parent_class — 返回对象或类的父类名
interface_exists — 检查接口是否已被定义
is_a — 如果对象属于该类或该类是此对象的父类则返回 TRUE
is_subclass_of — 如果此对象是该类的子类,则返回 TRUE
method_exists — 检查类的方法是否存在
property_exists — 检查对象或类是否具有该属性
trait_exists — 检查指定的 trait 是否存在

5.继承

<code class="hljs" php=""><!--?php
class Named_Cart extends Cart {
    var $owner;

    function set_owner ($name) {
        $this--->owner = $name;
    }
}
?></code>

PHP不支持多继承。

6.静态方法

<code class="hljs" php=""><!--?php
class A {
    function example() {
        echo I am the original function A::example().<br /-->
;
    }
}

class B extends A {
    function example() {
        echo I am the redefined function B::example().

;
        A::example();
    }
}

// A 类没有对象,这将输出
//   I am the original function A::example().

A::example();

// 建立一个 B 类的对象
$b = new B;

// 这将输出
//   I am the redefined function B::example().

//   I am the original function A::example().

$b->example();
?></code>

7.基类引用 parent

<code class="hljs" php=""><!--?php
class A {
    function example() {
        echo I am A::example() and provide basic functionality.<br /-->
;
    }
}

class B extends A {
    function example() {
        echo I am B::example() and provide additional functionality.

;
        parent::example();
    }
}

$b = new B;

// 这将调用 B::example(),而它会去调用 A::example()。
$b->example();
?></code>

8.序列化

<code class="hljs" php=""><!--?php
// classa.inc:
  class A {
      var $one = 1;

      function show_one() {
          echo $this--->one;
      }
  }

// page1.php:
  include(classa.inc);

  $a = new A;
  $s = serialize($a);
  // 将 $s 存放在某处使 page2.php 能够找到
  $fp = fopen(store, w);
  fwrite($fp, $s);
  fclose($fp);

// page2.php:
  // 为了正常解序列化需要这一行
  include(classa.inc);

  $s = implode(, @file(store));
  $a = unserialize($s);

  // 现在可以用 $a 对象的 show_one() 函数了
  $a->show_one();
?></code>

9.魔术函数 __sleep __wakeup

10.允许数组方式访问对象属性

方法1

function obj2array(obj){
return new ArrayObject(obj, ArrayObject::ARRAY_AS_PROPS);
}
这个方法比较简单,另一个方法要继承ArrayAccess要复杂一点。

11.数组转对象

<code class="hljs" php="">    /**
     * 数组转对象
     * @param unknown $e
     * @return void|StdClass
     */
    public static function arrayToObject($e){
        if( gettype($e)!=&#39;array&#39; ) return;
        foreach($e as $k=>$v){
            if( gettype($v)==&#39;array&#39; || getType($v)==&#39;object&#39; )
                $e[$k]=(object)arrayToObject($v);
        }
        return (object)$e;
    }</code>

12 自己实现的序列化与反序列化

用在redis时比较方便:

<code class="hljs" php="">    /**
     * 序列化对象,返回$json字符串
     */
    public static function serialize($model){
        //return serialize($model);
        if(!$model)return &#39;{}&#39;;
        $json=&#39;{&#39;;
        foreach($model as $key2=>$value2){
            if($json!=&#39;{&#39;)$json.=&#39;,&#39;;
            $json.=$key2:$value2;
        }
        $json.=&#39;}&#39;;


        return $json;
    }
    public static function unserialize($json){
        $json=str_replace(&#39;{&#39;, &#39;&#39;, $json);
        $json=str_replace(&#39;}&#39;,&#39;&#39;,$json);
        $array=explode(&#39;,&#39;, $json);
        $result=[];
        foreach($array as $key =>$value){
            $temparr=explode(&#39;,&#39;,$value);
            $temparr1=explode(&#39;:&#39;,$temparr[0]);

            if(count($temparr1)==0)continue;
            $result[$temparr1[0]]=trim( $temparr1[1],&#39;&#39;);
        }
        //$obj=  (object)($result);

        return obj2array($result);
        //return $result;
    }</code>

 

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/1027126.htmlTechArticlePHP 类的一些知识点 1.类的定义 items[$artnr += $num; }} 不能将一个类分开定义在多个文件,也不能将类定义分到多个PHP块(函数内部可以分)。...
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn