我有两个特殊情况,我不同意一个同事,是否应该使用常数.
我们使用一个大致像Symfony 1.x的自制框架.
>初始代码是,在一个路由选择PHP配置文件中进行路由,就像这样:
$router->map('/some_url',array('module' => 'some_module','action' => 'some_action')); $router->map('/some_other_url','action' => 'some_action')); // etc.
同事将其改为:
$router->map('/some_url',array(MODULE => 'some_module',ACTION => 'some_action')); $router->map('/some_other_url',ACTION => 'some_action')); // + in constants.PHP file: define('MODULE','module'); define('ACTION','action');
IMO这是不断的过度使用:如果“模块”或“动作”的概念被重命名,它将必须在整个代码中重命名,写为字符串或常量.此外,上面定义的常量名称没有非常具体的含义,有利于命名冲突/混淆.
>初始代码示例:
if (isset($_SESSION['unid']) && isset($_SESSION['login'])) { ... }
由同事修改:
if (isset($_SESSION[UNID]) && isset($_SESSION[LOGIN])) { ... } // + in a constants.PHP file: define('UNID','unid'); define('LOGIN','login');
在我们的应用程序中,这些会话变量名称为unid,登录名显然不大可能改变.尽管如此,如果声明常量在这里真的很好,我建议至少更精确的名称,例如FIELDNAME_UNID和FIELDNAME_LOGIN …
引入这些常数真的很相关(也就是说,命名应该是改进的),或者(我猜想)完全没用?
谢谢.
编辑
几个月后,这里有几条(令人难以置信的)lines.PHP文件.
我肯定发现这是一个完全无用的混乱,类似于this DailyWTF post.太多的常数杀死常数.
define('POST','POST'); define('GET','GET'); define('PROJECT','project'); define('APPLICATION','application'); define('MODULE','action'); define('ID','id'); define('SLUG','slug'); define('CONTROLLER','controller'); define('CONTENT','content'); define('AJAX','ajax'); define('EXECUTE','execute'); define('FORMAT','format'); define('BASE_HREF_CONSTANT','basehref'); define('UNID','unid'); define('USERNAME','username'); define('PASSWORD','password'); define('TEMPLATE','templates'); define('UNSECURE','unsecure'); define('MODE','mode'); define('MESSAGE','message'); define('TEMPORARY_SESSION','temporary_session'); define('ERRORMESSAGE','errormessage'); define('START_FROM','startfrom'); define('COUNT','count'); // and so on.