深入研究utf8编码和ascii编码

本文详细解析了UTF-8编码与ASCII编码的区别,并通过实验验证了UTF-8编码如何将汉字转换为3个字节的编码。实验通过编写代码读取包含汉字的文件,展示了汉字在UTF-8编码下的具体表示形式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.ASCII编码

ASCII编码是最简单的编码,只能用于英文编码,一个字节就是一个字符编码,如:

在Linux下面,一个test.txt文件的内容为:

abc

123

对应的ASCII编码为:

97 98 99 10

49 50 51 10

在linux中,行尾结束符为 ASCII码的10(10进制数哦)

2.UTF8编码

UTF8编码是一个复杂的问题。

UTF-8 编码字符理论上可以最多到 6个字节长,但目前全世界的所有文字和符号种类加起来也只要编到 4个字节长就够了。UTF-8 是以 8位(即 1个字节)为单元对原始码进行编码(注意一 点:这里所讲的原始码都是指Unicode码),并规定:多字节码(2个字 节以上才称为多字节)以转换后第1个字节起头的连续“1”的数目(这 些连续“1”称为标记位),表示转换成几个字节:“110”连续两个 “1”,表示转换结果为2个字节,“1110”表示3个字节,而“11110” 则表示4个字节……跟随在标记位之后的“0”,其作用是分隔标记位和 字符码位。第2~第4个字节的起头两个位固定设置为“10”,也作为标 记,剩下的6个位才做为字符码位使用。
   这样,2字节UTF-8码剩下11个字符码位,可用以转换0080~07FF的 原始字符码,3字节剩下16个字符码位,可用以转换0800~FFFF的原始字 符码,由此类推。编码方式的模板如下:

 原始码(16进制) UTF-8编码(二进制)
 --------------------------------------------
 0000 - 007F 0xxxxxxx
 0080 - 07FF 110xxxxx 10xxxxxx
 0800 - FFFF 1110xxxx 10xxxxxx 10xxxxxx
 ……
 --------------------------------------------

汉字的 Unicode编码范围为0800-FFFF,所以被编为 3个字节的UTF-8码。例如“汉”字的Unicode编码是6C49,6C49在0800-FFFF之间,所以 要用3个字节的模板:1110wwww 10xxxxyy 10yyzzzz。

6 C 4 9
 0110 1100 0100 1001
 wwww xxxx yyyy zzzz
 wwww xxxxyy yyzzzz
 1110wwww 10xxxxyy 10yyzzzz。
 11100110 10110001 10001001

 E 6 B 1 8 9

“汉”字的UTF-8编码是E6 B1 89

参考博客:http://blog.youkuaiyun.com/lazyclough/article/details/7691911

做实验验证以上分析:

编写test.txt,输入以下内容:

汉字测试

输入之后保存

在Linux下,编写以下代码:

#include<stdio.h>
#include<string.h>
char filename[100];
int main()
{
    //input
    strcpy( filename , "/home/Desktop/test.txt" );
    // open the file
    FILE * fp =fopen(filename,"r");
    if( NULL == fp )
    {
        printf("Failed to open the file!\n");
        return 0;
    }
    char tmp[100] ={'\0'};
    fgets( tmp , 100 , fp );    //读取文件的第一行所有字符
    //output
    printf("The length :%d\n",strlen(tmp) );
    printf("All chars are:\n");
    int len =strlen(tmp);
    for(int i=0;i<len;i++)
        printf("%d  ",tmp[i]);
    return 0;
}

运行结果截图:


修改test.txt的内容:

汉字测试abc

然后保存以下

运行程序,结果截图:


实验成功地证明了上述的理论,取得了满意的结果!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值