9条PHP编程小知识及易犯的小错误


Posted in PHP onJanuary 22, 2015

变量声明

如果在一条语句中声明一个变量,如下所示:$var='value';编译器首先会求出语句右半部分的值,恰恰正是语句的这一部分常常会引发错误。如果使用的语法不正确,就会出现解析错误。

解析错误

例如,Parse error:解析错误,unexpected T_WHILE in c:program filesapache groupapachehtdocsscript.php on line 19每次确定了前一错误时,解析错误一个接一个地不断出现,PHP在第一个解析错误之后就停止执行脚本。而且,解析错误具有很少的信息,几乎不报告错误所在的行号。比如表达式中使用了预定义的关键字,例如:while=10;while就是一个预定义的关键字,不能分配给它一个值。预定义关键字包括while、function等,我们不能使用这些预定义关键字来命名变量,否则编译器就会报错。其中,T_IF代表if(),T_WHILE代表while(),T_FOR代表for()等。

常见的错误

还有一些常见的错误,比如语句没有使用分号(;)结束,字符串中缺少引号等。另外就是,没有使用大括号(})结束一个函数或者一个循环,比如:function UselessFunction(){for($i<0;$i<10;$i++){}将产生下列错误:Parse error:parse error,unexpected$in c:program filesapache groupapachehtdocsereg2.php on line 9由于函数UselessFunction没有使用大括号(})来结束,PHP编译器会不断查找表示结束的大括号直至到达文件末尾为止。因为编译器未找到一个匹配的大括号,就会报告文件末尾处有错误。如果正确地反映了代码的层次结构,错误信息就会变得非常明显。否则,代码调试起来就会非常的困难。所以,一定要标明代码的层次结构,这对后续的开发人员来说,改进代码也会更容易一些。

MySQL错误

另一类的错误信息就是MySQL错误,这常常使PHP新手感到颇为头疼,比如:Warning:Supplied argument is not a valid MySQL result resource in...上面所报告有错的一行可能是:while($row=mysql_fetch_array($result)){}参数$result并不是一个有效的资源,因为查询失败,将无法处理mysql_fetch_array。任一查询的语法无效或者与数据库的连接失败,应该到MySQL控制台进行测试。

注意echo和print的区别

PHP中echo和print都是输出的作用,但是两者之间还是有细微的差别。echo输出后没有返回值,但print有返回值,当其执行失败时返回flase。因此可以作为一个普通函数来使用,例如执行$r=print"Hello World";变量$r的值将为1。而且代码中echo语句的运行效率要略快于print语句。

注意空字符串('')和NULL的区别

PHP中空字符串和NULL都是以值为0存储的,但是他们的类型并不一样,前者是string,而后者是NULL,可见字符串('')、NULL值相等但类型不等。

分清==(等于)和===(全等于)的区别

两者都属于比较运算符,==(等于)只比较值是否相等,而===(全等于)则不但比较值是否相等,还会比较类型是否相等,它更为严格。

分清include与require的区别

include()与require()的功能也基本相同,但在用法上也有一些不同,include()是有条件包含函数,而require()则是无条件包含函数。例如在下面代码中,如果变量$a为真,则将包含文件a.php:if($a){include("a.php");}而require()则和include()不同,不管$a取何值,下面的代码都会把文件a.php包含:if($a){require("a.php");}在错误处理方面,使用include语句,如果发生包含错误,程序将跳过include语句,虽然会显示错误信息但是程序还是会继续执行。但是,requre语句会提示一个致命错误。

注意isset和empty的区别

empty是判断一个变量是否为“空”,而isset则是判断一个变量是否已经被设置。

分清self::和this-->的区别

在访问PHP类中的成员变量或方法时,如果被引用的变量或者方法被声明成const(常量)或者static(静态属性),那么就必须使用域操作符::,而如果被引用的变量或者方法没有被声明成const或者static,那么就使用指向操作符->。

