请教前辈 S1E22 动动第一题答题
本帖最后由 wow7jiao 于 2017-3-15 09:41 编辑#include <stdio.h>
int main()
{
char str[] = "中";
int length, i;
length = sizeof(str) / sizeof(str);
printf("length of str: %d\n", length);
for (i = 0; i < length; i++)
{
printf("str[%d] = %d\n", i, str);
}
return 0;
}
鱼老师发的图片一个中文是占4个字节,下面的文字部分又说是一个中文是3个字节.这是为什么 很简单,在Linux里一个中文占三个字节没错,但是length of str:后面输出的是'中'和'\0'加起来的长度,所以是四个字节,这个输出会把结束符也算作一个字符,就变成四个字节了 本帖最后由 qwe1231069 于 2017-3-14 23:46 编辑
中文用unicode编码,占2的16次方位也就是两个字节。
ASCII编码是2的8次方,一个字节。应该是这样
UTF-8
UTF-16
UTF-32好多编码方式,好吧我蒙了,我不会。只是打酱油的
{:10_302:}
页:
[1]