多数大学生出来选择的工作和专业无关
首页 > 专业知识

详细讲解phpCB批量转换的代码示例

时间:2018-09-12 19:16:11 [来源]:郑州PHP培训学校

   详细讲解phpCB批量转换的代码示例

  phpCB批量转换的程序代码对于一个新手来说并不是很快就能写出来的。我们在文章中给出了一个范例,希望能作为一个参考学习的对象。
  我们在使用PHP语言的时候会遇到转换图片文件的需求。如果实现批量转换的话,就能节约大量的时间。下面我们就为大家具体讲解有关phpCB批量转换的方法。
  最近需要整理一个整站的php代码规范视图,前几天发现phpCB整理视图非常好,但有个缺点是不能批量处理,使用过程中发现phpCB是一个CMD程序,马上就想到php的system函数调用cmd,想到就做,下面是phpCB批量转换的php程序:
  < ?
  header("Content-type: text/html; charset=gb2312");define('ROOT_PATH', dirname(__FILE__));
  $topath="ww"; //要格式化视图的目录名,前后都不要“/”
  $path=ROOT_PATH."/".$topath;
  $arr=get_all_files($path);
  for($i=0;$i<count($arr);$i++)
  {
  $phpext=fileext($arr[$i]);
  if($phpext=="php")
  {
  $cmd="phpCB.exe ".$arr[$i]." > ".$arr[$i].".phpCB";system($cmd);
  unlink($arr[$i]);
  @rename($arr[$i].".phpCB",$arr[$i]);
  }
  }
  function get_all_files($path){
  $list = array();
  foreach(glob($path . '/*') as $item){
  if(is_dir($item)){
  $list = array_merge($list , get_all_files( $item ));} else {
  $list[] = $item;
  }
  }
  return $list;
  }
  function fileext($filename) {
  return trim(substr(strrchr($filename, '.'), 1, 10));}
  ?>
  phpCB批量转换的使用方法:把phpCB.exe放在windows/system32/目录下,php执行程序和要转换的文件夹放同一级路径,先配置$topath,然后在浏览器里访问本程序,没有结果输出。
  如何高效优化PHP代码解析损耗
  PHP代码解析损耗的优化目标是一个访问只运行一个php文件,并且这个文件里不包含任何与这个流程无关的代码。
  程序员们在进行PHP代码编程中总会希望对自己的代码程序进行最优化的操作,使程序尽量的轻便简洁。我们在性能分析shopex性能的时候。
  发现用在PHP的语法解析上的损耗占了很大比重,如果用valgrind看他的C调用的话,就会发现大约50%的时间被用在lex&yacc上面。也就是由PHP代码转成opcode的部分。即PHP代码解析损耗。
  这个方面PHP代码解析损耗的优化极限目标是: 一个访问只运行一个PHP文件,并且这个文件里不包含任何与这个流程无关的代码。
  如何兼顾代码结构容易理解和性能是个挑战
  我们的处理思路是,通过类似smarty的编译系统,将访问编译成一个个文件:因为shopex是mvc的结构,那么编译粒度就每个控制器的方法对应一个流程文件。
  当控制器第一次调用时,通过一种方法监控流经的每个model-method,子过程等等,最后抽取剥离出来,加上公用的数据库连接函数,配置文件等等一起组合成一个单一的终极PHP文件。
  至于缓存的更新基本就是版本的更新,每次升级的时候。touch一个cachestat文件的最后修改时间即可。
  那么实现的挑战有两个:
  * 一个叫model的函数化 (这样叫很酷,有点像虚的死神化) 。是弱化model层对象特性,让类退化为仅是函数的容器,减少继承,重载这些应用。
  * 二是实现一个自己的编译引擎。
  上面两条最新的shopex485已经走了很远了,商品和订单的函数都已经拆分了。第二个PHP代码解析损耗的解决办法是我们自己实现了一个叫tramsy的解析器( 翻转(smart)+y ),特点是把大量的插件改成了编译型。强化了编译插件的特性,增加了一种编译型modifier的插件类型。并且提出了变量预绑定的概念:
  {if $var=1}
  yes
  {elseif $var=2}
  no
  {else}
  what?
  {/if}
  如果是原生的smarty,生成的代码是:
  vars['var']==1){ ?>
  yes
  vars['var']==2){ ?>
  no
  what?
  如果在tramsy里,程序员预测var一定是1,并且有把握在其值改变的时候系统自动清除模板缓存,就可以把他设置为”预绑定变量”
  那么最终生成的代码就是:
  no
  这个设计大约减少了一倍多的编译结果。性能提升了大约20%,极大的优化了PHP代码解析损耗。
  PHP整数取余返回负数的相关解决办法
  PHP整数取余返回负数对于编程经验不足的新手来说还是比较头疼的一件事。希望通过本文介绍的内容,大家能充分掌握这一解决办法。
  PHP语言虽然功能强大,但并不代表其没有缺点,在编写代码的过程中未免会遇到一些让人头痛的问题。下面我们将为大家介绍有关PHP整数取余返回负数的解决办法。
  我们先来看个例子.
  $res = 16244799483;
  echo $res%9999999;
  // 输出结果为 -5069794, 正确的结果应该是4801107其实这也算上PHP一个BUG吧.最主要是PHP是个弱类型语言.他内置了机器来判断用户的类型.
  但是机器毕竟是机器.也有判断出错的时候.就像上面.所以这时候我们就需要人工干预下.
  所以我就想到要用下面的方法来解决PHP整数取余返回负数的问题.
  $res = floatval(16244799483);
  var_dump($res % 9999999);
  我们看到结果还是错误的-5069794.
  但是值得注意的是返回是一个int类型的.
  详细思考了一下.PHP整数取余返回负数的问题是这样处理的.
  PHP取余默认为整数的.
  而且当你定义$res = 16244799483;
  其实就已经溢出了.所以要加上强制类型转换.变成float类型.
  但是这样还不够.因为%这个取模计算还是针对整数的.
  所以我们需要一个函数fmod.是针对float类型的.
  所以最终PHP整数取余返回负数的解决办法为:
  $res = floatval(16244799483);
  var_dump(fmod($res,9999999));
  这样我们就解决了PHP整数取余返回负数这个问题.:)

上一篇:php中一些常用的字符处理函数

下一篇:简单快捷PHP数组赋值方法详解