在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
本文详细解析了USB字符串描述符的结构,包括bLength和bDescriptorType字段的作用,以及如何在C语言中使用宏定义实现字符串到UNICODE编码的转换。探讨了gcc编译器下wchar_t类型的编译选项。
296

被折叠的 条评论
为什么被折叠?



