收藏 分享(赏)

php单引号和双引号的区别.doc

上传人:dcjskn 文档编号:8514606 上传时间:2019-06-30 格式:DOC 页数:8 大小:39KB
下载 相关 举报
php单引号和双引号的区别.doc_第1页
第1页 / 共8页
php单引号和双引号的区别.doc_第2页
第2页 / 共8页
php单引号和双引号的区别.doc_第3页
第3页 / 共8页
php单引号和双引号的区别.doc_第4页
第4页 / 共8页
php单引号和双引号的区别.doc_第5页
第5页 / 共8页
点击查看更多>>
资源描述

1、php 单引号和双引号的区别.txt 今天心情不好。我只有四句话想说。包括这句和前面的两句。我的话说完了对付凶恶的人,就要比他更凶恶;对付卑鄙的人,就要比他更卑鄙没有情人味,哪来人情味 拿什么整死你,我的爱人。收银员说:没零钱了,找你两个塑料袋吧! “单引号和双引号的区别和用法?”现将答案总结了下,写成这篇小短文。 “ “双引号里面的字段会经过编译器解释,然后再当作 HTML 代码输出。 单引号里面的不进行解释,直接输出。 例如: $abc=my name is tome; echo $abc /结果是:my name is tom echo $abc /结果是:$abc echo “$abc

