从cstring转为char *后,strlen结果始终为1

C++语言 码拜 9年前 (2016-05-09) 1600次浏览
测试环境已设置为unicode编码。
测试代码如下:

int _tmain(int argc, _TCHAR* argv[])
{
	CString str = "test";
	char *p = (LPSTR)(LPCTSTR)str;
	cout<<"cout strlen(p): "<<strlen(p)<<endl;
	cin.get();
	return 0;
}

最终,strlen(p)输出的结果为1。
用debug追踪可知,经过强制转换后,p所指向的单元内容的分布为:t,0,e,0,s,0,t,0
大致是strlen检测到第1个0的时候就认为 char *结束了,于是就输出结果为1。
在这种情况(unicode+强制转换)下,应该使用哪个函数来得到char *的正确的长度?谢谢!
注:本人知道利用『曲线救国』的办法是可以的:str.GetLength()*2+2,但可不可以直接对p操作获得长度呢?

解决方案

8

unicode 版本的strlen

4

1)str.GetLength()*2
2)用wchar_t 版本 wcslen 可能要加下划线
3)自定义函数
strlen 本身实现不复杂
wcslen 也是

4

CString str = “test”;能编译通过?
宽字节的C风格字符串有本人的一套处理函数,不仅仅是字符串长度wcslen()

4

int _tmain(int argc, _TCHAR* argv[])
{
    CString str = "test";
    LPCTSTR p = (LPCTSTR)str;
 
    cout << "cout strlen(p): " << lstrlen(p) << endl;
    cout << "cout strlen(p): " << str.GetLength() << endl;
 
    cin.get();
    return 0;
}

4

	const size_t strsize = (m_filepath.GetLength() + 1) * 2; // 宽字符的长度;
	char * pstr = new char[strsize]; //分配空间;
	size_t sz = 0;
	wcstombs_s(&sz, pstr, strsize, m_filepath, _TRUNCATE);

试试这个,代码中m_filepath是CString,最终的到的pstr是char*,sz就是转化后的字符数


CodeBye 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权 , 转载请注明从cstring转为char *后,strlen结果始终为1
喜欢 (0)
[1034331897@qq.com]
分享 (0)