日志列表
RSSphp 查询 mysql时区分大小写
如果想让php在查询时能区分大小写可以在字段前面加一个字段 ‘binary’
如:我想模糊查询标题中包含 ’pHp‘ 这个单词的记录可以这样来写
select title from table where binary title like ‘%pHp%’
如果写成
select title from table where binary title like ‘%php%’
将查询不到
这样在查询的时候就会按照大小写来进行搜索
当然你也可以修改数据库字段的类型为 ‘binary’
这样你所有的查询都将以区分大小写来查询
php中utf-8编码和GB2312编码 正则表达式汉字匹配
在javascript中,要判断字符串是中文是很简单的。比如:
var str = 'php编程'; if (/^[u4e00-u9fa5]+$/.test(str)) { alert('该字符串全部是中文'); } else { alert('该字符串不全部是中文'); }
想当然的,在php中来判断字符串是否为中文,就会沿袭这个思路:
不过,很快就会发现,php并不支持这样的表达,报错:
Warning: preg_match() [
function.preg-match
]: Compilation failed: PCRE does not support L, l, N, U, or u at offset 3 in test.php on line 3
,想从php正则表达式对于十六进制数据的表达方式上进行突破,发现在php中,是用x表示十六进制数据的。于是,变换成如下的代码:
$str = 'php编程'; if (preg_match("/^[x4e00-x9fa5]+$/", $str)) { echo '该字符串全部是中文'; } else { echo '该字符串不全部是中文'; }
貌似不报错了,判断的结果也正确,不过把$str换成“编程”两字,结果却还是显示“该字符串不全部是中文”,看来这样的判断还是不够准确。
模式修正符: u
u (PCRE_UTF8)
此修正符启用了一个 PCRE 中与 Perl 不兼容的额外功能。模式字符串被当成 UTF-8。本修正符在 Unix 下自 PHP 4.1.0 起可用,在 win32 下自 PHP 4.2.3 起可用。
例子:
preg_match(‘/[x{2460}-x{2468}]/u’, $str); 匹配 内码汉字
按照他提供的方式进行测试,代码如下:
$str = 'php编程'; if (preg_match("/^[x{2460}-x{2468}]+$/u", $str)) { echo '该字符串全部是中文'; } else { echo '该字符串不全部是中文'; }
发现这次依然对是否为中文判断失常。不过,既然x表示的十六进制数据,为什么和js里边提供的范围x4e00-x9fa5不一样呢?于是我就换成了下边的代码:
$str = 'php编程'; if (preg_match("/^[x4e00-x9fa5]+$/u", $str)) { echo '该字符串全部是中文'; } else { echo '该字符串不全部是中文'; }
本来以为铁定成功了的事情,没想到,warning又一次产生了:
Warning: preg_match() [
function.preg-match
]: Compilation failed: invalid UTF-8 string at offset 6 in test.php on line 3
看来又有错误的表达方式了,于是对照了一下那篇文章的表达方式,给“4e00”和“9fa5”两边分别用”{“和“}”包起来,跑了一遍,发现真的准确了:
$str = 'php编程'; if (preg_match("/^[x{4e00}-x{9fa5}]+$/u", $str)) { echo '该字符串全部是中文'; } else { echo '该字符串不全部是中文'; }
我们先来看一段代码
$str = 'aaaaa'; $a = &$str; $str = 'zzz'; unset($str); echo $a;
这个代码一看觉得$a的值为null,但实际值为zzz
仔细看了手册后发现
当 unset 一个引用,只是断开了变量名和变量内容之间的绑定。这并不意味着变量内容被销毁了
看到这段后就不难理解了,这段代码unset掉的只是断开了str与其值间的绑定而已。
我用到的几个火狐插件
1.ColorZilla 先进的鼠标点选器,颜色选择器,页面缩放和其它有意思的东西
2.CSSViewer 查看CSS样式
3.Firebug 小小萤火虫,功能却很全,太方便了,我们这些做前端开发的人员可享福吧。有DOM查看,js调试,css调试等等一系列的工具
4.Web Developer Web Developer 插件强大的功能超乎你的想象,用于CSS网页布局开发调试只是它强大功能的一部分,对于网络程序的开发也提供了非常强大的辅助设计功能,我们不将它完全的展开探讨,我们仅针对CSS网页布局开发调试对它进行了解,有兴趣的朋友可以详细的研究一下它的强大功能。CSS工具是我们需要了解的重点,它提供了许
多功能来辅助我们查看网页
5.Fast Dial 可以像 Opera 浏览器的Speed dial 一样,让你通过点击缩略图快速访问常用的网站
6.Fasterfox 火狐忧化插件
7.FireFTP
8.FireGestures 用鼠标手势执行命令
9.Fission 在地址樯显示载入进度条
10.Flagfox 显示描述当前服务器位置的国旗
11.Forecastfox 在状态栏显示现在天气以及未来几天的天气预报
12.FoxTab 页面切换绚丽的3D效果
13.IE Tab 让Firefox也能内嵌IE用双核心
14.Screengrab 一个非常好用的截图插件 能随心所欲的截取你想要的部分和保存整个网页图片
15.SearchStatus 站火狐显示Alexa排名和PR值
16.ShowIP 显示当前网页的IP
php 不使用第三方变量和数组交换两个变量的值
今天去面试有一道题,怎样不用第三方变量和数组交换二个变量的值,在那里想了半天也没想出么样实现-_-!!,回来后查了下资料,可以用位运算中的异或运算。
下面是试例代码
<?php $a = 'str1'; $b = 'str2'; echo "交换前:\$a = {$a}; \$b = {$b};"; $b = $b ^ $a; $a = $b ^ $a; $b = $b ^ $a; echo "交换后:\$a = {$a}; \$b = {$b};"; ?>
此算法能够实现是由异或运算的特点决定的,通过异或运算能够使数据中的某些位翻转,其他位不变。这就意味着任意一个数与任意一个给定的值连续异或两次,值不变。
连续二十来天的阴雨天终于结束了,但我内心的阴雨天却来临了,我们失业了,在这个形式不太好的09年的春天。
这一切都来得太突然了,不知是因为失业的伤心还是因为分开的依依不舍,心里有一种很强的失落感。
怀念这短短三个月来和同事在一起的日子,真的很开心,这段时间好像就是一个梦,现在梦醒了。
希望我和其它同事一样早日找到新的工作
技术部全体合影

