文章來源:PHPBuilder.com
原作者:Luis Argerich
翻譯:erquan
erquan注:本人現還未來得及體驗PHP5,只是翻譯一篇老外的文章。
以下均由erquan翻譯,第1次作這些的事情希望沒有誤導大家。有些 " /> 久操视频免费看,欧美大胆一级视频,日韩在线视

一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

第1次親密接觸PHP5(1)


文章來源:phpBuilder.com
原作者:Luis Argerich
翻譯:erquan
erquan注:本人現還未來得及體驗php5,只是翻譯一篇老外的文章。
以下均由erquan翻譯,第1次作這些的事情希望沒有誤導大家。有些不準的地方請諒解。
大家看這樣的行不行,如果行的話,偶就翻譯完,不行就翻譯了,免得誤導了大家,也累哦。。。。:)
轉貼時請注明文章來源,謝謝:)


php5的正式版還沒發布,但我們可以學習、體驗下開發版給我們帶來的php新特性。
本文將集中介紹以下3大php5新功能:
* 新對象模式
* 結構化異常處理
* 名稱空間

在正式開始之前,請注意:
*文章中的部分例子用php4的方法實現,只是為了增強文章的可讀性
*本文所描述的新特性可能會與正式版特性有出入,請以正式版本為準。

* 新對象模式

php5新的對象模式在php4的基礎上做了很大的"升級",你看起來會很像Java:(。
下面的一些文字將對它做一些簡單介紹,并且附有小例子讓您開始體驗php5的新特性
come on~~:)

* 構造函數 和 析構函數
* 對象的引用
* 克隆對象
* 對象的3種模式:私有、公共和受保護
* 接口
* 虛擬類
* __call()
* __set()和__get()
* 靜態成員

構造函數 和 析構函數

php4中,和類名一樣的函數被默認為該類的構造器,并且在php4沒有析構函數的概念。(二泉 注:這點和Java一樣)
但從php5開始,構造函數被統一命名為 __construct,而且有了析構函數:__destruct(二泉 注:這點卻和Delphi一樣,可見php5吸收了眾多的成熟的OO思想,可C可賀~~):
例1:構造函數和析構函數

<?php
class foo {
  var $x;

  function __construct($x) {
    $this->x = $x;
  }

  function display() {
    print($this->x);
  }

  function __destruct() {
    print("bye bye");
  }
}

$o1 = new foo(4);
$o1->display();
?>

運行完你將看到輸出了"bye bye",這是因為類在終止的時候調用了__destruct()析構函數~~

對象的引用

正如你所知道的一樣,在php4中,對一個函數或方法傳遞一個變量時,實際上是傳遞了一個copy,除非你用了傳址符&來聲明
你在做一個變量的引用。在php5中,對象總是以引用的方式被指定:
例2:對象的引用

<?php
class foo {
  var $x;

  function setX($x) {
    $this->x = $x;
  }

  function getX() {
    return $this->x;
  }
}

$o1 = new foo;
$o1->setX(4);
$o2 = $o1;
$o1->setX(5);
if($o1->getX() == $o2->getX()) print("Oh my god!");
?>

(二泉 注:你將看到"Oh my god!"的輸出)
克隆對象

如上,如果有時不想得到對象的引用而想用copy時,怎么辦?在php5提供的 __clone 方法中實現:
例3:克隆對象

<?php
class foo {
  var $x;

  function setX($x) {
    $this->x = $x;
  }

  function getX() {
    return $this->x;
  }
}

$o1 = new foo;
$o1->setX(4);
$o2 = $o1->__clone();
$o1->setX(5);

if($o1->getX() != $o2->getX()) print("Copies are independant");
?>

克隆對象的方法在已被應用到很多語言中,所以你不必擔心它的性能:)。

Private, Public 和 Protected

php4中,你可以在對象的外面操作它任意的方法和變量--因為方法和變量是公用的。在php5引用了3種模式來控制
對變量、方法的控制權限:Public(公用的)、Protected(受保護)和Private(私有)

Public:方法和變量可以在任意的時候被訪問到
Private:只能在類的內部被訪問,子類也不能訪問
Protected:只能在類的內部、子類中被訪問

例子4:Public, protected and private

<?php
class foo {
  private $x;

  public function public_foo() {
    print("I'm public");
  }

  protected function protected_foo() {
    $this->private_foo(); //Ok because we are in the same class we can call private methods
    print("I'm protected");
  }

  private function private_foo() {
    $this->x = 3;
    print("I'm private");
  }
}

class foo2 extends foo {
  public function display() {
    $this->protected_foo();
    $this->public_foo();
    // $this->private_foo();  // Invalid! the function is private in the base class
  }
}

