时间:2021-07-01 10:21:17 帮助过:1人阅读
chr($i)
可以顺利的打印出ASCII,但是,当$i>=19968(汉字的Unicode的起始值4E00的十进制)后,发现没法打印出汉字。
虽然有其他方法,如:
//代码2
$character = html_entity_decode('一', ENT_QUOTES, 'UTF-8');
但为什么代码1没法打印出汉字?
使用chr($i)
可以顺利的打印出ASCII,但是,当$i>=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
代码如下
PHP_FUNCTION(chr)
{
long c;
char temp[2];
if (ZEND_NUM_ARGS() != 1) {
WRONG_PARAM_COUNT;
}
if (zend_parse_parameters_ex(ZEND_PARSE_PARAMS_QUIET, ZEND_NUM_ARGS() TSRMLS_CC, "l", &c) == FAILURE) {
c = 0;
}
temp[0] = (char)c;
temp[1] = '\0';
RETURN_STRINGL(temp, 1, 1);
}
可以看到的是,就是C语言的字符强制转换。