静态调用的成员一定要定义成 static (PHP5 ONLY)
贴士:PHP 5 引入了静态成员的概念,作用和 PHP 4 的函数内部静态变量一致,但前者是作为类的成员来使用。静态变量和 Ruby 的类变量(class variable)差不多,所有类的实例共享同一个静态变量。
<?php class foo { function bar() { echo 'foobar'; } } $foo = new foo; // instance way $foo->bar(); // static way foo::bar(); ?>
静态地调用非 static 成员,效率会比静态地调用 static 成员慢 50-60%。主要是因为前者会产生 E_STRICT 警告,内部也需要做转换。
使用类常量 (PHP5 ONLY)
贴士:PHP 5 新功能,类似于 C++ 的 const。
使用类常量的好处是:
- 编译时解析,没有额外开销
- 杂凑表更小,所以内部查找更快
- 类常量仅存在于特定「命名空间」,所以杂凑名更短
- 代码更干净,使除错更方便
(暂时)不要使用 require/include_once
require/include_once 每次被调用的时候都会打开目标文件!
- 如果用绝对路径的话,PHP 5.2/6.0 不存在这个问题
- 新版的 APC 缓存系统已经解决这个问题
文件 I/O 增加 => 效率降低
如果需要,可以自行检查文件是否已被 require/include。
不要调用毫无意义的函数
有对应的常量的时候,不要使用函数。
<?php php_uname('s') == PHP_OS; php_version() == PHP_VERSION; php_sapi_name() == PHP_SAPI; ?>
虽然使用不多,但是效率提升大概在 3500% 左右。
最快的 Win32 检查
<?php $is_win = DIRECTORY_SEPARATOR == '\\'; ?>
- 不用函数
- Win98/NT/2000/XP/Vista/Longhorn/Shorthorn/Whistler…通用
- 一直可用
时间问题 (PHP>5.1.0 ONLY)
你如何在你的软件中得知现在的时间?简单,「time() time() again, you ask me…」。
不过总归会调用函数,慢。
现在好了,用 $_SERVER['REQUEST_TIME'],不用调用函数,又省了。
加速 PCRE
- 对于不用保存的结果,不用 (),一律用 (?:)
这样 PHP 不用为符合的内容分配内存,省。效率提升 15% 左右。
- 能不用正则,就不用正则,在分析的时候仔细阅读手册「字符串函数」部分。有没有你漏掉的好用的函数?
例如:
strpbrk() strncasecmp() strpos()/strrpos()/stripos()/strripos()
加速 strtr
如果需要转换的全是单个字符的时候,用字符串而不是数组来做 strtr:
<?php $addr = strtr($addr, "abcd", "efgh"); // good $addr = strtr($addr, array('a' => 'e', // ... )); // bad ?>
效率提升:10 倍。
不要做无谓的替换
即使没有替换,str_replace 也会为其参数分配内存。很慢!解决办法:
- 用 strpos 先查找(非常快),看是否需要替换,如果需要,再替换
效率:
- 如果需要替换:效率几乎相等,差别在 0.1% 左右。
- 如果不需要替换:用 strpos 快 200%。
邪恶的 @ 操作符
不要滥用 @ 操作符。虽然 @ 看上去很简单,但是实际上后台有很多操作。用 @ 比起不用 @,效率差距:3 倍。
特别不要在循环中使用 @,在 5 次循环的测试中,即使是先用 error_reporting(0) 关掉错误,在循环完成后再打开,都比用 @ 快。
善用 strncmp
当需要对比「前 n 个字符」是否一样的时候,用 strncmp/strncasecmp,而不是 substr/strtolower,更不是 PCRE,更千万别提 ereg。strncmp/strncasecmp 效率最高(虽然高得不多)。
慎用 substr_compare (PHP5 ONLY)
按照上面的道理,substr_compare 应该比先 substr 再比较快咯。答案是否定的,除非:
- 无视大小写的比较
- 比较较大的字符串
不要用常量代替字符串
为什么:
- 需要查询杂凑表两次
- 需要把常量名转换为小写(进行第二次查询的时候)
- 生成 E_NOTICE 警告
- 会建立临时字符串
效率差别:700%。
不要把 count/strlen/sizeof 放到 for 循环的条件语句中
贴士:我的个人做法
<?php for ($i = 0, $max = count($array);$i < $max; ++$i); ?> 效率提升相对于: - count 50% - strlen 75% <strong>短的代码不一定快 </strong> <pre lang="php"> <?php // longest if ($a == $b) { $str .= $a; } else { $str .= $b; } // longer if ($a == $b) { $str .= $a; } $str .= $b; // short $str .= ($a == $b ? $a : $b); ?>
你觉得哪个快?
效率比较:
- longest: 4.27
- longer: 4.43
- short: 4.76
不可思议?再来一个:
<?php // original $d = dir('.'); while (($entry = $d->read()) !== false) { if ($entry == '.' || $entry == '..') { continue; } } // versus glob('./*'); // versus (include . and ..) scandir('.'); ?>
哪个快?
效率比较:
- original: 3.37
- glob: 6.28
- scandir: 3.42
- original without OO: 3.14
- SPL (PHP5): 3.95
画外音:从此也可以看出来 PHP5 的面向对象效率提高了很多,效率已经和纯函数差得不太多了。
提高 PHP 文件访问效率
需要包含其他 PHP 文件的时候,使用完整路径,或者容易转换的相对路径。
<?php include 'file.php'; // bad approach incldue './file.php'; // good include '/path/to/file.php'; // ideal ?>
物尽其用
PHP 有很多扩展和函数可用,在实现一个功能的之前,应该看看 PHP 是否有了这个功能?是否有更简单的实现?
<?php $filename = "./somepic.gif"; $handle = fopen($filename, "rb"); $contents = fread($handle, filesize($filename)); fclose($handle); // vs. much simpler file_get_contents('./somepic.gif'); ?>
关于引用的技巧
引用可以:
- 简化对复杂结构数据的访问
- 优化内存使用
<?php $a['b']['c'] = array(); // slow 2 extra hash lookups per access for ($i = 0; $i < 5; ++$i) $a['b']['c'][$i] = $i; // much faster reference based approach $ref =& $a['b']['c']; for ($i = 0; $i < 5; ++$i) $ref[$i] = $i; ?> <?php $a = 'large string'; // memory intensive approach function a($str) { return $str.'something'; } // more efficient solution function a(&$str) { $str .= 'something'; } ?>
==============================================
参考资料
http://ilia.ws
Ilia 的个人网站,Blog,他参与的开发以及出版的一些稿物链接等等。
http://ez.no
eZ components 官方网站,eZ comp 是针对 PHP5 的开源通用库,以效率为己任,Ilia 也参与了开发。
http://phparch.com
php|architect,不错的 php 出版商/培训组织。买不起或者买不到的话,网上可以下到很多经典的盗版。
http://talks.php.net
PHP 会议上的演讲合集,现在还不是很丰富,不过内容都是让人一看就容易废寝忘食的好东东,推荐早上睡眼朦胧的时候或者吃完午饭仔细研究,否则你会忘记吃饭和睡觉的!
==============================================