分享几个 PHP 编码的最佳实践
对于初学者而言,可能很难理解为什么某些做法更安全。
但是,以下一些技巧可能超出了 PHP 的范围。
始终使用大括号
让我们看下面的代码:
- if (isset($condition) && true === $condition)
- echo 'this is a success';
- 虽然正确,但是你再看看下面的代码
- if (isset($condition) && true === $condition)
- foreach (range("A", "Z") as $letter)
- echo $letter . PHP_EOL;
- echo 'this is a success';
依旧正确,但是 this is a success 最终只 echo 了一次,这可能是一个陷阱。
等等,我们在来看看将 $condition = false;
写在判断之前会发生什么
- $condition = false;
- if (isset($condition) && true === $condition)
- foreach (range("A", "Z") as $letter)
- echo $letter . PHP_EOL;
- echo 'this is a success';
该程序依旧成功打印 this is a success。
这显然不是我们想要的结果,你现在知道为什么花括号很重要了吧?
省略括号通常会导致不良的副作用。此外,阅读代码要困难得多。所以应当将其改写成这样
- $condition = false;
- if (isset($condition) && true === $condition) {
- foreach (range("A", "Z") as $letter) {
- echo $letter . PHP_EOL;
- }
- echo 'this is a success';
- }
跳过 else 部分
在使用任何变量之前,最好对它进行初始化。考虑以下例子:
- if (isset($condition) && true === $condition) {
- $main = 'chocolate';
- } else {
- $main = 'vanilla';
- }
如果你认为上面例子 OK 的话,那么试着添加几个 elseif
条件看看
- if ($condition) {
- $main = 'chocolate';
- $time = 2;
- } elseif($otherCondition)) {
- $main = 'strawberry';
- $time = 3;
- } elseif($otherOtherCondition)) {
- $main = 'apple';
- $time = 1;
- } else {
- $main = 'vanilla';
- $time = 9;
- }
该代码显得很笨重。当你在 elseif
代码块中添加逻辑时你可能会忘记一些变量。
试着这样做:
- $main = 'vanilla';
- $time = 9;
- if ($condition) {
- $main = 'chocolate';
- $time = 2;
- } elseif($otherCondition)) {
- $main = 'strawberry';
- $time = 3;
- } elseif($otherOtherCondition)) {
- $main = 'apple';
- $time = 1;
- }
这种方式,每个人都知道 $main
和 $time
变量在接下来的代码中应该被定义,该代码似乎更具可读性。
这种方式,每个人都知道 $main 和 $time 变量在接下来的代码中应该被定义,该代码似乎更具可读性。
不要使用 @运算符
在 PHP 中 @是一个错误控制操作符。它用于隐藏错误,但事实上没人希望如此。
相反,你应当试着捕获这些错误并使用错误日志记录。
@操作符有着极大的缺点,比如将任何调试变为噩梦或使代码运行更慢!
对于代码的每次运行,它都会调用 INI 设置以将 error_reporting 设为 0,并在这之后将其设回原始值。
它是如此耗费资源。我觉得完全不使用它才是更为安全的。
一些关于三元运算符的想法
虽然三元运算符可能很方便,但代码有可能更加难以阅读。
不要过度使用三元运算符
三元运算可用于简化 if-else 部分:
- $main = ($condition) ? "chocolate" : "vanilla";
含义如下:
- if ($condition) {
- $main = "chocolate";
- } else {
- $main = "vanilla";
- }
上面的例子是 ok 的,但我已经看到过如下的例子:
- $output = ($condition) ? ($otherCondition) ? 'ok' : 'ko' : 'unknown';
不建议链式或嵌套式地使用三元运算。
谨慎使用『Elvis』运算符
Elvis 运算符是一个特殊的运算符。
- $foo = $bar ?: "baz";
以上是指:
- $foo = $bar ? $bar : "baz";
可以这样写:
- if ($bar) {
- $foo = $bar;
- } else {
- $foo = "baz";
- }
信不信由你,正如维基百科所说:
“Elvis 运算符” 这个名字指的是这样一个事实:当它的符号?: 从侧面看时,就像是 埃尔维斯・普雷斯利 (Elvis Presley) 的一个表情符号和他的卷发。
请小心使用空合并运算符
自从 PHP7 起,null 合并运算符 可以用了:
需要将三元运算符与
isset()
结合使用的常见情况的语法。
因此:
- $result = isset($_GET['result']) ? $_GET['result'] : "default";
可以这样写:
- $result = $_GET['result'] ?? "default";
在尝试使用空合并操作符替换 ternaries 和 Elvis 操作符时要格外小心!
空合并运算符从不检查条件是否为真,而是检查您的 var 是否已设置而不为空 ( isset() 的概念)。
综上
我希望你喜欢这些编程技巧。我想说的最后一件事是:请不要为了简洁而牺牲了清晰度。
更多内容请访问
怎么从一名码农成为架构师的必看知识点:目录大全(持续更新)50W年薪挑战!
分享几个 PHP 编码的最佳实践的更多相关文章
- 结合异步模型,再次总结Netty多线程编码最佳实践
更多技术分享可关注我 前言 本文重点总结Netty多线程的一些编码最佳实践和注意事项,并且顺便对Netty的线程调度模型,和异步模型做了一个汇总.原文:结合异步模型,再次总结Netty多线程编码最 ...
- Dropbox可伸缩性设计最佳实践分享
http://www.infoq.com/cn/news/2012/11/dropbox-scale-bestpractice Dropbox的运维工程师Rajiv,跟大家分享了可伸缩性设计的最佳实践 ...
- 敏捷遇上UML-需求分析及软件设计最佳实践(郑州站 2014-6-7)
邀请函: 尊敬的阁下:我们将在郑州为您奉献高端知识大餐,当敏捷遇上UML,会发生怎样的化学作用呢?首席专家张老师将会为您分享需求分析及软件设计方面的最佳实践,帮助您掌握敏捷.UML及两者相结合的实 ...
- 10个精妙的Java编码最佳实践
这是一个比Josh Bloch的Effective Java规则更精妙的10条Java编码实践的列表.和Josh Bloch的列表容易学习并且关注日常情况相比,这个列表将包含涉及API/SPI设计中不 ...
- 你知道吗?10个精妙的 Java 编码最佳实践
这是一个比Josh Bloch的Effective Java规则更精妙的10条Java编码实践的列表.和Josh Bloch的列表容易学习并且关注日常情况相比,这个列表将包含涉及API/SPI设计中不 ...
- 腾讯优测优分享 | 探索react native首屏渲染最佳实践
腾讯优测是专业的移动云测试平台,旗下的优分享不定时提供大量移动研发及测试相关的干货~ 此文主要与以下内容相关,希望对大家有帮助. react native给了我们使用javascript开发原生app ...
- Windows Azure 安全最佳实践 - 第 7 部分:提示、工具和编码最佳实践
在撰写这一系列文章的过程中,我总结出了很多最佳实践.在这篇文章中,我介绍了在保护您的WindowsAzure应用程序时需要考虑的更多事项. 下面是一些工具和编码提示与最佳实践: · 在操作系统上运行 ...
- 智能合约最佳实践 之 Solidity 编码规范
每一门语言都有其相应的编码规范, Solidity 也一样, 下面官方推荐的规范及我的总结,供大家参考,希望可以帮助大家写出更好规范的智能合约. 命名规范 避免使用 小写的l,大写的I,大写的O 应该 ...
- 亿级SQL Server运维的最佳实践PPT分享
这次分享是我在微软的一次分享,关于SQL Server运维最佳实践的部分,由于受众来自不同背景,因此我让分享在一个更加抽象的角度进行,PPT分享如下: 点击这里进行下载
随机推荐
- 跨越真实和虚拟世界的边界——走近SIGGRAPH 2014大会
2014大会" title="跨越真实和虚拟世界的边界--走近SIGGRAPH 2014大会"> 作者:孙鑫 微软亚洲研究院研究员 一场大会振奋一座城 温哥华位于加 ...
- 在腾讯云服务器上安装JDK+Tomcat并启动tomcat
由于Java web项目需要使用到tomcat所以决定在腾讯云服务器(centos7.X)上安装JDK和tomcat,来部署我们的项目. 准备工具: 云服务器:centos7.x+ 本地连接服务器:X ...
- JXL包大解析;Java程序生成excel文件和解析excel文件内容
最近需求变化,需要把excel导入 我以前没有做过,所以我查了一些资料 和参考别人的代码 以下是多种方式: import java.io.File; import java.io.FileInputS ...
- 添砖加瓦:Linux系统监测
前言 前段时间因为项目需求,需要实时获取系统当前的运行状态,遂查阅了不少资料,基于/proc目录下的部分文件,实现了系统CPU.内存.网络和磁盘的实时监测. 一.CPU使用情况获取 获取CPU使用情况 ...
- 机器学习技法笔记(2)-Linear SVM
从这一节开始学习机器学习技法课程中的SVM, 这一节主要介绍标准形式的SVM: Linear SVM 引入SVM 首先回顾Percentron Learning Algrithm(感知器算法PLA)是 ...
- python常用魔术方法概览
构造和初始化 __init__(self, args) 构造函数 __new__(cls) 传入的是类实例 __del__(self) 析构函数,调用 del cls 时会被调用 属性访问控制 __g ...
- diary20180428
17:05:59 今天早晨去了图书馆.学习了一把vscode.试图在河边看电脑,总有小虫不让我专心. 23:27:34 看纯黑直播打战神,有点感触. 动漫或游戏,角色觉醒,实力大增,小时候(甚至现在) ...
- 微软发布MS MARCO数据集,提高计算机阅读理解能力
MARCO数据集,提高计算机阅读理解能力" title="微软发布MS MARCO数据集,提高计算机阅读理解能力"> 本文译自:Microsoft data ...
- linux tc流量控制
tc流量控制 项目背景 vintage3.0接口lookupforupdage增加一个策略,当带宽流量tx或rx超过40%,75%随机返回304:超过60%,此接口均返回304 为了对测试机器进行流量 ...
- 渗透之——MSF提权
在WEB渗透中当我们拿到webshell了,我们可以试试用MSF(metasploit)来进行提权,在MSF里meterpreter很强大的! 我们先用msfvenom生成一个EXE的木马后门. ms ...