VC里字符串转字节数组

时间:2023-01-10 15:36:58
请问:VC里有如C#里的这类函数吗?System.Text.Encoding.Asscii.GetString(byte[]);

字符串转换为字节数组?这个问题在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码字符串

#2


你哪个区的?

#3


1楼的应该是LZ要的

#4


对的,"中国"的ASCII码字符串 为“FFFFFFD6FFFFFFD0FFFFFFB9FFFFFFFA” ;
那么怎么由“FFFFFFD6FFFFFFD0FFFFFFB9FFFFFFFA”转回“中国”呢?

#5


还有我迷惑的是,通过程序出来,为什么“中”是“FFFFFFD6FFFFFFD0”,“国”是“FFFFFFB9FFFFFFFA”,这样一个汉字转为字节就不止2个字节了。

#6


该回复于2009-04-01 10:28:39被版主删除

#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;
}

#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”转回“中国”有点没对

#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);

这样终于对了,谢谢,揭贴

#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码字符串

#2


你哪个区的?

#3


1楼的应该是LZ要的

#4


对的,"中国"的ASCII码字符串 为“FFFFFFD6FFFFFFD0FFFFFFB9FFFFFFFA” ;
那么怎么由“FFFFFFD6FFFFFFD0FFFFFFB9FFFFFFFA”转回“中国”呢?

#5


还有我迷惑的是,通过程序出来,为什么“中”是“FFFFFFD6FFFFFFD0”,“国”是“FFFFFFB9FFFFFFFA”,这样一个汉字转为字节就不止2个字节了。

#6


该回复于2009-04-01 10:28:39被版主删除

#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;
}

#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”转回“中国”有点没对

#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);

这样终于对了,谢谢,揭贴