热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

C++字符字符串处理及字符集编码方案

本文介绍了C++中字符字符串处理的问题,并详细解释了字符集编码方案,包括UNICODE、Windowsapps采用的UTF-16编码、ASCII、SBCS和DBCS编码方案。同时说明了ANSIC标准和Windows中的字符/字符串数据类型实现。文章还提到了在编译时需要定义UNICODE宏以支持unicode编码,否则将使用windowscodepage编译。最后,给出了相关的头文件和数据类型定义。



cpp 调库总遇到字符处理的问题,开坑慢填。


  • 字符集


    • UNICOUDE
      Windows apps 采用 UTF-16 实现
      大多数字符 2-byte,补充集合用 a pair of 2-byte
    • Windows / OEM Code Page
      ASCII 基础上设计各国互不兼容的编码方案,ASCII只用了1个字节的前127个编码
      主要分为 SBCS 和 DBCS (中日韩)
      美国国家标准学会(American National Standards Institute) 收集整合,为每种方案设计 code page identifier。
  • ANSI C 标准 和 Windows 三套字符/字符串数据类型实现
    需要说明的是,ANSI C 标准并没有具体规定基本类型应占字节数,具体占位和平台 CPU + OS + Compiler 有关


    • generic
      编译时在 #include 前定义 UNICODE 宏,否则以windows code page编译
    • 仅用于 unicode
    • 仅用于 windows code pages

    // 头文件 Winnt.h
    // Generic types TCHAR LPTSTR LPTCH
    #ifdef UNICODE
    typedef wchar_t TCHAR; // char 是 ANSI C data type
    #else
    typedef unsigned char TCHAR;
    #endif
    typedef TCHAR *LPTSTR, *LPTCH;
    // 8-bit character specific 去掉表示类型的T
    typedef unsigned char CHAR; // char 是 ANSI C data type
    typedef CHAR *LPSTR, *LPCH;
    // Unicode specific (wide characters) 表示类型的T换成宽字符W
    typedef unsigned wchar_t WCHAR;
    typedef WCHAR *LPWSTR, *LPWCH;

  • Windows API 三套处理字符/字符串的函数
    generic versionwindow code page version 用 “A” 标识、Unicode version 用 “W” 标识
    主要看 Standard C runtime library 中的字符处理函数


    • wcs/_wcs
      Unicode版,处理 wchar_t 类型
    • str
      code page版,处理 char 类型
    • _mbs
      DBCS版,处理中日韩等字符
    • _tcs
      generic版,处理 TCHAR 类型

    // to use the generic functions and compile for Unicode.
    #define _UNICODE
    #include
    #include

    需要说明的是,带下划线的 _UNICODE 用于standard C library,而不带下划线 UNICODE 用于Microsoft windows runtimes

  • 相互转换
    本质只有两种字符类型转换 MultiByteToWideCharWideCharToMultiByte

  • 字符串处理 STL 中的
    指路 cppreference/string 支持三种 general types of strings


    • std::basic_string - a templated class designed to manipulate strings of any character type.
    • std::basic_string_view(C++17) - a lightweight non-owning read-only view into a subsequence of a string.
    • Null-terminated strings - arrays of characters terminated by a special null character.
      在这里插入图片描述
      basic_string 的衍生最常使用
      Null-terminate string 在字符串处理函数如 _tcstok 等经常使用,本质可以看作字符指针


