PHP各版本中函數的型別聲明的詳解

jacklove
發布: 2023-04-02 08:14:01
原創
1596 人瀏覽過

本文為大家總結介紹了下PHP各版本中函數的類型聲明的使用方法,非常簡單實用,有需要的小伙伴可以參考下

PHP7開始支援標量類型聲明,強型別語言的味道比較濃。使用這個特性的過程中踩過兩次坑:一次是聲明boolean,最近是聲明double。為避免以後繼續犯類似錯誤,就把官方文件翻了一次。本文是看完後對PHP函數的型別宣告使用做的一次總結。

從語法上,PHP的函數定義經過了幾個時期:

遠古時代(PHP 4)

定義一個函數非常的簡單,使用function name(args) {body} 的語法宣告。不能指定參數和回傳值類型,參數和回傳值類型有無限種可能。這是到目前為止最常見的函數宣告方式。

陣列與引用類型參數值宣告(PHP 5)

#陣列(array)、類別(class)、介面(interface)、函數(callable)可用在函數聲明中。從5.6開始,支援常數(包括類別常數)為預設參數,以及參數數組(以省略號…為前綴)。例如:

function sum(...$numbers) {
  $sum = 0;
  foreach ($numbers as $number) {
    $sum += $number;
  }
  return $sum;
}
登入後複製

注意:如果參數的值可能為null,null必須為參數的預設值,否則呼叫時會出錯。例如:

function foo(array $arr = null) {
  ...
}
登入後複製

標量類型和傳回值宣告(PHP 7)

函數正式支援標量類型(int , bool, float等)和傳回值型別(可宣告型別同參數)宣告。從這個版本開始,寫PHP有像寫java的感覺。

遺憾是如果函數傳回值有可能是null,就不能指定回傳值類型。例如:

function getModel() : Foo {
  if ($this->_model === null) {
     $this->_model = xxxx; // get from db or otherelse
  }
  return $this->_model;   // 如果$this->_model仍是null,运行出错
}
登入後複製

參數與傳回值可為null以及void傳回型別宣告(PHP 7.1)

當參數與傳回值型別有可能是null時,在類型前以問號(?)修飾,可以解決null值問題(與預設參數不衝突);在型別宣告新增iterable,同時也支援void型別回傳值。例如:

function getModel(?int $id) : ?Foo {
  if ($id !== null) {
    $this->_model = xxxx;
  } else {
    $this->_model = yyyy;
  }
  return $this->_model;
}
 
// 调用
$foo->getModel(null);
$foo->getModel(100);
 
// 函数声明了参数并且没有提供默认参数,调用时不传入参数会引发错误
// 将函数声明改成 getModel(?int $id = 100) {},可以不传参数
$foo->getModel();
登入後複製

當函數傳回值為void時,函數體的return後不能接任何類型,或不出現return語句。

function test(array $arr) : void {
  if (!count($arr) {
    return;
  }
 
  array_walk($arr, function ($elem) {xxxx});
}
登入後複製

回顧完以上歷史,可以看出PHP 7.1,函數型別宣告已經十分完善(雖然實務上用的不多)。

再說說實踐中踩到的坑。參數和回傳值型別宣告可用的型別有:

  1. 類別/介面

  2. self,只能用在自身的方法上

  3. array

  4. bool

  5. #callable

  6. ##int

  7. float

  8. string

  9. iterable


注意清單中並沒有boolean和double類型!除非你定義了這兩個類型,否則用在參數和回傳值就是錯誤的!

這也是PHP有點痛的地方。平常使用時的double和float兩個關鍵字幾乎等同,例如doubleval是floatval的別名,is_double是is_float的別名,轉換時用(double)和(float)效果相同。但是到了型別聲明這裡就不行,同樣的情況出現在bool和boolean身上。

總結

目前PHP 7.2穩定版已經發布,建議在新專案中盡量使用PHP 7.1及後續版本。為了寫出清晰和可維護的程式碼,建議聲明類型。建議引用型別或string才使用null值,int/float等標量型別的參數盡量不要用null。 func_get_argc等函數,如非必要,盡量不使用。

您可能感興趣的文章:

PHP實作統計一個數字在排序數組中出現次數的方法講解

PHP呼叫ffmpeg對影片截圖並拼接腳本

#Yii2中的場景(scenario)和驗證規則(rule)的詳解

#

以上是PHP各版本中函數的型別聲明的詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!