這篇文章主要介紹PHP中可能會被忽略的問題有哪些,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供江北網(wǎng)站建設(shè)、江北做網(wǎng)站、江北網(wǎng)站設(shè)計、江北網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、江北企業(yè)網(wǎng)站模板建站服務(wù),十載江北做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。1.echo和print的區(qū)別
PHP中echo和print的功能基本相同(輸出),但是兩者之間還是有細微差別的。echo輸出后沒有返回值,但print有返回值,當其執(zhí)行失敗時返回flase。因此可以作為一個普通函數(shù)來使用,例如執(zhí)行下面的代碼后變量$r的值將為1。
$r = print "Hello World";
這意味著print可用在一些復(fù)雜的表達式中,而echo則不行。但是,因為echo語句不要求返回任何數(shù)值,所已在代碼中echo語句的運行效率要略微快于print語句。
2.include與require的區(qū)別
include()與require()的功能也基本相同(包含),但在用法上也有一些不同,include()是有條件包含函數(shù),而require()則是無條件包含函數(shù)。例如在下面代碼中,如果變量$a為真,則將包含文件a.php:
if($a){
include("a.php");
}
而require()則和include()不同,不管$a取何值,下面的代碼將把文件a.php包含進文件里:
if($a){
require("a.php");
}
在錯誤處理方面,使用include語句,如果發(fā)生包含錯誤,程序?qū)⑻^include語句,雖然會顯示錯誤信息但是程序還是會繼續(xù)執(zhí)行!但requre卻會給你來個致命錯誤。
當然,從字面意思上我們也可以理解七分:requre是很強硬的請求、要求的意思。
3.require_once()和include_once()語句
題外話了,因為長的像,簡單require_once()和include_once()語句分別對應(yīng)于require()和include()語句。require_once() 和include_once()語句主要用于需要包含多個文件時,可以有效地避免把同一段代碼包含進去而出現(xiàn)函數(shù)或變量重復(fù)定義的錯誤。
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)設(shè)置。但是這里有一點絕對要注意起來:當一個變量值為0,empty 認為這個變量同等于空,即相當于沒有設(shè)置。比如當我們檢測$id 變量的時候,當$id=0 ,用empty和isset來檢測變量$id是否已經(jīng)配置,兩都將返回不同的值:empty 認為沒有配置,isset 則能夠取得 $id 的值,看下邊例子:
$id=0;
empty($id)?print "我是空的":print "我是$id ."; //結(jié)果:我是空的
!isset($id)?print "我是空的":print "我是$id .";//結(jié)果:我是0
6.==(等)和===(恒等)的區(qū)別
回顧上面第四條空字符串("")和NULL的區(qū)別,再來看一個例子:
'' == NULL;
'' === NULL;
運行之后你會發(fā)現(xiàn)第一個為true,而第二個則為false!可見==只是比較值是否相等,而===則不但比較值,還會比較類型,更為嚴格。
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)的位置。
如果成功,則返回字符串的其余部分(從匹配點)。如果沒有找到該字符串,則返回 false。
stripos() 不區(qū)分大小寫 strpos() 區(qū)分大小寫
函數(shù)返回字符串在另一個字符串中第一次出現(xiàn)的位置。
如果沒有找到該字符串,則返回 false。
經(jīng)測試證明如果只是單純查找判斷是否存在則strpos()的執(zhí)行效率要大于strstr()
9.PHP中 HTTP_HOST 和 SERVER_NAME
相同點:
當滿足以下三個條件時,兩者會輸出相同信息。
1. 服務(wù)器為80端口
2. apache的conf中ServerName設(shè)置正確
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. 當服務(wù)器為非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
所以,在實際程序中,應(yīng)盡量使用_SERVER["HTTP_HOST"] ,比較保險和可靠。
如果在端口映射的情況下,并且在內(nèi)網(wǎng)訪問,用“$_SERVER['HTTP_X_FORWARDED_HOST']”比較好。
以上是“PHP中可能會被忽略的問題有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!