詳細介紹在PHP中單引號和雙引號的區別

來源:互聯網
上載者:User

1、定義字串   
在PHP中,字串的定義可以使用單引號,也可以使用雙引號。但是必須使用同一種單或雙引號來定義字串,如:‘Hello"和“Hello'為非法的字串定義。   
定義字串時,只有一種引號被視為定義符,即單引號或雙引號。於是,如果一個字串由雙引號開始,那麼只有雙引號被分析器解析。這樣,你就可以在雙引號串中包含任何其他字元,甚至單引號。下面的引號串都是合法的:

Php代碼

$s = "I am a 'single quote string' inside a double quote string";

$s = 'I am a "double quote string" inside a single quote string';

$s = "I am a 'single quote string' inside a double quote string";

$s = 'I am a "double quote string" inside a single quote string';   

而串 "Why doesn't "this" work?" 則會被分為三段。如果在這個串中想要表示出雙引號,則可以使用轉義符""(反斜線),變成 "Why doesn't "this" work?" 即可。

2、字串變數中的單、雙引號   

PHP允許我們在雙引號串中直接包含字串變數,我們可以發現下面的兩個字串的處理結果是相同的。

$full_name = $first_name . ' ' . $last_name;

$full_name = "$first_name $last_name";   

單引號串和雙引號串在PHP中的處理是不相同的。雙引號串中的內容可以被解釋而且替換,而單引號串中的內容總被認為是一般字元。例如:

Php代碼

$foo = 2;

echo "foo is $foo"; // 列印結果: foo is 2

echo 'foo is $foo'; // 列印結果: foo is $foo

echo "foo is $foon"; // 列印結果: foo is 2 (同時換行)

echo 'foo is $foon'; // 列印結果: foo is $foon

$foo = 2;

echo "foo is $foo"; // 列印結果: foo is 2

echo 'foo is $foo'; // 列印結果: foo is $foo

echo "foo is $foon"; // 列印結果: foo is 2 (同時換行)

echo 'foo is $foon'; // 列印結果: foo is $foon   

正如你所看到的,在單引號串中甚至反斜線也失去了他的擴充含義(除了插入反斜線\和插入單引號')。所以,當你想在字串中進行變數代換和包 含n(分行符號)等逸出序列時,你應該使用雙引號。單引號串可以用在其他任何地方,指令碼中使用單引號串處理速度會更快些,因為PHP文法分析器對單引號串 的處理方式比較單純,而雙引號的處理由於串內部也需要解析,因此更複雜些,所以處理速度略慢。   

在字串中引用複雜的變數組合時,可能會產生一些問題,下面的代碼會正常工作:

Php代碼

echo "value = $foo";

echo "value = $a[$i]";

echo "value = $foo";

echo "value = $a[$i]";   

而下面的代碼卻不能得到我們希望的結果:

echo "value = $a[$i][$j]"; //我們希望列印二維數組$a的某個元素。   

為避免這些字串使用中的潛在問題,我們通常把複雜的變數從字串中分離開來,就像這樣:echo 'value = ' . $a[$i][$j];//字串的串連用點(.)   

還有一種辦法是將複雜變數用花括弧括起來,文法分析器就能正確辨認了:

echo "value = {$a[$i][$j]}" //列印二維數組$a的某個元素   

這樣,又出現新問題了。當我們想在字串中引用花括弧字元本身時,就要記得使用轉義符了:

Php代碼

$var = 3;

echo "value = {$var}"; // 列印結果 "value = 3"

echo "value = {$var}"; // 列印結果 "value = {3}"

$var = 3;

echo "value = {$var}"; // 列印結果 "value = 3"

echo "value = {$var}"; // 列印結果 "value = {3}"

3、在SQL語句中   

這是會經常遇到的問題,在插入資料庫的SQL語句是採用單引號來定義字串,如果要將一個含有單引號的字串插入資料庫,這個SQL語句就會出錯。

如:$sql="insert into userinfo (username,password) Values('O'Kefee','123456')"   

此時,處理的方法之一是在SQL語句中加入轉義符反斜線,

即:……Values('O'Kefee',……   

當然也可以使用函數 addslashes(),該函數的功能就是加入轉義符,

即:$s = addslashes("O'Kefee") ……Values('".$s."',……   

還有一種方法是設定php.ini中的magic-quotes選項,開啟該選項,則通過表單提交的資訊中如果有單引號是,將會自動加上如轉義符。因此不用使用其他函數了。

補充: 這就要從雙引號和單引號的作用講起: 雙引號裡面的欄位會經過編譯器解釋然後再當作HTML代碼輸出,但是單引號裡面的不需要解釋,直接輸出。

例如:

$abc='I love u';

echo $abc //結果是:I love u

echo '$abc' //結果是:$abc

echo "$abc" //結果是:I love u

所以在對資料庫裡面的SQL語句賦值的時候也要用在雙引號裡面SQL="select a,b,c from ..." 但是SQL語句中會有單引號把欄位名引出來

例如:select * from table where user='abc';

這裡的SQL語句可以直接寫成SQL="select * from table where user='abc'"

但是如果象下面:

$user='abc';

SQL1="select * from table where user=' ".$user." ' ";對比一下

SQL2="select * from table where user=' abc ' "

我把單引號和雙引號之間多加了點空格,希望你能看的清楚一點。

也就是把'abc' 替換為 '".$user."'都是在一個單引號裡面的。只是把整個SQL字串分割了。 SQL1可以分解為以下3個部分

1:"select * from table where user=' "

2:$user

3:" ' "

字串之間用 . 來串連

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.