為什麼 === 的速度比 == 快?

2020-07-16 10:06:29

比較運算子 == (相等運算子)=== (恆等運算子) 用於比較兩個值。他們也被稱為 寬鬆等於 (==)嚴格等於 (===) 運算子。

符號名稱例子輸出結果
==等於$a == $b忽略型別,如果 $a 等於 $b 則為 TRUE
===恆等於$a === $b如果 $a 等於 $b,並且型別相同則為 TRUE

PHP 運算子 PHP中有很多運算子, 但 == 和 === 運算子嚴格或隨意執行類似的任務。

  • 如果兩個值的型別不同,那麼 == 和 === 會得到 不同的結果。運算速度也會有所不同, 因為 == 會先進行型別轉換,然後進行比較。
  • 如果兩個值型別相同,那麼 == 和 === 會得到 相同的結果。 運算速度也幾乎相同,兩個運算子都不會進行型別轉換。

相等運算 == 比較兩個值時會臨時轉換資料型別,而 === (全等運算子)不需要執行任何型別轉換,因此計算量減少,速度也更快。

案例 1:

<?php 

// 0 == 0 ->  型別相同返回 true
// 轉換完成,然後
// 檢查是否相等
var_dump(0 == "a"); 

// 1 == 1 -> true 
var_dump("1" == "01"); 

// 10 == 10 -> true 
var_dump("10" == "1e1"); 

// 100 == 100 -> true 
var_dump(100 == "1e2"); 

// 0 === "a" -> 這種情況為 false
// 轉換不僅完成
// 還檢查是否存在
// 是否相等
var_dump(0 === "a"); 

// "1" === "01" -> false 
var_dump("1" === "01"); 

// "10" === "1e1" -> false 
var_dump("10" === "1e1"); 

// 100 == "1e2" -> false 
var_dump(100 === "1e2"); 

switch ("a") { 
case 0: 
    echo "In first case"; 
    break; 

// 永遠不會匹配 "a" 選項
// 因為 switch 使用的是 == 
case "a": 
    echo "In sceond case"; 
    break; 
} 
?>

輸出:

bool(true)
bool(true)
bool(true)
bool(true)
bool(false)
bool(false)
bool(false)
bool(false)
In first case

案例 2:

<?php 

// TRUE - 以下表示式等同於 (bool)1 == TRUE 
var_dump(1 == TRUE); 

// TRUE - 以下表示式等同於 (bool)0 == FALSE 
var_dump(0 == FALSE); 

// FALSE - 1 不全等於 TRUE
// 1 是整形, TRUE 是布林型 
var_dump(1 === TRUE); 

// FALSE - 0 不全等於 FALSE
// 0 是整形, FALSE 是布林型
var_dump(0 === FALSE); 
?>

輸出:

bool(true)
bool(true)
bool(false)
bool(false)

注意: === 運算子‘型別比較相對安全’, 僅當兩個值具有相同的型別和值時才會返回 TRUE, 使用 == 時,值相等就會返回 TRUE。

以上就是為什麼 === 的速度比 == 快?的詳細內容,更多請關注TW511.COM其它相關文章!