最近项目使用symfony框架,这个框架对数据库的操作在这个团队里使用的是ORM进行操作,说实话使用ORM的开发效率和运行效率不一定高多少,到是它的实体命名和现有数据库字段的命名不太一样,ORM实体属性命名是驼峰式的,数据库字段是下划线分隔,这就产生了字段映射的过程。当碰到需要手动写实体必须的数组时,字段映射是一件很头疼的事情,尤其是字段比较多的时候,写到你想吐。到这就产生一个问题就是把以下划线分隔的命名字段转换成驼峰式命名。小弟我也很懒,在网上找了半天,也没找到一个具体的PHP Demo,有的也是java写的,还着还挺复杂。于是乎我就自己动手丰衣足食,顺手写了两个,废话不多说直接贴代码:
<?php //微妙时间 function microtime_float() { list($usec, $sec) = explode(" ", microtime()); return ((float)$usec + (float)$sec); } //将下划线命名转换为驼峰式命名 function convertUnderline1 ( $str , $ucfirst = true) { while(($pos = strpos($str , ‘_‘))!==false) $str = substr($str , 0 , $pos).ucfirst(substr($str , $pos+1)); return $ucfirst ? ucfirst($str) : $str; } //将下划线命名转换为驼峰式命名 function convertUnderline2 ( $str , $ucfirst = true) { $str = explode(‘_‘ , $str); foreach($str as $key=>$val) $str[$key] = ucfirst($val); if(!$ucfirst) $str[0] = strtolower($str[0]); return implode(‘‘ , $str); } //第一种方式调用10w次所需时间 $s1 = microtime_float(); for ($i=0;$i<1000;$i++) { $str= ‘abcd_efgh_igk_lmn‘; convertUnderline1($str); } $e1 = microtime_float(); echo ‘convertUnderline1: run time = ‘; echo $e1-$s1;echo ‘<br />‘; //第二种方式调用10w次所需时间 $s2 = microtime_float(); for ($i=0;$i<1000;$i++) { $str= ‘abcd_efgh_igk_lmn‘; convertUnderline2($str); } $e2 = microtime_float(); echo ‘convertUnderline2: run time = ‘; echo $e2-$s2;
为什么我要写两个呢?两种不同的处理方式,我是想看看那个处理效率高。
经过测试发现,字符串拼接的方式要比用数组来处理慢了0.1秒,当然这是每个函数执行10w次才能看出的结果,当然1w次也能看出差别,1次就可以忽略不计了。
下面是测试结果:
执行1K次:
convertUnderline1: run time = 0.0050010681152344
convertUnderline2: run time = 0.0039999485015869
执行1w次:
convertUnderline1: run time = 0.05500602722168
convertUnderline2: run time = 0.036003828048706
执行10w次:
convertUnderline1: run time = 0.46304702758789
convertUnderline2: run time = 0.31903195381165
为什么字符串截取拼接要比数组连接慢呢?如果你看过PHP C的底层你就会明白了。所以以后如果有大量的字符串需要连接成一个字符串的 不要在用点连接了,放在一个数组后使用implode连接。
还有一个要说的,这样的方法同样在JS里也是,数组连接要比字符串连接块。