<menu id="ycqsw"></menu><nav id="ycqsw"><code id="ycqsw"></code></nav>
<dd id="ycqsw"><menu id="ycqsw"></menu></dd>
  • <nav id="ycqsw"></nav>
    <menu id="ycqsw"><strong id="ycqsw"></strong></menu>
    <xmp id="ycqsw"><nav id="ycqsw"></nav>
  • php判斷變量是否為空的函數(mysql數據庫知識點總結)


    PHP中echo和print的功能基本相同(輸出),但是兩者之間還是有細微差別的。echo輸出后沒有返回值,但print有返回值,當其執行失敗時返回flase。因此可以作為一個普通函數來使用,例如執行下面的代碼后變量$r的值將為1。

    1$r = print "Hello World";

    這意味著print可用在一些復雜的表達式中,而echo則不行。但是,因為echo語句不要求返回任何數值,所已在代碼中echo語句的運行效率要略微快于print語句。

    2.include與require的區別

    include()與require()的功能也基本相同(包含),但在用法上也有一些不同,include()是有條件包含函數,而require()則是無條件包含函數。例如在下面代碼中,如果變量$a為真,則將包含文件a.php

    123if($a){ include("a.php"); }

    而require()則和include()不同,不管$a取何值,下面的代碼將把文件a.php包含進文件里:

    123if($a){ require("a.php"); }

    在錯誤處理方面,使用include語句,如果發生包含錯誤,程序將跳過include語句,雖然會顯示錯誤信息但是程序還是會繼續執行!但requre卻會給你來個致命錯誤。

    當然,從字面意思上我們也可以理解七分:requre是很強硬的請求、要求的意思。

    3.require_once()和include_once()語句

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

    4.空字符串(”)和NULL的區別

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

    5.isset和 empty的區別

    從字面意思上我們就可以明白:empty是判斷一個變量是否為“空”,而isset 則是判斷一個變量是否已經設置。但是這里有一點絕對要注意起來:當一個變量值為0,empty 認為這個變量同等于空,即相當于沒有設置。比如當我們檢測$id 變量的時候,當$id=0 ,用empty和isset來檢測變量$id是否已經配置,兩都將返回不同的值:empty 認為沒有配置,isset 則能夠取得 $id 的值,看下邊例子:

    123$id=0; empty($id)?print "我是空的":print "我是$id ."; //結果:我是空的!isset($id)?print "我是空的":print "我是$id .";//結果:我是0

    6.==(等)和===(恒等)的區別

    回顧上面第四條空字符串(“”)和NULL的區別,再來看一個例子:

    12'' == NULL; '' === NULL;

    運行之后你會發現第一個為true,而第二個則為false!可見==只是比較值是否相等,而===則不但比較值,還會比較類型,更為嚴格。

    7.self :: 和 this-> 的區別

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

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

    8.strstr() 與 strpos() 的區別

    stristr() 不區分大小寫 strstr() 區分大小寫

    函數查找字符串在另一個字符串中第一次出現的位置。

    如果成功,則返回字符串的其余部分(從匹配點)。如果沒有找到該字符串,則返回 false。

    stripos() 不區分大小寫 strpos() 區分大小寫

    函數返回字符串在另一個字符串中第一次出現的位置。

    如果沒有找到該字符串,則返回 false。

    經測試證明如果只是單純查找判斷是否存在則strpos()的執行效率要大于strstr()

    9.PHP中 HTTP_HOST 和 SERVER_NAME

    相同點:

    當滿足以下三個條件時,兩者會輸出相同信息。

    1. 服務器為80端口

    2. apache的conf中ServerName設置正確

    3. HTTP/1.1協議規范

    不同點:

    1. 通常情況:

    _SERVER[“HTTP_HOST”] 在HTTP/1.1協議規范下,會根據客戶端的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”] ,比較保險和可靠。

    如果在端口映射的情況下,并且在內網訪問,用“$_SERVER[‘HTTP_X_FORWARDED_HOST’]”比較好。

    版權聲明:本文內容由互聯網用戶自發貢獻,該文觀點僅代表作者本人。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。如發現本站有涉嫌抄襲侵權/違法違規的內容, 請發送郵件至 舉報,一經查實,本站將立刻刪除。

    發表評論

    登錄后才能評論
    国产精品区一区二区免费