PHP中单引号和双引号的区别

在PHP中,字符串的概念可以使用朝鲜语单引号’ ‘,也足以使用保加坎Pina斯语双引号” “。

①转义的字符不一样

在PHP中,平日五个字符串被定义在黄金时代对引号中

可是必得使用相似种单或双引号来定义字符串,如:’Hello
World”和”Hello
World’为不法的字符串定义。

单引号和双引号中都能够行使转义字符(\卡塔尔国,但只可以转义在单引号中引起来的单引号和转义转义符本身。假诺用双引号(“”卡塔尔国括起字符串,PHP掌握越多极度字符串的转义体系。

奉公守法上边包车型大巴措施操作:

单引号和双引号到底有甚分化吧?

 ';

$str2 = "\",\\,a\r\n\tb\v\$\'";
echo $str2,'
';
?>

 代码如下

PHP允许我们在双引号串中央机关单位接包罗字串变量。

②对变量的剖释分化
单引号字符串中冒出的变量不会被变量值代替。即PHP不会解析单引号中的变量,而是将变量名原样输出。双引号字符串最重大的某个是内部的变量名会被变量值代替,即能够解析双引号中包罗的变量。

$out = str_replace(array(‘rn’, ‘r’, ‘n’State of Qatar, ”, $out卡塔尔国;PHP
提供两种概念字符串的艺术:单引号、双引号、本地文书档案(菲律宾语名字为 here
document 或然 heredoc)。

而单引号串中的内容总被认为是经常字符,因而单引号中的内容不会被转义功能更加高。

 '; // I am $age years old 
echo $str2,'
'; // I am 20 years old;
?>

单引号:
运用单引号是最便捷的措施,因为 PHP
不会检查单引号字符串中的内置变量和转义系列,需求转义的字符独有反斜杠和单引号自己。

比如:

③解析速度差别

双引号:
会检讨内置变量和转义连串,但不可能分辨转义的单引号。那也正表达了始于这段代码的荒诞之处,精确的做法是行使双引号来定义换行的转义类别:

$str='hello';
echo "str is $str"; //运行结果: str is hello
echo 'str is $str'; //运行结果: str is $str

单引号无需思量变量的解析,速度比双引号快.推荐用单引号.不常双引号也正如好用,举个例子在拼凑sql
语句

 代码如下

php中,双引号中的变量($var卡塔尔国和特殊字符(rn之类卡塔尔会被转义,单引号中的内容不会被转义(所以功能越来越高)。

反斜杠

$out = str_replace(array(“rn”, “r”, “n”), ”, $out);

使用上的话,我原先很喜爱在sql字符串里这么写$sql = “SELECT * FROM table
WHERE id = $id”,那样里面包车型大巴$id能够被转义,单引号就足够。

 //使用单引号
echo ' this \n is \r the blog \t of \\ zhoumanhe \\'; 
//上面使用单引号输出的值是 this \n is \r the blog \t of \ zhoumanhe \

echo '
';
echo "
";

//使用双引号
echo "this \n is \r the blog \t of \\ zhoumanhe \\"; 
//上面使用双引号输出的值是 this is the blog of \ zhoumanhe \ 

当和姑书档案:
检查有着的放权变量和转义类别,双引号无需转义。举例:

在JavaScript中单引号和双引号未有分别,只要成对使用就能够。

使用sql

 代码如下

自身在JavaScript 中选取单引号许多是因为 Javascript 和 HTML
打交道非常多,输出 HTML 片段的时候没有需求转义 HTML 中品质的引号。
一句话来讲,看其实际情形形来,怎么方便怎么利用。

 倘若查询条件中运用的是常量,比如:

echo <<<EOT
this is a “here document” example.
just for test.

select * from abc_table where user_name='abc';

EOT;轻便记录下,加深影像。

SQL语句可以写成:

,如:

SQLstr = “select * from abc_table where user _name= ‘abc'” ;

 代码如下

假如查询条件中行使的是变量,比方:

‘I am a string in single quotes’
“I am a string in double quotes”

$user_name = $_REQUEST['user_name']; //字符串变量

  PHP语法深入分析器是用成对的引号来判别四个字符串的。由此,全体字符串必得接收相像种单仍然双
引号来定义开首和终结。举个例子,上边包车型大巴字串定义是非法的:

 

$user=array (”name”=> $_REQUEST['user_name‘,"age"=>$_REQUEST['age'];//数组变量

 代码如下

SQL语句就足以写成:

 

SQLstr = “select * from abc_table where user_name = ‘ ” . $user_name . ” ‘ “;
SQLstr = “select * from abc_table where user_name = ‘ ” . $user["name"] . ” ‘ “;

“I am not a valid string since I have unmatching quote marks’
‘Me neither!”

相对来讲一下:

  定义字符串时,独有大器晚成种引号被视为定义符,即单引号或双引号。于是,若是七个字符串由双引
号发轫,那么独有双引号被剖析器剖判。那样,你就能够在双引号串中富含其余其余字符,乃至单引
号。上边包车型地铁引号串都以合法的:

SQLstr=”select * from abc_table where user_name = ‘ abc ‘ ” ;
SQLstr=”select * from abc_table where user_name =' ” . $user _name . ” ‘ “;
SQLstr=”select * from abc_table where user_name =' ” . $user["name"] . ” ‘ “;

 代码如下

SQLstr能够解释为以下3个部分:

$s = “I am a ‘single quote string’ inside a double quote string”;
$s = ‘I am a “double quote string” inside a single quote string’;

1:”select * from table where user_name = ‘ ” //固定SQL语句
2:$user //变量
3:” ‘ ”

  当PHP蒙受与串的开端绝对应的引号时,便感觉已经到了字符串尾巴部分,于是:

附:大家也看看了 echo ‘
‘; html中的标签在单引号和双引号中都有效。

“Why doesn’t “this” work?”

总括一下PHP引号使用原则

  实际上被PHP语法深入分析器分成三个部分:

1.字符串的值用引号

“Why doesn’t “——包罗二个单引号的双引号串
this——多余的字符,解析器不能管理
” work?” ——普通字符串

2.PHP中尽量用单引号,HTML代码全体用双引号

  上边的这一个例子妄图在双引号串中隐含双引号,而剖析器在遇到第二个双引号时便感觉字符串结
束了。要达到规定的规范包蕴引号的目标,必需剖析器在遇见串内普通引号的时候不经意它的本心,大家在引号的
眼前加上三个反斜杠来告诉PHP:那几个引号是字符串的少年老成有的,正确的表示方法是这么:

3.在含有变量的时候,用双引号能够简化操作

 代码如下

4.复杂的气象下用大括号包起来

“Why doesn’t “that” work?”

PHP引号还恐怕有二个用场就是,不常须要用php生成文本文件,换行符n须求用双引号技艺好使,单引号则会直接把n当成字符输出。

  在立陶宛共和国语字符串中叁个广阔的难点是撇号’的选取,因为它便是二个单引号,而在印度语印尼语串中万分宽广
(德语全体魄)。你不得不小心管理那么些字符:

运用计算:在字符串里面无需参与 变量 大概 单引号(‘)和反斜杠(\)时,尽量用单引号引字符串,因为省去了双引号检验和检查核对查管理理转义和解析变量上边包车型客车时日。能用单引号尽量用单引号。

 代码如下

‘You’d better escape your apostrophes’

  能够看来反斜杠在字符串中有她的非常意义,当大家须要在字符串中富含反斜杠本人时,需求在
该符号后边多加多少个反斜杠。比如:

 代码如下

$file = “c:windowssystem.ini”;
echo $file; // 打字与印刷结果为: c:windowssystem.ini
$file = “c:windowssystem.ini”;
echo $file; // 打印结果为: c:windowssystem.ini

  另风流倜傥种字符串定义模式,能够清除特殊字符的相当慢,何况便于引用较长的文本。该字符串定义方
法以<<<符号紧跟一个自定义字符串开端,最后大器晚成行以该自定义字符串停止,而且必得顶格。

二、字串的连接

  字串能够使用字串连接符(.卡塔尔来三番五次,如:

 代码如下

$first_name = ‘Charlie’;
$last_name = ‘Brown’;
$full_name = $first_name . ‘ ‘ . $last_name;

  见惯不惊的用处是独当一面大块的HTML字串代码,赋值号 (=卡塔尔 连接符 (.State of Qatar能够被简写合并为 (.=卡塔尔 符
号,如:

 代码如下

$html = ‘<table>’;
$html .=
‘<tr><td>number</td><td>square</td></tr>’;
for ( $i=0 ; $i<10 ; $i++) {
$square = $i * $i;
$html .= ‘<tr><td>’ . $i . ‘</td><td>’ . $square
. ‘</td></tr>’;
}
$html .= ‘</table>’;

三、在字串中选取变量

  那些效用令你不要使用连接符号来粘和大度的粗略字符串。PHP允许大家在双引号串中央职能部门接包括字
串变量,我们能够开采下边包车型客车三个字串的管理结果是千篇后生可畏律的。

 代码如下

$full_name = $first_name . ‘ ‘ . $last_name;
$full_name = “$first_name $last_name”;

  单引号串和双引号串在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

  正如你所看见的,在单引号串中照旧反斜杠也错失了他的恢弘含义(除了插入反斜杠和插入单
引号’)。所以,当你想在字串中开展变量代换和带有n(换行符)等转义种类时,你应该运用双引
号。单引号串能够用在其它任什么位置方,脚本中动用单引号串管理速度会更加快些,因为PHP语法深入分析器对
单引号串的管理格局相比较单纯,而双引号的管理由于串内部也亟需深入分析,因而更复杂些,所以拍卖速
度略慢。

  在字符串中援用复杂的变量组适这时候,大概会时有产生部分题材,上面包车型客车代码会平时办事:

 代码如下

echo “value = $foo”;
echo “value = $a[$i]”;

  而上面包车型地铁代码却不可能收获大家期望的结果:

 代码如下

echo “value = $a[$i][$j]”; //大家盼望打字与印刷二维数组$a的有些成分。

  为防止那几个字串使用中的潜在难题,大家普通把复杂的变量从字串中分别开来,就疑似这么:

 代码如下

echo ‘value = ‘ . $a[$i][$j];

  还只怕有生机勃勃种艺术是将复杂变量用花括号括起来,语法深入分析器就能够科学识别了:

 代码如下

echo “value = {$a[$i][$j]}” //打字与印刷二维数组$a的某部元素

  那样,又出新新主题素材了。当我们想在字串中援引花括号字符自己时,将在记得使用转义符了:

 代码如下

$var = 3;
echo “value = {$var}”; // 打字与印刷结果 “value = 3”
echo “value = {$var}”; // 打字与印刷结果 “value = {3}”

三、斜杠和SQL语句

  生成HTML代码或SQL查询语句是编写PHP程序时平时遇上何况是件风趣的作业。为何那样说呢,
因为那关乎到变化其它生龙活虎连串型的代码,你必得紧凑地酌量和固守这种代码所必要的编辑语法和规
则。

  大家来看这么二个事例,假若你想查询数据库中名字是“O’Keefe”的客户,经常SQL语句的花样
是这么的:

 代码如下

select * from users where
last_name = ‘O’Keefe’

  请小心SQL语句这一个Slovak语全数格(撇号)需采纳反斜杠转义。PHP特意提供了部分函数来管理那样
的景观,函数AddSlashes($str卡塔尔的用处正是全自动在字串中对引号字符插入反斜杠转义符:

 代码如下

$last_name = “O’Keefe”;
$sql = “select * from users where last_name = ‘” .
addslashes($last_name) . “‘”;

  在这里个事例中,你还要在last_name字串外面括上单引号(SQL语法要求),由于此地运用的是双
引号串,所以对那对单引号就无须使用转义了。上面包车型地铁那个讲话是行使单引号串的拾壹分方式:

 代码如下

$sql = ‘select * from users where last_name = ” .
addslashes($last_name) . ”’;

  任曾几何时候你要在数据库中写入字串,你都一定要确定保障内部的引号精确使用了转义符号,这是累累PHP
初读书人常犯的不当。

四、双引号和HTML

  与SQL语句分裂,在正规HTML语言中双引号常被用来代表字串(以后游人如织浏览器材有较强的容错功
能,允许在HTML中用单引号以致毫无引号表示字符串),比如:

 代码如下

$html = ‘<a href=”‘.$url.'”>’.$link.'</a>’;
$html = “<a href=”$url”>$link</a>”;

  HTML语言不支持反斜杠转义,那点在大家采纳表单的hidden
inputs来传输数据的时候就能有着
认识了。设置hidden
inputs的值的最佳点子,是利用htmlspecialchars(卡塔尔函数来编码。下边包车型客车语句可
以健康传输三个恐怕带有双引号的数据:

 代码如下

  <input type=hidden name=var
value=”<?php echo
htmlspecialchars($var) ?>”> 

大器晚成、引号定义字符串。要到达富含引号的目标,
必得深入分析器在遇见串内普通引号的时候忽视它的本心,大家在引号的
后面加上两个反斜杠来报告PHP:那些引号是字符串的大器晚成部分,精确的意味方法是这么:单引号串能够用在别的任哪里方,脚本中动用单引号串处理速度会更加快些,因为PHP语法深入分析器对
单引号串的管理情势相比单纯,而双引号的拍卖由于串内部也供给深入分析,因而更头眼昏花些,所以拍卖速
度略慢。

以此…双引号转义,单引号不转义
如:/r/n是换行,可是只要你用单引号写入文件,不会是换行,而是多少个字符,假如用双引号写入文件,正是换行.

最后看看别的网址的说法

” ” 双引号里面包车型大巴字段会经过编写翻译器解释,然后再作为HTML代码输出。

‘ ‘ 单引号里面包车型地铁不开展表明,直接出口。

从字面意思上就足以看看,单引号比双引号要快了。

例如:

 代码如下

$abc=’my name is tome’;
echo $abc //结果是:my name is tom
echo ‘$abc’ //结果是:$abc
echo “$abc” //结果是:my name is tom

特地在动用MYSQL语句的时候,双引号和单引号的用法让新手手足无措,在此边,举个例子,来进展验证。

假使查询条件中接纳的是常量,举个例子:

 代码如下

select * from abc_table where user_name=’abc’;

SQL语句能够写成:

 代码如下

SQLstr = “select * from abc_table where user _name= ‘abc’” ;

假诺查询条件中运用的是变量,比方:

 代码如下

$user_name = $_REQUEST[‘user_name’]; //字符串变量

 代码如下

$user=array (”name”=>
$_REQUEST[‘user_name‘,”age”=>$_REQUEST[‘age’];//数组变量

SQL语句就足以写成:

 代码如下

SQLstr = “select * from abc_table where user_name = ‘ ” . $user_name
. ” ‘ “;

SQLstr = “select * from abc_table where user_name = ‘ ” .
$user[“name”] . ” ‘ “;

对待一下:

 代码如下

SQLstr=”select * from abc_table where user_name = ‘ abc ‘ ” ;

SQLstr=”select * from abc_table where user_name =’ ” . $user _name .
” ‘ “;

SQLstr=”select * from abc_table where user_name =’ ” .
$user[“name”] . ” ‘ “;

SQLstr能够解释为以下3个部分:

 代码如下

1:”select * from table where user_name = ‘ ” //固定SQL语句
2:$user //变量
3:” ‘ ”
1,2,3局地字符串之间用”.”

发表评论

电子邮件地址不会被公开。 必填项已用*标注