如果你对 UTF-8 非常了解,就更没必要这样做。找一个提供了 UTF-8 文本处理功能并且可以跨平台运行的 C 库来做这件事吧!下面的这段文本是 UTF-8 编码的:我需要在 C 程序中读入这些文本。为了模拟程序读到 '@' 字符这一时刻,我需要用一个 char * 类型的指针对 demo_text 字符串中的 '@' 字符进行定位。'@' 字符在 demo_text 的末尾。我需要一个偏移距离,而这个偏移距离就是 demo_text 字串在 UTF-8 编码层次上的长度,通过这个偏移距离,我可以从 demo_text 字符串的基地址跳到 '@' 字符的基地址。g_utf8_strlen 的原型如下:g_utf8_strlen 第二个参数 max 的设定规则如下:

关于在C程序中处理UTF-8文本的方法详解

关于在C程序中处理UTF-8文本的方法详解

关于在C程序中处理UTF-8文本的方法详解

关于在C程序中处理UTF-8文本的方法详解

关于在C程序中处理UTF-8文本的方法详解

关于在C程序中处理UTF-8文本的方法详解

关于在C程序中处理UTF-8文本的方法详解