请教字节流里 c++的 TCHAR 怎么转成 go 的 string 啊?

2019-10-08 11:48:15 +08:00
 morty961
和别人对接项目,用 websocket 传输数据,对方是 c++的,直接用结构体这种序列化方式。
tchar 怎么转换 go 的 string 呢? go 的 string 又怎么转换成 tchar 呢?
c++那边使用 unicode,tchar 大小为 2
我不会 c++,底层比较薄弱。请教下各位大佬
解决的可以发个红包答谢
2704 次点击
所在节点    Go 编程语言
8 条回复
koebehshian
2019-10-08 11:59:44 +08:00
go 的 string 是 utf-8,windows 上的 cplusplus 的 tchar 定义了_UNICODE 宏之后是 uft-16,没定义是操作系统本地的编码(中文简体系统是 gbk )
koebehshian
2019-10-08 12:05:24 +08:00
最简单的方法是约定一种编码,传输汉字编码的十六进制字符串,而不是十六进制值,也就是纯 ascii 码,发送方编码,接收方解码,类似网页图片用 base64
koebehshian
2019-10-08 12:09:59 +08:00
go 标准库 unicode/utf16 有个 Encode 函数,把 uft-32 转成 utf-16, go 中的字符串能直接显式转成[]rune 类型
WinCloud
2019-10-08 12:21:33 +08:00
给个小建议,网络传字符尽量用 utf-8,后面能少好多问题。
TCHAR 本身是 Win32 下的宏定义,字节数和编码不确定,不建议直接用在网络或者文件相关的模块上。
GeruzoniAnsasu
2019-10-08 12:46:14 +08:00
TCHAR 是个宏,用来控制使用 char 还是 wchar_t 作为字符类型。


然而……
用哪种 char 作为字符类型并不能代表字符串用哪种编码格式储存
用哪种 char 作为字符类型并不能代表字符串用哪种编码格式储存
用哪种 char 作为字符类型并不能代表字符串用哪种编码格式储存



也就是说,完全可以用单字节 char string 来存变长编码 unicode ( utf8 ),也可以用单字节 char string 存(伪)定长编码 utf16 ;也可以用 wchar_t 去存 utf16 这样一般一个 wchar_t 刚好能放一个 utf16 的编码序列……微软曾是这么想的但现在证明想法很蠢。

对于完全不需要跟 windows API 打交道的数据,应当一律使用单字节字符 char 类型并采用 utf8 编码来存储字符串。当要使用 windows API 时转成 utf16。

如果对方的代码不用到 windowsAPI (尤其指 xxxA 和 xxxW 有区别的 API 如 MessageBoxW ),那么只用 ANSI 字符编译的版本也就是 TCHAR 定义为 char 的版本也不会有问题。

当然一般不是这种情况

另一种情况 TCHAR 被定义成 wchar_t,使用 utf16 编码,但在内存层面来看并不需要知道一个字符被定义成了多大,byte 序列都是一样的,把整段内存以 utf16 的方式 decode 即可
reus
2019-10-08 12:53:09 +08:00
叫他改成 json,不折腾
jimrok
2019-10-08 13:07:44 +08:00
要看对方平台用什么方式编码,GBK,UTF8 都会导致不同的解码方式。建议在异构平台下都按照 protobuf 进行编码。
nicebird
2019-10-08 13:45:14 +08:00
上 protobuf\json\xml

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/606954

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX