27、除非脚本可以缓存 , 否则每次调用时都会重新编译一次 。引入一套PHP缓存机制通常可以提升25%至100%的性能,以免除编译开销 。
28、尽量做缓存,可使用memcached 。memcached是一款高性能的内存对象缓存系统,可用来加速动态Web应用程序 , 减轻数据库负 载 。对运算码 (OP code)的缓存很有用,使得脚本不必为每个请求做重新编译 。
29、当操作字符串并需要检验其长度是否满足某种要求时,你想当然地会使用strlen()函数 。此函数执行起来相当快,因为它不做任何计算 , 只返 回在zval 结构(C的内置数据结构,用于存储PHP变量)中存储的已知字符串长度 。但是,由于strlen()是函数,多多少少会有些慢,因为函数调用会经过诸多步 骤,如字母小写化(译注:指函数名小写化 , PHP不区分函数名大小写)、哈希查找,会跟随被调用的函数一起执行 。在某些情况下,你可以使用isset() 技巧加速执行你的代码 。
(举例如下)
if (strlen($foo)5) { echo “Foo is too short”$$ }
(与下面的技巧做比较)
if (!isset($foo{5})) { echo “Foo is too short”$$ }
调用isset()恰巧比strlen()快,因为与后者不同的是,isset()作为一种语言结构,意味着它的执行不需要函数查找和字母小写化 。也就是说 , 实际上在检验字符串长度的顶层代码中你没有花太多开销 。
34、当执行变量$i的递增或递减时 , $i++会比++$i慢一些 。这种差异是PHP特有的,并不适用于其他语言 , 所以请不要修改你的C或Java 代码并指望它们能立即变快,没用的 。++$i更快是因为它只需要3条指令(opcodes),$i++则需要4条指令 。后置递增实际上会产生一个临时变 量 , 这个临时变量随后被递增 。而前置递增直接在原值上递增 。这是最优化处理的一种 , 正如Zend的PHP优化器所作的那样 。牢记这个优化处理不失为一个好 主意,因为并不是所有的指令优化器都会做同样的优化处理 , 并且存在大量没有装配指令优化器的互联网服务提供商(ISPs)和服务器 。
35、并不是事必面向对象(OOP) , 面向对象往往开销很大 , 每个方法和对象调用都会消耗很多内存 。
36、并非要用类实现所有的数据结构 , 数组也很有用 。
37、不要把方法细分得过多,仔细想想你真正打算重用的是哪些代码?
38、当你需要时 , 你总能把代码分解成方法 。
39、尽量采用大量的PHP内置函数 。
40、如果在代码中存在大量耗时的函数 , 你可以考虑用C扩展的方式实现它们 。
41、评估检验(profile)你的代码 。检验器会告诉你,代码的哪些部分消耗了多少时间 。Xdebug调试器包含了检验程序,评估检验总体上可 以显示出代码的瓶颈 。
42、mod_zip可作为Apache模块,用来即时压缩你的数据,并可让数据传输量降低80% 。
43、在可以用file_get_contents替代file、fopen、feof、fgets等系列方法的情况下,尽量用 file_get_contents,因为他的效率高得多!但是要注意file_get_contents在打开一个URL文件时候的PHP版本问题;
44、尽量的少进行文件操作,虽然PHP的文件操作效率也不低的;
45、优化Select SQL语句,在可能的情况下尽量少的进行Insert、Update操作(在update上,我被恶批过);
46、尽可能的使用PHP内部函数(但是我却为了找个PHP里面不存在的函数,浪费了本可以写出一个自定义函数的时间,经验问题?。。?
47、循环内部不要声明变量,尤其是大变量:对象(这好像不只是PHP里面要注意的问题吧?);
- redis的热点数据缓存 redis热点数据切换
- redis缓存失效怎么办 redis缓存数据不一致
- mongodb 更新子文档 mongodb数据文件无法新建
- mongodb查看数据库大小 查看mongodb集群容量
- mysql数据统计方案
- mysql创建数据表时指定字符集 mysql有符号创建
- 纯phpmysql
- mysql数据库优化 mysql订单优化
- 查找php.ini phpredis查找
- redis哨兵模式数据不一致 redis为什么叫哨兵
