PHP学习笔记--不同编码占据不同的字节

gbk中 1个汉字=2个字节

utf-8中 1个汉字=3个字节

 

补充: 在php中 substr函数,是按照字节的截取的。所以在截取字符串时要考虑要中文编码和英文字符,因为他们所占字节不一样。如上所说。 在遇到中英混编时,substr就腌了。 所以在php5中 iconv_substr() 函数出现了,

iconv_substr() 函数是基于字节的位移来计算的,也就是按位计算。 

如:

echo iconv_substr('我是123哈哈!',0,6,'UTF-8');
//显示:  我是123哈

 

还有 mb_substr() 函数和 mb_strcut()  注: mb_substr() 是按照字来算的。和iconv_substr() 差不多。而mb_substr()  是按照字节来分的。 但是不会像substr()函数一样,截取半个中文字符时,会出现乱码!

需要注意的是这两个函数使用都需要在php.ini 中把 php_mbstring.dll 功能给打开才能用

以上的函数,详细用法请自行查询PHP手册!

posted @ 2013-05-23 16:55  clouds008  阅读(167)  评论(0编辑  收藏  举报