PHP易混淆知識整理筆記
PHP易混淆知識整理筆記
php經(jīng)常會混淆的知識點有很多,例如include與require的區(qū)別;require_once()和include_once()語句等一些列的知識點,感覺這方面欠缺的朋友可以參考一下!
(相關資料圖)
1.echo和print的區(qū)別
PHP中echo和print的功能基本相同(輸出),但是兩者之間還是有細微差別的。echo輸出后沒有返回值,但print有返回值,當其執(zhí)行失敗時返回flase。因此可以作為一個普通函數(shù)來使用,例如執(zhí)行下面的代碼后變量$r的值將為1。
1 | $r = print "Hello World" ; |
這意味著print可用在一些復雜的表達式中,而echo則不行。但是,因為echo語句不要求返回任何數(shù)值,所已在代碼中echo語句的運行效率要略微快于print語句。
2.include與require的區(qū)別
include()與require()的功能也基本相同(包含),但在用法上也有一些不同,include()是有條件包含函數(shù),而require()則是無條件包含函數(shù)。例如在下面代碼中,如果變量$a為真,則將包含文件a.php:
123 | if ( $a ){?? include ( "a.php" );?? } |
而require()則和include()不同,不管$a取何值,下面的代碼將把文件a.php包含進文件里:
123 | if ( $a ){?? require ( "a.php" );?? } |
在錯誤處理方面,使用include語句,如果發(fā)生包含錯誤,程序將跳過include語句,雖然會顯示錯誤信息但是程序還是會繼續(xù)執(zhí)行!但requre卻會給你來個致命錯誤。
當然,從字面意思上我們也可以理解七分:requre是很強硬的請求、要求的意思。
3.require_once()和include_once()語句
題外話了,因為長的像,簡單require_once()和include_once()語句分別對應于require()和include()語句。require_once() 和include_once()語句主要用于需要包含多個文件時,可以有效地避免把同一段代碼包含進去而出現(xiàn)函數(shù)或變量重復定義的錯誤。
4.空字符串("")和NULL的區(qū)別
PHP中空字符串和NULL都是以值為0存儲的,但是他們的類型并不一樣,你可以試一下echo gettype("");和echo gettype(NULL);你會發(fā)現(xiàn)他們打印出來的分別是string和NULL,當然還有0也容易混淆,你可以試試echo gettype(0);打印一下類型,會發(fā)現(xiàn)0的類型是integer(整型),可見字符串("")、NULL和0是“等值”但不等類型。
5.isset和 empty的區(qū)別
從字面意思上我們就可以明白:empty是判斷一個變量是否為“空”,而isset 則是判斷一個變量是否已經(jīng)設置。但是這里有一點絕對要注意起來:當一個變量值為0,empty 認為這個變量同等于空,即相當于沒有設置。比如當我們檢測$id 變量的時候,當$id=0 ,用empty和isset來檢測變量$id是否已經(jīng)配置,兩都將返回不同的值:empty 認為沒有配置,isset 則能夠取得 $id 的值,看下邊例子:
123 | $id =0;?? empty ( $id )? print "我是空的" : print "我是$id ." ; //結果:我是空的?? !isset( $id )? print "我是空的" : print "我是$id ." ; //結果:我是0?? |
6.==(等)和===(恒等)的區(qū)別
回顧上面第四條空字符串("")和NULL的"區(qū)別,再來看一個例子:
12 | "" == NULL;?? "" === NULL; |
運行之后你會發(fā)現(xiàn)第一個為true,而第二個則為false!可見==只是比較值是否相等,而===則不但比較值,還會比較類型,更為嚴格。
7.self :: 和 this-> 的區(qū)別
在訪問PHP類中的成員變量或方法時,如果被引用的變量或者方法被聲明成const(定義常量)或者static(聲明靜態(tài)),那么就必須使用操作符::,反之如果被引用的變量或者方法沒有被聲明成const或者static,那么就必須使用操作符->。
另外,如果從類的內部訪問const或者static變量或者方法,那么就必須使用自引用的self,反之如果從類的內部訪問不為const或者static變量或者方法,那么就必須使用自引用的$this。
8.strstr() 與 strpos() 的區(qū)別
stristr() 不區(qū)分大小寫 strstr() 區(qū)分大小寫
函數(shù)查找字符串在另一個字符串中第一次出現(xiàn)的位置。
如果成功,則返回字符串的其余部分(從匹配點)。如果沒有找到該字符串,則返回 false。
stripos() 不區(qū)分大小寫 strpos() 區(qū)分大小寫
函數(shù)返回字符串在另一個字符串中第一次出現(xiàn)的位置。
如果沒有找到該字符串,則返回 false。
經(jīng)測試證明如果只是單純查找判斷是否存在則strpos()的執(zhí)行效率要大于strstr()
9.PHP中 HTTP_HOST 和 SERVER_NAME
相同點:
當滿足以下三個條件時,兩者會輸出相同信息。
1. 服務器為80端口
2. apache的conf中ServerName設置正確
3. HTTP/1.1協(xié)議規(guī)范
不同點:
1. 通常情況:
_SERVER["HTTP_HOST"] 在HTTP/1.1協(xié)議規(guī)范下,會根據(jù)客戶端的HTTP請求輸出信息。
_SERVER["SERVER_NAME"] 默認情況下直接輸出apache的配置文件httpd.conf中的ServerName值。
2. 當服務器為非80端口時:
_SERVER["HTTP_HOST"] 會輸出端口號,例如:mimiz.cn:8080
_SERVER["SERVER_NAME"] 會直接輸出ServerName值
因此在這種情況下,可以理解為:HTTP_HOST = SERVER_NAME : SERVER_PORT
3. 當配置文件httpd.conf中的ServerName與HTTP/1.0請求的域名不一致時:
httpd.conf配置如下:
ServerName mimiz.cn
ServerAlias www.mimiz.cn
客戶端訪問域名www.mimiz.cn
_SERVER["HTTP_HOST"] 輸出 www.mimiz.cn
_SERVER["SERVER_NAME"] 輸出 mimiz.cn
所以,在實際程序中,應盡量使用_SERVER["HTTP_HOST"] ,比較保險和可靠。
如果在端口映射的情況下,并且在內網(wǎng)訪問,用“$_SERVER["HTTP_X_FORWARDED_HOST"]”比較好。
經(jīng)過小編對以上知識點的整理,大家的思路是不是更清晰了,對這些概念是不是有了區(qū)分,那就好好收藏這份筆記吧!
詞條內容僅供參考,如果您需要解決具體問題
(尤其在法律、醫(yī)學等領域),建議您咨詢相關領域專業(yè)人士。