摘要:為什么變量的值為字符串,但同時會是空值呢讓我們在變量上嘗試使用其它一些函數(shù)來進(jìn)行判斷吧以上結(jié)果為譯者注這邊的結(jié)果可能存在問題的結(jié)果同樣為,可以到這里去運(yùn)行下查看結(jié)果。和函數(shù)執(zhí)行結(jié)果符合預(yù)期判斷,唯獨(dú)函數(shù)返回了錯誤結(jié)果。
本文首發(fā)于 震驚 php empty 函數(shù)判斷結(jié)果為空,但實(shí)際值卻為非空,轉(zhuǎn)載請注明出處。
最近我在一個項目中使用 empty 時獲取到了一些意料之外的結(jié)果。下面是我處理后的調(diào)試記錄,在這里與你分享了。
var_dump( $person->firstName, empty($person->firstName) );
它的結(jié)果是:
string(5) "Freek" bool(true)
結(jié)果出人意料。為什么變量的值為字符串,但同時會是空值呢?讓我們在 $person->firstName 變量上嘗試使用其它一些函數(shù)來進(jìn)行判斷吧:
var_dump( $person->firstName, empty($person->firstName), isset($person->firstName), is_null($person->firstName) );
以上結(jié)果為:
string(5) "Freek" bool(true) // empty bool(true) // isset bool(false) // is_null
譯者注:這邊的結(jié)果可能存在問題 isset 的結(jié)果同樣為 false,可以到 這里 去運(yùn)行下查看結(jié)果。
isset 和 is_null 函數(shù)執(zhí)行結(jié)果符合預(yù)期判斷,唯獨(dú) empty 函數(shù)返回了錯誤結(jié)果。
這里讓我們來看看 person 類的實(shí)現(xiàn)代碼吧:
class person { protected $attributes = []; public function __construct(array $attributes) { $this->attributes = $attributes; } public function __get($name) { return $this->attributes[$name] ?? null; } }
從上述代碼我們可以看到 Person 對象的成員變量是通過 __get 魔術(shù)方法從 $attributes 數(shù)組中檢索出來的。
當(dāng)將變量傳入一個普通函數(shù)時,$person->firstName 會先進(jìn)行取值處理,然后再將獲取到的結(jié)果作為參數(shù)傳入函數(shù)內(nèi)。
但是 empty 不是一個函數(shù),而是一種數(shù)據(jù)結(jié)構(gòu)。所以當(dāng)將 $person->firstName** 傳入 **empty** 時,并不會先進(jìn)行取值處理。而是會先判斷 **$person 對象成員變量 firstName 的內(nèi)容,由于這個變量并未真實(shí)存在,所以返回 false。
在正中應(yīng)用場景下,如果你希望 empty 函數(shù)能夠正常處理變量,我們需要在類中實(shí)現(xiàn) __isset 魔術(shù)方法。
class Person { protected $attributes = []; public function __construct(array $attributes) { $this->attributes = $attributes; } public function __get($name) { return $this->attributes[$name] ?? null; } public function __isset($name) { $attribute = $this->$name; return !empty($attribute); } }
這是當(dāng) empty 進(jìn)行控制判斷時,會使用這個魔術(shù)方法來判斷最終的結(jié)果。
再讓我們看看輸出結(jié)果:
var_dump( $person->firstName, empty($person->firstName) );
新的檢測結(jié)果:
string(5) "Freek" bool(false)
完美!
原文:When empty is not empty
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/28707.html
摘要:可空性在中,類型系統(tǒng)區(qū)分一個引用是可以容納可空引用還是不能容納非空引用。使用可以很方便得將可空轉(zhuǎn)為非空,但可空變量值為,則會。 目錄介紹 01.可空性 02.安全調(diào)用運(yùn)算符:?. 03.Elvis運(yùn)算符:?: 04.安全轉(zhuǎn)換運(yùn)算符:as? 05.非空斷言:!! 06.let函數(shù)說明 07.可空類型的擴(kuò)展 08.Java中判斷方式 09.kotlin是否解決NPE 10.kotlin如...
摘要:是第一批在堆上分配記錄的類型語言之一。實(shí)際上,的這段話低估了過去五十年來數(shù)百萬程序員為修復(fù)空引用所耗費(fèi)的代價。很明顯,這種方式不具備擴(kuò)展性,同時還犧牲了代碼的可讀性。是目前程序開發(fā)中最典型的異常。完成這一任務(wù)有多種方法。 用Optional取代null 如果你作為Java程序員曾經(jīng)遭遇過NullPointerException,請舉起手。如果這是你最常遭遇的異常,請繼續(xù)舉手。非??上?,...
摘要:樹中結(jié)點(diǎn)的最大層次稱為樹的深度或高度。二叉樹有深度遍歷和廣度遍歷,深度遍歷有前序中序和后序三種遍歷方法。二叉樹的前序遍歷可以用來顯示目錄結(jié)構(gòu)等中序遍歷可以實(shí)現(xiàn)表達(dá)式樹,在編譯器底層很有用后序遍歷可以用來實(shí)現(xiàn)計算目錄內(nèi)的文件及其信息等。 樹的簡介 棧、隊列、鏈表等數(shù)據(jù)結(jié)構(gòu),都是順序數(shù)據(jù)結(jié)構(gòu)。而樹是非順序數(shù)據(jù)結(jié)構(gòu)。樹型結(jié)構(gòu)是一類非常重要的非線性結(jié)構(gòu)。直觀地,樹型結(jié)構(gòu)是以分支關(guān)系定義的層次結(jié)...
閱讀 701·2023-04-25 19:53
閱讀 4295·2021-09-22 15:13
閱讀 2578·2019-08-30 10:56
閱讀 1335·2019-08-29 16:27
閱讀 2946·2019-08-29 14:00
閱讀 2424·2019-08-26 13:56
閱讀 447·2019-08-26 13:29
閱讀 1624·2019-08-26 11:31