经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » PHP » 查看文章
请纠正这5个PHP编码小陋习
来源:cnblogs  作者:八重樱  时间:2020/11/9 16:11:44  对本文有异议

在做过大量的代码审查后,我经常看到一些重复的错误,以下是纠正这些错误的方法。

 

在循环之前测试数组是否为空

  1. $items = [];
  2. // ...
  3. if (count($items) > 0) {
  4. foreach ($items as $item) {
  5. // process on $item ...
  6. }
  7. }

  

foreach 以及数组函数 (array_*) 可以处理空数组。

  • 不需要先进行测试
  • 可减少一层缩进
  1. $items = [];
  2. // ...
  3. foreach ($items as $item) {
  4. // process on $item ...
  5. }

  

将代码内容封装到一个 if 语句汇总

  1. function foo(User $user) {
  2. if (!$user->isDisabled()) {
  3. // ...
  4. // long process
  5. // ...
  6. }
  7. }

  

这不是 PHP 特有的情况,不过我经常碰到此类情况。你可以通过提前返回来减少缩进。

所有主要方法处于第一个缩进级别

  1. function foo(User $user) {
  2. if ($user->isDisabled()) {
  3. return;
  4. }
  5.  
  6. // ...
  7. // 其他代码
  8. // ...
  9. }

  

多次调用 isset 方法

你可能遇到以下情况:

  1. $a = null;
  2. $b = null;
  3. $c = null;
  4. // ...
  5.  
  6. if (!isset($a) || !isset($b) || !isset($c)) {
  7. throw new Exception("undefined variable");
  8. }
  9.  
  10. // 或者
  11.  
  12. if (isset($a) && isset($b) && isset($c) {
  13. // process with $a, $b et $c
  14. }
  15.  
  16. // 或者
  17.  
  18. $items = [];
  19. //...
  20. if (isset($items['user']) && isset($items['user']['id']) {
  21. // process with $items['user']['id']
  22. }

  

我们经常需要检查变量是否已定义,php 提供了 isset 函数可以用于检测该变量,而且该函数可以一次接受多个参数,所以一下代码可能更好

  1. $a = null;
  2. $b = null;
  3. $c = null;
  4. // ...
  5.  
  6. if (!isset($a, $b, $c)) {
  7. throw new Exception("undefined variable");
  8. }
  9. // 或者
  10.  
  11. if (isset($a, $b, $c)) {
  12. // process with $a, $b et $c
  13. }
  14. // 或者
  15. $items = [];
  16. //...
  17. if (isset($items['user'], $items['user']['id'])) {
  18. // process with $items['user']['id']
  19. }

 

  1. echo sprintf 方法一起使用
  1. $name = "John Doe";
  2. echo sprintf('Bonjour %s', $name);

  

看到这段代码你可能会想笑,不过我的确这样写了一段时间,而且我仍然会看到很多这样写的!其实echosprintf并不需同时使用,printf就可以完全实现打印功能。

  1. $name = "John Doe";
  2. printf('Bonjour %s', $name);

  

通过组合两种方法检查数组中是否存在键

  1. $items = [
  2. 'one_key' => 'John',
  3. 'search_key' => 'Jane',
  4. ];
  5.  
  6. if (in_array('search_key', array_keys($items))) {
  7. // process
  8. }

  

我经常看到的最后一个错误是in_arrayarray_keys的联合使用。所有这些都可以使用array_key_exists替换。

  1. $items = [
  2. 'one_key' => 'John',
  3. 'search_key' => 'Jane',
  4. ];
  5.  
  6. if (array_key_exists('search_key', $items)) {
  7. // process
  8. }

  

我们还可以使用isset来检查值是否不是null

  1. if (isset($items['search_key'])) {
  2. // process
  3. }

  

原文链接:http://www.cnblogs.com/a609251438/p/13937721.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号