$x = new foo();
$x->public_foo();
//$x->protected_foo();  //Invalid cannot call protected methods outside the class and derived classes
//$x->private_foo();    //Invalid private methods can only be used inside the class

$x2 = new foo2();
$x2->display();
?>


提示:變量總是私有形式,直接訪問一個私有變量并不是一個好的OOP思想,應該用其他的方法來實現 set/get 的功能


接口

正如你知道的一樣,在 php4 中實現繼承的語法是"class foo extends parent"。無論在php4 還是在 php5 中,都不支持多重繼承即只能從一個類往下繼承。 php5中的"接口"是這樣的一種特殊的類:它并不具體實現某個方法,只是用來定義方法的名稱和擁有的元素,然后通過關鍵字將它們一起引用并實現具體的動作。

Example 5: 接口
<?php
interface displayable {
  function display();
}

interface printable {
  function doprint();
}

class foo implements displayable,printable {
  function display() {
    // code
  }

  function doprint() {
    // code
  }
}
?>

這對代碼的閱讀性和理解性是非常有幫助的:讀到該類時,你就知道foo包含了接口displayable和printable,而且一定有print()(二泉 注:應該是doprint())方法和display()方法。不必知道它們內部是如何實現就可輕松操作它們只要你看到foo的聲明。

虛擬類

虛擬類是一種不能被實例化的類,它可以像超類一樣,可以定義方法和變量。
在虛擬類中還可以定義虛擬的方法,而且在該方法也不能在該類是被實現,但必須在其子類中被實現

Example 6: 虛擬類

<?php
abstract class foo {
  protected $x;

  abstract function display();

  function setX($x) {
    $this->x = $x;
  }
}


class foo2 extends foo {
  function display() {
    // Code
  }
}
?>


__call()方法

php5時,如果你定義了 __call()方法,當你試圖訪問類中一個不存在的變量或方法時,__call()就會被自動調用:
Example 7: __call


<?php
class foo {

  function __call($name,$arguments) {
    print("Did you call me? I'm $name!");
  }
}

$x = new foo();
$x->doStuff();
$x->fancy_stuff();
?>


這個特殊的方法被習慣用來實現"方法重載",因為你依靠一個私有參數來實現并檢查這個參數:
Exampe 8:  __call 實現方法重載

<?php
class Magic {

  function __call($name,$arguments) {
    if($name=='foo') {
      if(is_int($arguments[0])) $this->foo_for_int($arguments[0]);
      if(is_string($arguments[0])) $this->foo_for_string($arguments[0]);
    }
  }

  private function foo_for_int($x) {
    print("oh an int!");
  }

  private function foo_for_string($x) {
    print("oh a string!");
  }
}

$x = new Magic();
$x->foo(3);
$x->foo("3");
?>


__set()方法 和 __get()方法

當訪問或設置一個未定義的變量時,這兩個方法將被調用:

Example 9: __set and __get

<?php
class foo {

  function __set($name,$val) {
    print("Hello, you tried to put $val in $name");
  }

  function __get($name) {
    print("Hey you asked for $name");
  }
}

$x = new foo();
$x->bar = 3;
print($x->winky_winky);
?>

php技術第1次親密接觸PHP5(1),轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 久久精品观看 | 精品伊人 | 婷婷国产 | 国产高清一区二区三区四区 | 久久夜色精品国产噜噜亚洲a | 日本高清色惰www在线视频 | 久久综合狠狠综合久久 | 亚洲欧美黄 | 91精品一区二区三区在线 | 加勒比综合在线 | 一级毛片免费不卡 | 激情网址在线观看 | 涩视频成人永久免费观看网站 | 国产亚洲综合成人91精品 | 精品久久中文字幕有码 | 小说区图片区综合视频区 | 黄视频在线播放 | 91精品观看91久久久久久 | 中文字幕亚洲国产 | 国产大臿蕉香蕉大视频女 | 狠狠干视频网 | 一区二区视频在线观看高清视频在线 | 国产精品视频区 | 国产国产人精品视频69 | 怡红院最新网址 | 久久经典视频 | 久久亚洲一级毛片 | 国产在视频线精品视频www666 | 免费观看色视频 | 欧美日韩一区二区三在线 | 特黄aaaaa日本大片免费看 | 2020国产精品视频免费 | 亚洲tv精品一区二区三区 | 国产一区二区在线播放 | 激情文学激情图片 | 五月婷婷伊人 | 91麻豆国产精品91久久久 | 99在线在线视频免费视频观看 | 亚洲黄色小说图片 | 国产福利微拍精品一区二区 | 免费福利视频网址 |