ANSI和UNICODE

本文详细解析了Windows系统中ANSI与UNICODE字符集的使用场景及区别,深入介绍了MFC中各种字符串类型如LPSTR、LPCSTR、LPTSTR等的含义与应用,并解释了_T与L宏的作用。

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

因为Windows使用两种字符集ANSI和UNICODE,前者就是通常使用的单字节方式,但这种方式处理象中文这样的双字节字符不方便,容易出现半个汉字的情况。
而后者是双字节方式,方便处理双字节字符。Windows NT的所有与字符有关的函数都提供两种方式的版本,而Windows 9x只支持ANSI方式。
  如果你编译一个程序为ANSI方式,_T实际不起任何作用,编译器会把_T(“Hello”)以ANSI方式保存;而如果编译一个程序为UNICODE方式,则编译器会把_T(“Hello”)字符串以UNICODE方式保存。
_T和L的区别在于,L不管你是以什么方式编译,一律以UNICODE方式保存。
  LPSTR:32bit指针指向一个字符串,每个字符占1字节
  LPCSTR:32-bit指针指向一个常字符串,每个字符占1字节
  LPCTSTR:32-bit指针指向一个常字符串,每字符可能占1字节或2字节,取决于Unicode是否定义
  LPTSTR:32-bit指针每字符可能占1字节或2字节,取决于Unicode是否定义
  L是表示字符串资源为Unicode的。

MFC中CString和LPSTR是可以通用
CString str=_T(“TestStr”)

wchar_t w1= L’中’; //Unicode 编码 ,宽字符字符串前面要加L

LPSTR = char*
LPCSTR = const char*
LPTSTR:
如果定义了UNICODE宏,那么LPTSTR = wchar_t否则LPTSTR = char
告诉你方法,
"LP"前缀是历史遗留的,在Win32下就是 P ,代表指针的含义。
"C"代表const
"T"的含义就是如果定义了UNICODE,它就是宽字符版本,否则就是Ansi版本。
完整定义如下:

### MySQL ODBC 驱动中的 ANSI Unicode 版本区别 在讨论 MySQL ODBC 驱动程序时,ANSI Unicode 是指字符编码的不同处理方式。ODBC (Open Database Connectivity) 接口允许应用程序连接到数据库管理系统。 #### 字符集支持差异 - **ANSI版本**: 使用单字节字符集(SBCS),通常适用于ASCII码范围内的数据传输。对于多语言环境下的应用开发来说,这种模式可能无法满足需求[^1]。 - **Unicode版本**: 支持双字节或多字节字符集(MBCS), 如UTF-8 或 UTF-16 编码标准。这使得能够正确存储并检索全球各种文字系统的信息,包括但不限于中文、日文其他复杂脚本的语言. #### 性能考量 由于每个字符占用的空间不同,在性能方面也会有所体现: - 对于仅限于基本拉丁字母的应用场景下,ANSI 可能会提供更快的数据交换速度因为其更简单的内部表示形式; - 当涉及到国际化软件产品或是需要处理多种自然语言的情况,则应优先考虑采用Unicode版以确保兼容性准确性; ```cpp // 示例代码展示如何设置 DSN 的 CharacterSet 参数来指定使用的字符集类型 SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &hEnv); SQLSetEnvAttr(hEnv, SQL_ATTR_ODBC_VERSION, (void*)SQL_OV_ODBC3, 0); SQLAllocHandle(SQL_HANDLE_DBC, hEnv, &hDbc); // 设置为 ANSI char ansiDSN[] = "Driver={MySQL ODBC Driver}; Server=localhost; Database=testdb; User=root; Password=pass;"; SQLDriverConnect(hDbc, NULL, (SQLCHAR*)ansiDSN, SQL_NTS, retConnStr, sizeof(retConnStr), NULL, SQL_DRIVER_NOPROMPT); // 设置为 Unicode wchar_t unicodeDSN[] = L"Driver={MySQL ODBC Driver}; Server=localhost; Database=testdb; User=root; Password=pass; CharacterSet=utf8mb4;"; SQLDriverConnectW(hDbc, NULL, (SQLWCHAR*)unicodeDSN, SQL_NTS, wretConnStr, sizeof(wretConnStr)/sizeof(wchar_t)-1, NULL, SQL_DRIVER_NOPROMPT); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值