溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

PHP中可能會被忽略的問題有哪些

發(fā)布時間:2021-10-12 14:43:25 來源:億速云 閱讀:151 作者:小新 欄目:開發(fā)技術(shù)

這篇文章主要介紹PHP中可能會被忽略的問題有哪些,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!

1.echo和print的區(qū)別
PHP中echo和print的功能基本相同(輸出),但是兩者之間還是有細(xì)微差別的。echo輸出后沒有返回值,但print有返回值,當(dāng)其執(zhí)行失敗時返回flase。因此可以作為一個普通函數(shù)來使用,例如執(zhí)行下面的代碼后變量$r的值將為1。
$r = print "Hello World";
這意味著print可用在一些復(fù)雜的表達(dá)式中,而echo則不行。但是,因為echo語句不要求返回任何數(shù)值,所已在代碼中echo語句的運(yùn)行效率要略微快于print語句。

2.include與require的區(qū)別
include()與require()的功能也基本相同(包含),但在用法上也有一些不同,include()是有條件包含函數(shù),而require()則是無條件包含函數(shù)。例如在下面代碼中,如果變量$a為真,則將包含文件a.php:
if($a){
include("a.php");
}
而require()則和include()不同,不管$a取何值,下面的代碼將把文件a.php包含進(jìn)文件里:
if($a){
require("a.php");
}
在錯誤處理方面,使用include語句,如果發(fā)生包含錯誤,程序?qū)⑻^include語句,雖然會顯示錯誤信息但是程序還是會繼續(xù)執(zhí)行!但requre卻會給你來個致命錯誤。
當(dāng)然,從字面意思上我們也可以理解七分:requre是很強(qiáng)硬的請求、要求的意思。

3.require_once()和include_once()語句
題外話了,因為長的像,簡單require_once()和include_once()語句分別對應(yīng)于require()和include()語句。require_once() 和include_once()語句主要用于需要包含多個文件時,可以有效地避免把同一段代碼包含進(jìn)去而出現(xiàn)函數(shù)或變量重復(fù)定義的錯誤。

4.空字符串('')和NULL的區(qū)別
PHP中空字符串和NULL都是以值為0存儲的,但是他們的類型并不一樣,你可以試一下echo gettype('');和echo gettype(NULL);你會發(fā)現(xiàn)他們打印出來的分別是string和NULL,當(dāng)然還有0也容易混淆,你可以試試echo gettype(0);打印一下類型,會發(fā)現(xiàn)0的類型是integer(整型),可見字符串('')、NULL和0是“等值”但不等類型。

5.isset和 empty的區(qū)別
從字面意思上我們就可以明白:empty是判斷一個變量是否為“空”,而isset 則是判斷一個變量是否已經(jīng)設(shè)置。但是這里有一點(diǎn)絕對要注意起來:當(dāng)一個變量值為0,empty 認(rèn)為這個變量同等于空,即相當(dāng)于沒有設(shè)置。比如當(dāng)我們檢測$id 變量的時候,當(dāng)$id=0 ,用empty和isset來檢測變量$id是否已經(jīng)配置,兩都將返回不同的值:empty 認(rèn)為沒有配置,isset 則能夠取得 $id 的值,看下邊例子:
$id=0;
empty($id)?print "我是空的":print "我是$id ."; //結(jié)果:我是空的
!isset($id)?print "我是空的":print "我是$id .";//結(jié)果:我是0
 
6.==(等)和===(恒等)的區(qū)別
回顧上面第四條空字符串("")和NULL的區(qū)別,再來看一個例子:
'' == NULL;
'' === NULL;
運(yùn)行之后你會發(fā)現(xiàn)第一個為true,而第二個則為false!可見==只是比較值是否相等,而===則不但比較值,還會比較類型,更為嚴(yán)格。

7.self :: 和 this-> 的區(qū)別
在訪問PHP類中的成員變量或方法時,如果被引用的變量或者方法被聲明成const(定義常量)或者static(聲明靜態(tài)),那么就必須使用操作符::,反之如果被引用的變量或者方法沒有被聲明成const或者static,那么就必須使用操作符->。

另外,如果從類的內(nèi)部訪問const或者static變量或者方法,那么就必須使用自引用的self,反之如果從類的內(nèi)部訪問不為const或者static變量或者方法,那么就必須使用自引用的$this。

8.strstr() 與 strpos() 的區(qū)別
stristr() 不區(qū)分大小寫 strstr() 區(qū)分大小寫
函數(shù)查找字符串在另一個字符串中第一次出現(xiàn)的位置。
如果成功,則返回字符串的其余部分(從匹配點(diǎn))。如果沒有找到該字符串,則返回 false。
stripos() 不區(qū)分大小寫 strpos() 區(qū)分大小寫
函數(shù)返回字符串在另一個字符串中第一次出現(xiàn)的位置。
如果沒有找到該字符串,則返回 false。
經(jīng)測試證明如果只是單純查找判斷是否存在則strpos()的執(zhí)行效率要大于strstr()

9.PHP中 HTTP_HOST 和 SERVER_NAME
相同點(diǎn):
當(dāng)滿足以下三個條件時,兩者會輸出相同信息。
1. 服務(wù)器為80端口
2. apache的conf中ServerName設(shè)置正確
3. HTTP/1.1協(xié)議規(guī)范

不同點(diǎn):
1. 通常情況:
_SERVER["HTTP_HOST"] 在HTTP/1.1協(xié)議規(guī)范下,會根據(jù)客戶端的HTTP請求輸出信息。
_SERVER["SERVER_NAME"] 默認(rèn)情況下直接輸出apache的配置文件httpd.conf中的ServerName值。

2. 當(dāng)服務(wù)器為非80端口時:
_SERVER["HTTP_HOST"] 會輸出端口號,例如:mimiz.cn:8080
_SERVER["SERVER_NAME"] 會直接輸出ServerName值
因此在這種情況下,可以理解為:HTTP_HOST = SERVER_NAME : SERVER_PORT

3. 當(dāng)配置文件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
所以,在實(shí)際程序中,應(yīng)盡量使用_SERVER["HTTP_HOST"] ,比較保險和可靠。
如果在端口映射的情況下,并且在內(nèi)網(wǎng)訪問,用“$_SERVER['HTTP_X_FORWARDED_HOST']”比較好。

以上是“PHP中可能會被忽略的問題有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI