使用chr($i)
可以顺利的打印出ASCII,但是,当$i>=19968(汉字的Unicode的起始值4E00的十进制)后,发现没法打印出汉字。
如:
<?php
//代码1
header('Content-Type: text/html; charset=utf-8');
echo chr(19968);//汉字一的Unicode值:4E00
?>
虽然有其他方法,如:
//代码2
$character = html_entity_decode('一', ENT_QUOTES, 'UTF-8');
但为什么代码1没法打印出汉字?
ASCII根本就不包含汉字,
包含汉字的是GB2312-80,GBK,Big5,unicode
汉字是多字节,你用ord就会发现,只会返还汉字的首字节。
其实chr函数的源代码就在 /ext/standard/string.c
代码如下
{
long c;
char temp[2];
}
可以看到的是,就是C语言的字符强制转换。