PHP字符串常量过度使用?

前端之家收集整理的这篇文章主要介绍了PHP字符串常量过度使用?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有两个特殊情况,我不同意一个同事,是否应该使用常数.

我们使用一个大致像Symfony 1.x的自制框架.

>初始代码是,在一个路由选择PHP配置文件中进行路由,就像这样:

  1. $router->map('/some_url',array('module' => 'some_module','action' => 'some_action'));
  2. $router->map('/some_other_url','action' => 'some_action'));
  3. // etc.

同事将其改为:

  1. $router->map('/some_url',array(MODULE => 'some_module',ACTION => 'some_action'));
  2. $router->map('/some_other_url',ACTION => 'some_action'));
  3.  
  4. // + in constants.PHP file:
  5. define('MODULE','module');
  6. define('ACTION','action');

IMO这是不断的过度使用:如果“模块”或“动作”的概念被重命名,它将必须在整个代码重命名,写为字符串或常量.此外,上面定义的常量名称没有非常具体的含义,有利于命名冲突/混淆.
>初始代码示例:

  1. if (isset($_SESSION['unid']) && isset($_SESSION['login'])) { ... }

由同事修改

  1. if (isset($_SESSION[UNID]) && isset($_SESSION[LOGIN])) { ... }
  2.  
  3. // + in a constants.PHP file:
  4. define('UNID','unid');
  5. define('LOGIN','login');

在我们的应用程序中,这些会话变量名称为unid,登录名显然不大可能改变.尽管如此,如果声明常量在这里真的很好,我建议至少更精确的名称,例如FIELDNAME_UNID和FIELDNAME_LOGIN …

引入这些常数真的很相关(也就是说,命名应该是改进的),或者(我猜想)完全没用?

谢谢.

编辑

几个月后,这里有几条(令人难以置信的)lines.PHP文件.
我肯定发现这是一个完全无用的混乱,类似于this DailyWTF post.太多的常数杀死常数.

  1. define('POST','POST');
  2. define('GET','GET');
  3.  
  4. define('PROJECT','project');
  5. define('APPLICATION','application');
  6. define('MODULE','action');
  7. define('ID','id');
  8. define('SLUG','slug');
  9. define('CONTROLLER','controller');
  10. define('CONTENT','content');
  11. define('AJAX','ajax');
  12. define('EXECUTE','execute');
  13. define('FORMAT','format');
  14. define('BASE_HREF_CONSTANT','basehref');
  15. define('UNID','unid');
  16. define('USERNAME','username');
  17. define('PASSWORD','password');
  18. define('TEMPLATE','templates');
  19. define('UNSECURE','unsecure');
  20. define('MODE','mode');
  21. define('MESSAGE','message');
  22. define('TEMPORARY_SESSION','temporary_session');
  23. define('ERRORMESSAGE','errormessage');
  24. define('START_FROM','startfrom');
  25. define('COUNT','count');
  26.  
  27. // and so on.
有一个使用常量的有效参数.

如果你不小心做了像:

  1. $router->map('/some_url',array('moduel' => 'some_module','action' => 'some_action'));

它将以一些未定义的方式失败(注意拼写错误的“moduel”).

如果您在涉及常数时发生拼写错误或拼写错误,PHP会发出通知,并立即抓住.

实际上节省你的频率是一个辩论的问题.就个人而言,我通常不认为这是值得的.

猜你在找的PHP相关文章