1. 字符编码的起源和解决方案
为什么会谈起字符编码呢?这个事情的根源是英文字符使用的ASCII编码无法表示世界上其他语言的字符.所以就会导致ASCII之外的字符显示的时候的乱码问题.
为了解决字符显示乱码的问题,不同国家和地区针对自己使用的字符进行了编码,但每种编码都无法涵盖所有字符,所以Unicode编码诞生了.Unicode的诞生是为了解决所有字符使用统一的一套编码,这样就统一了字符显示.
但是实际中,各个系统都有自己的编码,以中文为例,Window系统下编辑的文本有多种编码方式,如GBK,要显示在Unicode编码系统下,就需要将中文的编码转化为Unicode,同样,如果Unicode编码需要在GBK编码系统中显示也需要转化.所以就形成了一种约定俗成的方案,Unicode作为媒介,其他编码先转为Unicode编码,然后由Unicode再转为目标编码.这样,其他编码只需要提供到Unicode的转化器和从Unicode转化回来的转化器就可以,避免任意语言之间的转化器.具体的框架如下:
编码器负责将自己的编码格式转为Unicode编码模式,解码器是从Unicode编码转化为自己的编码格式.
2. SyberOS字符编码解决方案
SyberOS操作系统使用开源框架Qt作为应用开发框架,其使用Unicode编码,所以不存在字符编码的问题.但是存在其他字符编码的问题,我们需要把不同的编码转为Unicode或者从Unicode转为其他编码.
Qt为处理字符编码针对字节流和字符串提供了不同的类QByteArray和QString.字节流是一个个字节组成的,字符串是一个个unic