PHP 相关文章推荐
让PHP COOKIE立即生效,不用刷新就可以使用
Mar 09 PHP
PHP输出缓存ob系列函数详解
Mar 11 PHP
用PHP代替JS玩转DOM的思路及示例代码
Jun 15 PHP
Laravel中扩展Memcached缓存驱动实现使用阿里云OCS缓存
Feb 10 PHP
Codeigniter检测表单post数据的方法
Mar 21 PHP
Yii中CGridView实现批量删除的方法
Dec 28 PHP
PHP获取用户访问IP地址的5种方法
May 16 PHP
thinkPHP框架可添加js事件的分页类customPage.class.php完整实例
Mar 16 PHP
PHP使用new StdClass()创建空对象的方法分析
Jun 06 PHP
PHP实现将标点符号正则替换为空格的方法
Aug 09 PHP
laravel migrate初学常见错误的解决方法
Oct 11 PHP
Yii2.0框架实现带分页的多条件搜索功能示例
Feb 20 PHP
PHP将HTML转换成文本的实现代码
Jan 21 #PHP
php使用Cookie控制访问授权的方法
Jan 21 #PHP
PHP+MySQL修改记录的方法
Jan 21 #PHP
PHP+MySQL删除操作实例
Jan 21 #PHP
PHP+MySQL插入操作实例
Jan 21 #PHP
php+mysql数据库查询实例
Jan 21 #PHP
php使用Cookie实现和用户会话的方法
Jan 21 #PHP
You might like
php5 图片验证码实现代码
2009/12/11 PHP
javascript之通用简单的table选项卡实现(二)
2010/05/09 Javascript
jQuery实现的类flash菜单效果代码
2010/05/17 Javascript
jquery动态切换背景图片的简单实现方法
2016/05/14 Javascript
jQuery改变form表单的action,并进行提交的实现代码
2016/05/25 Javascript
基于JS实现checkbox全选功能实例代码
2016/10/31 Javascript
JavaScript之underscore_动力节点Java学院整理
2017/07/03 Javascript
微信小程序 input输入及动态设置按钮的实现
2017/10/27 Javascript
angular2模块和共享模块详解
2018/04/08 Javascript
JavaScript引用类型Array实例分析
2018/07/24 Javascript
webuploader分片上传的实现代码(前后端分离)
2018/09/10 Javascript
浅谈针对Vue相同路由不同参数的刷新问题
2018/09/29 Javascript
vue 中Virtual Dom被创建的方法
2019/04/15 Javascript
详解在React-Native中持久化redux数据
2019/05/22 Javascript
vue router 传参获取不到的解决方式
2019/11/13 Javascript
JavaScript复制变量三种方法实例详解
2020/01/09 Javascript
Python3 log10()函数简单用法
2019/02/19 Python
Python如何使用PIL Image制作GIF图片
2020/05/16 Python
Python xlrd模块导入过程及常用操作
2020/06/10 Python
python读取图像矩阵文件并转换为向量实例
2020/06/18 Python
python基于pygame实现飞机大作战小游戏
2020/11/19 Python
css3背景图片透明叠加属性cross-fade简介及用法实例
2013/01/08 HTML / CSS
html5 冒号分隔符对齐的实现
2019/07/31 HTML / CSS
英国浴室洗脸盆购物网站:Click Basin
2018/06/08 全球购物
应届毕业生自我鉴定范文
2013/12/27 职场文书
领导的自我鉴定
2013/12/28 职场文书
简单英文演讲稿
2014/01/01 职场文书
护士的自我鉴定
2014/02/07 职场文书
小学生期末评语大全
2014/04/21 职场文书
公司踏青活动方案
2014/08/16 职场文书
领导干部作风建设自查报告
2014/10/23 职场文书
单位介绍信格式范文
2015/05/04 职场文书
法定代表人身份证明书
2015/06/18 职场文书
教师远程研修感悟
2015/11/18 职场文书
浅谈Python列表嵌套字典转化的问题
2021/04/07 Python
MySQL 分区表中分区键为什么必须是主键的一部分
2022/03/17 MySQL