2、“ /结果是: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 = $_REQUESTuser_name; /字符串变量 或 $user=array (“name“= $_REQUESTus

3、er_name,“age“=$_REQUESTage;/数组变量 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 use

4、r_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 部分字符串之间用“.“ 来连接 一、引号定义字符串在 PHP 中,通常一个字符串被定义在一对引号中,如:I am a string in single quotes“I am a strin

5、g in double quotes“PHP 语法分析器是用成对的引号来判断一个字符串的。因此,所有字符串必须使用同一种单或者双引号来定义开始和结束。例如,下面的字串定义是不合法的:“I am not a valid string since I have unmatching quote marksMe neither!“定义字符串时,只有一种引号被视为定义符,即单引号或双引号。于是,如果一个字符串由双引号开始,那么只有双引号被分析器解析。这样,你就可以在双引号串中包含任何其他字符,甚至单引号。下面的引号串都是合法的:$s = “I am a single quote string insi

6、de a double quote string“;$s = I am a “double quote string“ inside a single quote string;当 PHP 遇到与串的开头相对应的引号时,便认为已经到了字符串尾部,于是:“Why doesnt “this“ work?“实际上被 PHP 语法分析器分成三个部分:“Why doesnt “包含一个单引号的双引号串this多余的字符,分析器无法处理“ work?“ 普通字符串上面的这个例子企图在双引号串中包含双引号,而分析器在遇到第二个双引号时便认为字符串结束了。要达到包含引号的目的,必须分析器在遇到串内普通引号的时

7、候忽略它的原意,我们在引号的前面加上一个反斜杠来告诉 PHP:这个引号是字符串的一部分,正确的表示方法是这样:“Why doesnt “that“ work?“在英文字符串中一个常见的问题是撇号的使用,因为它就是一个单引号,而在英文串中十分常见(英文所有格) 。你必须小心处理这些字符:Youd better escape your apostrophes可以看到反斜杠在字符串中有他的特殊含义,当我们需要在字符串中包含反斜杠本身时,需要在该符号前面多加一个反斜杠。例如:$file = “c:windowssystem.ini“;echo $file; / 打印结果为: c:windowssyst

8、em.ini$file = “c:windowssystem.ini“;echo $file; / 打印结果为: c:windowssystem.ini另一种字符串定义方式,能够消除特殊字符的烦恼,而且便于引用较长的文本。该字符串定义方法以;$html .= numbersquare;for ( $i=0 ; $i . $i . . $square . ;$html .= ;三、在字串中使用变量这个功能让你无须使用连接符号来粘和大量的简单字符串。PHP 允许我们在双引号串中直接包含字串变量,我们可以发现下面的两个字串的处理结果是相同的。$full_name = $first_name . .

9、$last_name;$full_name = “$first_name $last_name“;单引号串和双引号串在 PHP 中的处理是不相同的。双引号串中的内容可以被解释而且替换,而单引号串中的内容总被认为是普通字符。例如:$foo = 2;echo “foo is $foo“; / 打印结果: foo is 2echo foo is $foo; / 打印结果: foo is $fooecho “foo is $foon“; / 打印结果: foo is 2 (同时换行)echo foo is $foon; / 打印结果: foo is $foon正如你所看到的,在单引号串中甚至反斜杠也失

10、去了他的扩展含义(除了插入反斜杠和插入单引号) 。所以,当你想在字串中进行变量代换和包含n(换行符)等转义序列时,你应该使用双引号。单引号串可以用在其他任何地方,脚本中使用单引号串处理速度会更快些,因为 PHP 语法分析器对单引号串的处理方式比较单纯,而双引号的处理由于串内部也需要解析,因此更复杂些,所以处理速度略慢。在字符串中引用复杂的变量组合时,可能会产生一些问题,下面的代码会正常工作:echo “value = $foo“;echo “value = $a$i“;而下面的代码却不能得到我们希望的结果:echo “value = $a$i$j“; /我们希望打印二维数组$a 的某个元素。为

11、避免这些字串使用中的潜在问题,我们通常把复杂的变量从字串中分离开来,就像这样: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 程

12、序时经常遇到而且是件有趣的事情。为什么这么说呢,因为这涉及到生成另外一种类型的代码,你必须仔细地考虑和遵循这种代码所要求的编写语法和规则。我们来看这样一个例子,假如你想查询数据库中名字是“OKeefe”的用户,通常 SQL语句的形式是这样的:select * from users where last_name = OKeefe请注意 SQL 语句这个英文所有格(撇号)需使用反斜杠转义。PHP 专门提供了一些函数来处理这样的情况,函数 AddSlashes($str)的用途就是自动在字串中对引号字符插入反斜杠转义符:$last_name = “OKeefe“;$sql = “select *

13、from users where last_name = “ . addslashes($last_name) . “;在这个例子中,你还要在 last_name 字串外面括上单引号(SQL 语法要求) ,由于这里使用的是双引号串,所以对这对单引号就无须使用转义了。下面的这个语句是使用单引号串的等价形式:$sql = select * from users where last_name = . addslashes($last_name) . ;任何时候你要在数据库中写入字串,你都必须确保里面的引号正确使用了转义符号,这是很多 PHP初学者常犯的错误。四、双引号和 HTML与 SQL 语句不

14、同,在标准 HTML 语言中双引号常被用来表示字串(现在很多浏览器具备较强的容错功能,允许在 HTML 中用单引号甚至不用引号表示字符串) ,例如:$html = .$link.;$html = “$link“;HTML 语言不支持反斜杠转义,这一点在我们使用表单的 hidden inputs 来传输数据的时候就会有所体会了。设置 hidden inputs 的值的最好办法,是使用 htmlspecialchars()函数来编码。下面的语句可以正常传输一个可能包含双引号的数据:“ 经常有人问我,听说在 PHP 中处理字符串用单引号会快,那么如果存在变量替换的时候,是使用单引号连接快呢,还是双引

15、号快呢? 简单的回答,显然是苍白无力的。 今天我们来做个实验,看看到底单引号和双引号有什么区别,谁快,谁慢。测试代码如下:接下来,让我们以前文章提到过的 Opcodes 生成器来看看,最终我们的这段代码是怎么被执行的:Branch analysis from position: 0Return foundfilename: /home/xinchen/string.phpfunction name: (null)number of ops: 24compiled vars: !0 = $single_quotes, !1 = $double_quotes, !2 = $var, !3 = $s

16、ingle_quotes_var, !4 = $double_quotes_var, !5 = $single_quotes_var_pre, !6 = $double_quotes_var_preline # op fetch ext return operands-2 0 ASSIGN !0, This+is+a+String3 1 ASSIGN !1, This+is+a+String4 2 ECHO !05 3 ECHO !17 4 ASSIGN !2, String8 5 CONCAT 3 This+is+a+, !26 ASSIGN !3, 39 7 INIT_STRING 58

17、ADD_STRING 5 5, This+is+a+9 ADD_VAR 5 5, !210 ASSIGN !4, 511 11 ECHO !312 12 ECHO !414 13 ASSIGN !2, This16 14 CONCAT 8 !2, +is+a+String15 ASSIGN !5, 817 16 INIT_STRING 1017 ADD_VAR 10 10, !218 ADD_STRING 10 10, +is+a+String19 ASSIGN !6, 1019 20 ECHO !520 21 ECHO !622 22 RETURN 123* ZEND_HANDLE_EXCE

18、PTION注意第 0 到第 3 条 op line, 可以看出在没有使用变量替换的情况下,双引号的和单引号所产生的 Opcodes 是一样的。再来看:第 4 到第 12 条, 可以发现,在使用变量替换的情况下,使用双引号和单引号所生成的 Opcodes 是不一样的,我们来分析双引号情况下的 Opcodes:7 INIT_STRING 初始化一个字符串变量,存放在5 临时变量中。8 ADD_STRING 将第一部分字符串写入。9 ADD_VAR 将变量替换的字符串写入。第 16-28 行同理。从这里我们可以发现,在使用双引号的情况下和使用单引号的情况下,同样的逻辑,所经历的执行确实不一样的(因为

19、,Opcodes 对于 PHP 来说就是最终的执行代码)。单单从生成的Opcods 数量来说,就已经足以证明确实是使用单引号会快了。至于编译阶段,双引号和单引号的区别也是很大的, 我就举个数字来说明: 在 scanning阶段, 对于双引号的词法规则有 14 条,而对于单引号,仅仅只有 6 条。呵呵,是不是经过这样的分析,你会更清楚的了解到以后该怎么使用单引号和双引号了呢?顺便说一句,对于不需要变量替换的纯字符串,大家都知道,因为在 C/C+中,双引号才表示字符串,所以这种情况下,还是使用双引号的好。另外对于 W3C 标准来说, HTML 中的属性值应该是使用双引号来包含的 ,所以不要习惯了单引号,到处滥用哦 看到这些,我可以想到光光是一个引号问题都有这么大学问,是应该好好学习下免得以后搞得我头痛。希望大家也要注意下了。

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 企业管理 > 管理学资料

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报