- 相關(guān)推薦
PHP函數(shù)中isset和array-key-exists的差異
本文將為大家講解PHP函數(shù)中isset和array_key_exists的差異,歡迎學(xué)習(xí)!
在判斷某個 PHP 數(shù)組的索引值是否存在,一般會使用 isset 和 array_key_exists 兩種方法。
isset($a['key'])
array_key_exists('key', $a)
array_key_exists 確切地告訴你,數(shù)組是否存在某個鍵,而 isset 則只是返回鍵值是否為 null 的狀態(tài)。也就是說,假設(shè)給定下面的數(shù)組:
$a = array('key1' => '123', 'key2' => null);
使用這兩個方法判斷鍵值存在情況,結(jié)果如下:
isset($a['key1']); // true
array_key_exists('key1', $a); // true
isset($a['key2']); // false
array_key_exists('key2', $a); // true
從 PHP 引擎本身來說,底層都是 C 語言的實現(xiàn),array_key_exists 和 isset 應(yīng)該都是很快的。如果運算次數(shù)上千次上萬次,這種情況下 isset 的性能應(yīng)該更為顯著。
【相關(guān)閱讀】PHP函數(shù)similar_text()原理分析
PHP有個計算兩個字符串相似度的函數(shù)similar_text(),可以得出一個百分比來表示兩個字符串的相似程度。效果如下:
similar_text('aaaa', 'aaaa', $percent);
var_dump($percent);
//float(100)
similar_text('aaaa', 'aaaabbbb', $percent);
var_dump($percent);
//float(66.666666666667)
similar_text('abcdef', 'aabcdefg', $percent);
var_dump($percent);
//float(85.714285714286)
利用這個函數(shù),可以用來做模糊搜索的功能,或者其他需要模糊匹配的功能。最近我在驗證碼識別研究中的特征匹配一步上涉及到了這個函數(shù)。
但這個函數(shù)具體使用了怎樣的算法呢?我研究了他的底層實現(xiàn),總結(jié)為三步:
(1)找出兩個字符串中相同部分最長的一段;
(2)再用同樣的方法在剩下的兩段中分別找出相同部分最長的一段,以此類推,直到?jīng)]有任何相同部分;
(3)相似度 = 所有相同部分的長度之和 * 2 / 兩個字符串的長度之和;
我研究的源代碼版本是PHP 5.4.6,相關(guān)的代碼位于文件php-5.4.6/ext/standard/string.c的第2951~3031行。以下是我加過注釋后源代碼。
//找出兩個字符串中相同部分最長的一段
【PHP函數(shù)中isset和array-key-exists的差異】相關(guān)文章:
php empty()和isset()的區(qū)別09-28
PHP中isset()與empty()的使用區(qū)別詳解10-14
PHP中iconv函數(shù)知識11-01
php中rename函數(shù)用法08-08
基于PHP中的常用函數(shù)精粹07-19
PHP的語言結(jié)構(gòu)和函數(shù)的區(qū)別09-02
PHP時間和日期函數(shù)詳解10-17
php中iconv函數(shù)使用方法08-23