推荐阅读
  • 尽管我们尽最大努力,任何软件开发过程中都难免会出现缺陷。为了更有效地提升对支持部门的协助与支撑,本文探讨了多种策略和最佳实践,旨在通过改进沟通、增强培训和支持流程来减少这些缺陷的影响,并提高整体服务质量和客户满意度。 ... [详细]
  • 本文探讨了资源访问的学习路径与方法,旨在帮助学习者更高效地获取和利用各类资源。通过分析不同资源的特点和应用场景,提出了多种实用的学习策略和技术手段,为学习者提供了系统的指导和建议。 ... [详细]
  • NOIP2000的单词接龙问题与常见的成语接龙游戏有异曲同工之妙。题目要求在给定的一组单词中,从指定的起始字母开始,构建最长的“单词链”。每个单词在链中最多可出现两次。本文将详细解析该题目的解法,并分享学习过程中的心得体会。 ... [详细]
  • 本文详细介绍了在CodeUp平台中实现大数进制转换的技术方法。具体而言,该问题要求将一个最多包含30位数字的十进制非负整数转换为二进制表示。输入数据包含多行,每行包含一个不超过30位的十进制非负整数。通过高效的算法设计,确保了大数转换的准确性和性能。 ... [详细]
  • 数字图书馆近期展出了一批精选的Linux经典著作,这些书籍虽然部分较为陈旧,但依然具有重要的参考价值。如需转载相关内容,请务必注明来源:小文论坛(http://www.xiaowenbbs.com)。 ... [详细]
  • 第六章:枚举类型与switch结构的应用分析
    第六章深入探讨了枚举类型与 `switch` 结构在编程中的应用。枚举类型(`enum`)是一种将一组相关常量组织在一起的数据类型,广泛存在于多种编程语言中。例如,在 Cocoa 框架中,处理文本对齐时常用 `NSTextAlignment` 枚举来表示不同的对齐方式。通过结合 `switch` 结构,可以更清晰、高效地实现基于枚举值的逻辑分支,提高代码的可读性和维护性。 ... [详细]
  • 本文介绍了如何在iOS平台上使用GLSL着色器将YV12格式的视频帧数据转换为RGB格式,并展示了转换后的图像效果。通过详细的技术实现步骤和代码示例,读者可以轻松掌握这一过程,适用于需要进行视频处理的应用开发。 ... [详细]
  • 本文探讨了 Java 中 Pair 类的历史与现状。虽然 Java 标准库中没有内置的 Pair 类,但社区和第三方库提供了多种实现方式,如 Apache Commons 的 Pair 类和 JavaFX 的 javafx.util.Pair 类。这些实现为需要处理成对数据的开发者提供了便利。此外,文章还讨论了为何标准库未包含 Pair 类的原因,以及在现代 Java 开发中使用 Pair 类的最佳实践。 ... [详细]
  • 蓝桥杯物联网基础教程:通过GPIO输入控制LED5的点亮与熄灭
    本教程详细介绍了如何利用STM32的GPIO接口通过输入信号控制LED5的点亮与熄灭。内容涵盖GPIO的基本配置、按键检测及LED驱动方法,适合具有STM32基础的读者学习和实践。 ... [详细]
  • 寒假作业解析:第三周 2月12日 第7题
    尽快完成之前的练习任务!每日一练2.1 Problem A Laurenty and Shop 的题目要求是选择两条不同的路线以最小化总的等待时间。简要分析:通过对比不同路线的等待时间,可以找到最优解。此问题可以通过动态规划或贪心算法来解决,具体取决于路线的复杂性和约束条件。 ... [详细]
  • 蓝桥杯算法实战:节点选取策略优化分析
    本文针对蓝桥杯算法竞赛中的节点选取策略进行了深入分析与优化。通过对比不同节点选择方法的效果,提出了基于贪心算法和动态规划的综合优化方案,旨在提高算法效率和准确性。实验结果表明,该优化策略在处理大规模数据集时表现出色,显著提升了算法性能。 ... [详细]
  • 解题心得:UVA1339(逻辑分析与字符串处理+排序算法)
    解题心得:UVA1339(逻辑分析与字符串处理+排序算法) ... [详细]
  • 在 Linux 环境下,多线程编程是实现高效并发处理的重要技术。本文通过具体的实战案例,详细分析了多线程编程的关键技术和常见问题。文章首先介绍了多线程的基本概念和创建方法,然后通过实例代码展示了如何使用 pthreads 库进行线程同步和通信。此外,还探讨了多线程程序中的性能优化技巧和调试方法,为开发者提供了宝贵的实践经验。 ... [详细]
  • 在Linux系统中,通过使用`read`和`write`函数可以实现文件的高效复制操作。`open`函数用于打开或创建文件,其返回值为文件描述符,成功时返回一个有效的文件描述符,失败时返回-1。`path`参数指定了要操作的文件路径,而`oflag`参数则定义了文件的打开模式和属性。此外,为了确保数据的完整性和一致性,还需要合理处理文件读取和写入过程中的错误和异常情况。 ... [详细]
  • 深入解析 Android 中 EditText 的 getLayoutParams 方法及其代码应用实例 ... [详细]
author-avatar
Angels萱萱
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有