C语言宏定义中L##"STRING"

瘦欲@ 提交于 2019-11-25 20:43:43

在USB字符串描述符中
在这里插入图片描述
bLength为描述符长度,bDeorType为描述符类型,字符编码统一采用UNICODE编码,UNICODE采用两个字节字节表示一个字符,如果是英语字符的话,那就很简单了,直接在ASCII码前面补上一个为0x00的字节数据就组成UNICODE编码了。

但是在C编译器中,
#define WIDE_STRING(string) _WIDE_STRING(string)
#define _WIDE_STRING(string) L##string

通过WIDE_STRING(“string”)配合wchar可以将“string”直接变成UNICODE。

#define WIDE_STRING(string) _WIDE_STRING(string)
#define _WIDE_STRING(string) L##string

#define USBD_STRING_DESC(string)
(uint8_t *)&(struct {
uint8_t _len;
uint8_t _type;
wchar_t _data[sizeof(string)];
}) {
sizeof(WIDE_STRING(string)) + 2U - 2U,
USB_DESCTYPE_STRING,
WIDE_STRING(string)
}

L"string"表示Unicode字符串,是const WCHAR *类型,一个字符有16位。而_T(“string”)的含义和_UNICODE宏定义有关,如果_UNICODE定义,则_T(“string”)和L"string"一样,否则_T(“string”)是普通字符串。

char buff[] = “string”;
WCHAR buff[]=L"string"

同时注意,在gcc中,wchar_t可以选择编译成2字节和4字节,编译选项为:-fshort-wchar

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!