对于一般的c++程序字符串而言,都是以null结束的,但是如果我们使用com传递字符串可能遇到一些字符串并不是以null为结束标志的,这个就是说在字符串中可能包含null字符,但是并不是结束标志,我们使用com的时候一般用BSTR传递参数,这个BSTR按我的理解就是宽字符,但是宽字符头部有一个4字节表示长度的标志,这样我们就能判定我们要传递的字符串是多长的,不会因为null结束标志而使字符串传输错误。使用BSTR,要记得下面几个函数
BSTR SysAllocString(
OLECHAR FAR* sz
);
BSTR SysAllocStringByteLen(
char FAR* psz,
unsigned int len
);
BSTR SysAllocStringLen(
OLECHAR FAR* pch,
unsigned int cch
);
我们如何将一个包含null结束串的字符串赋值给BSTR呢,就要用到SysAllocStringByteLen这个函数,第一参数是要传递的包含null串的地址,第二个是这个串的长度,例如:
char a[5]={0x03,0x04,0x00,0x05};
BSTR b=SysAllocStringByteLen(a,5);
上面虽然解决了给bstr赋值的问题,但是,我们会发现,传入我们的com是ansi字符,大家都知道,com的参数都是unicode字符的,如果你传递ansi字符,那么看到的就是乱码,如何解决这个问题呢,可以这样:
char a[5]={0x03,0x04,0x00,0x05};
wchar_t *tempz=new wchar_t[5+1];
MultiByteToWideChar(CP_ACP,0,a,5,tempz,5);
b=SysAllocStringLen((unsigned short*)tempz,5);
delete []tempz;
这样的意思就是先将这个串unicode化,然后再使用SysAllocStringByteLen,因为SysAllocStringByteLen并不会将原始串unicode化,但是如果我们使用CString::AllocSysString这个函数,他是帮我们unicode的,但是这个函数不能传输包含null的串。
上面是一种解决方法,如果有更好的解决方法大家可以再告诉我。