字符串转换为字节数组?这个问题在C#里有现成的编码函数,在VC里请问如何实现??
应用举例:
CString mystr="中国";
CString myaimstr;
我需要myaimstr="FFFFFFFF";//求“中国”的字节形式的字符串
而后又可以根据myaimstr ="FFFFFFFF"反转得到mystr ="中国";//根据字节字符串得到相应的汉字或者其它字符串
11 个解决方案
#1
CString mystr="中国";
CString myaimstr;
char *pBuffer = mystr.GetBuffer(0);
for(int i=0;i<lstrlen(mystr);i++)
{
myaimstr.Format(myaimstr+"%02X",pBuffer[i]);
}
mystr.ReleaseBuffer();
不知是不是你想要的结果,因为看不懂 "中国" 与 "FFFFFFFF"有何关系,我的理解是"中国"的ASCII码字符串
CString myaimstr;
char *pBuffer = mystr.GetBuffer(0);
for(int i=0;i<lstrlen(mystr);i++)
{
myaimstr.Format(myaimstr+"%02X",pBuffer[i]);
}
mystr.ReleaseBuffer();
不知是不是你想要的结果,因为看不懂 "中国" 与 "FFFFFFFF"有何关系,我的理解是"中国"的ASCII码字符串
#2
你哪个区的?
#3
1楼的应该是LZ要的
#4
对的,"中国"的ASCII码字符串 为“FFFFFFD6FFFFFFD0FFFFFFB9FFFFFFFA” ;
那么怎么由“FFFFFFD6FFFFFFD0FFFFFFB9FFFFFFFA”转回“中国”呢?
那么怎么由“FFFFFFD6FFFFFFD0FFFFFFB9FFFFFFFA”转回“中国”呢?
#5
还有我迷惑的是,通过程序出来,为什么“中”是“FFFFFFD6FFFFFFD0”,“国”是“FFFFFFB9FFFFFFFA”,这样一个汉字转为字节就不止2个字节了。
#6
#7
//没调试过
CString mystr = "中国";
CString myaimstr = "";
CString str;
for(int i = 0; i < mystr.GetLength(); i++)
{
str.Format("%02X", mystr.GetAt(i));
myaimstr += str;
}
long n;
for(i = 0; i < myaimstr.GetLength(); i++)
{
str = myaimstr.Mid(i*2, 2);
n = strtol(str, NULL, 16);
mystr.SetAt(i, (char)n);
}
#8
for(int i = 0; i < mystr.GetLength(); i++)
{
str.Format("%02X", (BYTE)mystr.GetAt(i)); //奇怪,GetAt返回的不是char吗?非要转成unsigned char才正常
myaimstr += str;
}
{
str.Format("%02X", (BYTE)mystr.GetAt(i)); //奇怪,GetAt返回的不是char吗?非要转成unsigned char才正常
myaimstr += str;
}
#9
//调试过的
CString mystr = "中国";
CString myaimstr = "";
CString str;
for(int i = 0; i < mystr.GetLength(); i++)
{
str.Format("%02X", (BYTE)mystr.GetAt(i));
myaimstr += str;
}
long n;
for(i = 0; i < myaimstr.GetLength()/2; i++)
{
str = myaimstr.Mid(i*2, 2);
n = strtol(str, NULL, 16);
mystr.SetAt(i, (char)n);
}
#10
for(int i = 0; i < mystr.GetLength(); i++)
{
str.Format("%02X", (BYTE)mystr.GetAt(i)); //奇怪,GetAt返回的不是char吗?非要转成unsigned char才正常
myaimstr += str;
}
这段代码对了,得到“D6D0B9FA”,两个汉字转为四个字节。
但是:
long n;
for(i = 0; i < myaimstr.GetLength(); i++)
{
str = myaimstr.Mid(i*2, 2);
n = strtol(str, NULL, 16);
mystr.SetAt(i, (char)n);
}
由“D6D0B9FA”转回“中国”有点没对
{
str.Format("%02X", (BYTE)mystr.GetAt(i)); //奇怪,GetAt返回的不是char吗?非要转成unsigned char才正常
myaimstr += str;
}
这段代码对了,得到“D6D0B9FA”,两个汉字转为四个字节。
但是:
long n;
for(i = 0; i < myaimstr.GetLength(); i++)
{
str = myaimstr.Mid(i*2, 2);
n = strtol(str, NULL, 16);
mystr.SetAt(i, (char)n);
}
由“D6D0B9FA”转回“中国”有点没对
#11
long n;
char p[5];
for(int i = 0; i < myaimstr.GetLength()/2; i++)
{
str = myaimstr.Mid(i*2, 2);
n = strtol(str, NULL, 16);
p[i]= (char)n;
}
p[5]='\0';
SetDlgItemText(IDC_EDIT2,p);
这样终于对了,谢谢,揭贴
char p[5];
for(int i = 0; i < myaimstr.GetLength()/2; i++)
{
str = myaimstr.Mid(i*2, 2);
n = strtol(str, NULL, 16);
p[i]= (char)n;
}
p[5]='\0';
SetDlgItemText(IDC_EDIT2,p);
这样终于对了,谢谢,揭贴
#1
CString mystr="中国";
CString myaimstr;
char *pBuffer = mystr.GetBuffer(0);
for(int i=0;i<lstrlen(mystr);i++)
{
myaimstr.Format(myaimstr+"%02X",pBuffer[i]);
}
mystr.ReleaseBuffer();
不知是不是你想要的结果,因为看不懂 "中国" 与 "FFFFFFFF"有何关系,我的理解是"中国"的ASCII码字符串
CString myaimstr;
char *pBuffer = mystr.GetBuffer(0);
for(int i=0;i<lstrlen(mystr);i++)
{
myaimstr.Format(myaimstr+"%02X",pBuffer[i]);
}
mystr.ReleaseBuffer();
不知是不是你想要的结果,因为看不懂 "中国" 与 "FFFFFFFF"有何关系,我的理解是"中国"的ASCII码字符串
#2
你哪个区的?
#3
1楼的应该是LZ要的
#4
对的,"中国"的ASCII码字符串 为“FFFFFFD6FFFFFFD0FFFFFFB9FFFFFFFA” ;
那么怎么由“FFFFFFD6FFFFFFD0FFFFFFB9FFFFFFFA”转回“中国”呢?
那么怎么由“FFFFFFD6FFFFFFD0FFFFFFB9FFFFFFFA”转回“中国”呢?
#5
还有我迷惑的是,通过程序出来,为什么“中”是“FFFFFFD6FFFFFFD0”,“国”是“FFFFFFB9FFFFFFFA”,这样一个汉字转为字节就不止2个字节了。
#6
#7
//没调试过
CString mystr = "中国";
CString myaimstr = "";
CString str;
for(int i = 0; i < mystr.GetLength(); i++)
{
str.Format("%02X", mystr.GetAt(i));
myaimstr += str;
}
long n;
for(i = 0; i < myaimstr.GetLength(); i++)
{
str = myaimstr.Mid(i*2, 2);
n = strtol(str, NULL, 16);
mystr.SetAt(i, (char)n);
}
#8
for(int i = 0; i < mystr.GetLength(); i++)
{
str.Format("%02X", (BYTE)mystr.GetAt(i)); //奇怪,GetAt返回的不是char吗?非要转成unsigned char才正常
myaimstr += str;
}
{
str.Format("%02X", (BYTE)mystr.GetAt(i)); //奇怪,GetAt返回的不是char吗?非要转成unsigned char才正常
myaimstr += str;
}
#9
//调试过的
CString mystr = "中国";
CString myaimstr = "";
CString str;
for(int i = 0; i < mystr.GetLength(); i++)
{
str.Format("%02X", (BYTE)mystr.GetAt(i));
myaimstr += str;
}
long n;
for(i = 0; i < myaimstr.GetLength()/2; i++)
{
str = myaimstr.Mid(i*2, 2);
n = strtol(str, NULL, 16);
mystr.SetAt(i, (char)n);
}
#10
for(int i = 0; i < mystr.GetLength(); i++)
{
str.Format("%02X", (BYTE)mystr.GetAt(i)); //奇怪,GetAt返回的不是char吗?非要转成unsigned char才正常
myaimstr += str;
}
这段代码对了,得到“D6D0B9FA”,两个汉字转为四个字节。
但是:
long n;
for(i = 0; i < myaimstr.GetLength(); i++)
{
str = myaimstr.Mid(i*2, 2);
n = strtol(str, NULL, 16);
mystr.SetAt(i, (char)n);
}
由“D6D0B9FA”转回“中国”有点没对
{
str.Format("%02X", (BYTE)mystr.GetAt(i)); //奇怪,GetAt返回的不是char吗?非要转成unsigned char才正常
myaimstr += str;
}
这段代码对了,得到“D6D0B9FA”,两个汉字转为四个字节。
但是:
long n;
for(i = 0; i < myaimstr.GetLength(); i++)
{
str = myaimstr.Mid(i*2, 2);
n = strtol(str, NULL, 16);
mystr.SetAt(i, (char)n);
}
由“D6D0B9FA”转回“中国”有点没对
#11
long n;
char p[5];
for(int i = 0; i < myaimstr.GetLength()/2; i++)
{
str = myaimstr.Mid(i*2, 2);
n = strtol(str, NULL, 16);
p[i]= (char)n;
}
p[5]='\0';
SetDlgItemText(IDC_EDIT2,p);
这样终于对了,谢谢,揭贴
char p[5];
for(int i = 0; i < myaimstr.GetLength()/2; i++)
{
str = myaimstr.Mid(i*2, 2);
n = strtol(str, NULL, 16);
p[i]= (char)n;
}
p[5]='\0';
SetDlgItemText(IDC_EDIT2,p);
这样终于对了,谢谢,揭贴