1、定義字符串
在PHP中,字符串的定義可以使用單引號(hào),也可以使用上引號(hào)。但是必須使用同一種單或雙引號(hào)來(lái)定義字符串,如:‘Hello"和“Hello'為非法的字符串定義。
定義字符串時(shí),只有一種引號(hào)被視為定義符,即單引號(hào)或雙引號(hào)。于是,如果一個(gè)字符串由雙引號(hào)開(kāi)始,那么只有雙引號(hào)被分析器解析。這樣,你就可以在雙引號(hào)串中包含任何其他字符,甚至單引號(hào)。下面的引號(hào)串都是合法的:
$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?" 則會(huì)被分為三段。如果在這個(gè)串中想要表示出雙引號(hào),則可以使用轉(zhuǎn)義符"\"(反斜線),變成 "Why doesn't \"this\" work?" 即可。
2、字符串變量中的單、雙引號(hào)
PHP允許我們?cè)陔p引號(hào)串中直接包含字串變量,我們可以發(fā)現(xiàn)下面的兩個(gè)字串的處理結(jié)果是相同的。
$full_name = $first_name . ' ' . $last_name;
$full_name = "$first_name $last_name";
單引號(hào)串和雙引號(hào)串在PHP中的處理是不相同的。雙引號(hào)串中的內(nèi)容可以被解釋而且替換,而單引號(hào)串中的內(nèi)容總被認(rèn)為是普通字符。例如:
$foo = 2;
echo "foo is $foo"; // 打印結(jié)果: foo is 2
echo 'foo is $foo'; // 打印結(jié)果: foo is $foo
echo "foo is $foo\n"; // 打印結(jié)果: foo is 2 (同時(shí)換行)
echo 'foo is $foo\n'; // 打印結(jié)果: foo is $foo\n
正如你所看到的,在單引號(hào)串中甚至反斜杠也失去了他的擴(kuò)展含義(除了插入反斜杠\\和插入單引號(hào)\')。所以,當(dāng)你想在字串中進(jìn)行變量代換和包 含\n(換行符)等轉(zhuǎn)義序列時(shí),你應(yīng)該使用雙引號(hào)。單引號(hào)串可以用在其他任何地方,腳本中使用單引號(hào)串處理速度會(huì)更快些,因?yàn)镻HP語(yǔ)法分析器對(duì)單引號(hào)串 的處理方式比較單純,而雙引號(hào)的處理由于串內(nèi)部也需要解析,因此更復(fù)雜些,所以處理速度略慢。
在字符串中引用復(fù)雜的變量組合時(shí),可能會(huì)產(chǎn)生一些問(wèn)題,下面的代碼會(huì)正常工作:
echo "value = $foo";
echo "value = $a[$i]";
而下面的代碼卻不能得到我們希望的結(jié)果:
echo "value = $a[$i][$j]"; //我們希望打印二維數(shù)組$a的某個(gè)元素。
為避免這些字串使用中的潛在問(wèn)題,我們通常把復(fù)雜的變量從字串中分離開(kāi)來(lái),就像這樣:
echo 'value = ' . $a[$i][$j];//字符串的連接用點(diǎn)(.)
還有一種辦法是將復(fù)雜變量用花括號(hào)括起來(lái),語(yǔ)法分析器就能正確辨認(rèn)了:
echo "value = {$a[$i][$j]}" //打印二維數(shù)組$a的某個(gè)元素
這樣,又出現(xiàn)新問(wèn)題了。當(dāng)我們想在字串中引用花括號(hào)字符本身時(shí),就要記得使用轉(zhuǎn)義符了:
$var = 3;
echo "value = {$var}"; // 打印結(jié)果 "value = 3"
echo "value = \{$var}"; // 打印結(jié)果 "value = {3}"
3、在SQL語(yǔ)句中
這是會(huì)經(jīng)常遇到的問(wèn)題,在插入數(shù)據(jù)庫(kù)的SQL語(yǔ)句是采用單引號(hào)來(lái)定義字符串,如果要將一個(gè)含有單引號(hào)的字符串插入數(shù)據(jù)庫(kù),這個(gè)SQL語(yǔ)句就會(huì)出錯(cuò)。如:
$sql="insert into userinfo (username,password) Values('O'Kefee','123456')"
此時(shí),處理的方法之一是在SQL語(yǔ)句中加入轉(zhuǎn)義符反斜線,即:……Values('O\'Kefee',……
當(dāng)然也可以使用函數(shù) addslashes(),該函數(shù)的功能就是加入轉(zhuǎn)義符,即:
$s = addslashes("O'Kefee") ……Values('".$s."',……
還有一種方法是設(shè)置php.ini中的magic-quotes選項(xiàng),打開(kāi)該選項(xiàng),則通過(guò)表單提交的信息中如果有單引號(hào)是,將會(huì)自動(dòng)加上如轉(zhuǎn)義符。因此不用使用其他函數(shù)了。
該文章是轉(zhuǎn)載滴,覺(jué)得好棒,這是原始出處和作者信息:www.mryang.org/logs/23060199.html