“使用多字节字符集”和“使用Unicode字符集”下的字符串的长度问题

本文介绍了在Unicode和非Unicode环境下,lstrlen、wcslen以及strlen函数的使用和区别。lstrlen会根据环境返回字符个数,wcslen返回宽字符个数,strlen返回ANSI字符个数。同时,通过示例展示了strlen、wcslen与sizeof在计算字符串长度时的不同,strlen返回字节数,wcslen返回字符数,sizeof返回字节数包括''。

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

#ifdef UNICODE

#define lstrlen  lstrlenW

#else

#define lstrlen  lstrlenA

#endif // !UNICODE

在Unicode下,lstrlen等同lstrlenW,在非Unicode下等同lstrlenA。

在Unicode下,lstrlen等同wcslen在非Unicode下等同strlen

一个是C的标准函数,一个是WinAPI函数。


小结:
1、lstrlen依据参数的类型,返回字符串中字符的个数(如果操作系统定义了UINCODE,则表示宽字符,如果未定义,则表示ANSI字符)
2、wcslen返回宽字符的个数
3、strlen返回ANSI字符的个数




再讨论strlen、wcslen与sizeof的区别。


在非Unicode下,TCHAR = char,_tcslen = strlen
在Unicode下,TCHAR = wchar_t , _tcslen = wcslen


TCHAR szGBR[] = _T("abcd");
TCHAR szCHN[] = _T("民主科学");

int iStrLenGBR = lstrlen(szGBR);
int iStrLenCHN = lstrlen(szCHN);

int iSizeofGBR = sizeof(szGBR);
int iSizeofCHN = sizeof(szCHN);


在非Unicode下:

iStrLenGBR = strlen(szGBR);
iStrLenCHN = strlen(szCHN);

iStrLenGBR = 4;
iStrLenCHN = 8;

iSizeofGBR = 5;
iSizeofCHN = 9;


在Unicode下:

iStrLenGBR =wcslen(szGBR);
iStrLenCHN =wcslen(szCHN);

iStrLenGBR = 4;
iStrLenCHN = 4;

iSizeofGBR = 10;
iSizeofCHN = 10;


由此可见:

strlen返回的是字节数(对中英文不一致,中文占两个字节,不包括'\0');

wcslen返回的是字符数(对中英文一致);

sizeof返回的是字节数(包含'\0',而'\0'在Unicode下也是占两个字节的)。





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值