这是我想要做的:
typedef uint16_t uchar16_t;
uchar16_t buf[32];
// buf will contain timezone information like GMT-6, Eastern Daylight Time, etc
char * str = "Test";
for (int i = 0; i <= strlen(str); i++)
buf[i] = str[i];我猜这是不正确的,因为uchar16_t包含2个字节,而字符串包含1个字节。
我该怎么做呢?
发布于 2010-06-12 03:00:10
斯特伦?buf32?想要毁灭宇宙吗?
您想要使用wstringstream。
std::wstringstream lols;
lols << "Test";
std::wstring cakes;
lols >> cakes;Edit@Comment:你不应该使用strlen,因为任何像样的字符串系统都允许嵌入零,而strlen的速度非常慢。此外,您没有根据需要调整缓冲区的大小,因此如果字符串的大小大于31,则会出现缓冲区溢出。此外,您还必须(如果您确实动态地调整了缓冲区大小)之后手动释放它。这两件事都是C字符串系统的严重缺陷。我的示例代码让您的标准库编写人员为您完成所有工作并避免所有这些问题。
发布于 2010-06-12 03:03:17
如果您的字符串始终是ASCII,这实际上是可以的。为了正确地做到这一点,可移植函数是mbstowcs,它假设您是从默认语言环境转换的,或者如果您是在Windows上,那么有一些API函数可以让您显式地指定源代码页。
发布于 2010-06-12 02:59:24
只要str是ASCII码,您的代码就可以工作;不过,在循环条件下调用strlen()可能不是一个好主意。如果您的系统上有swprintf(),那么只使用它可能会更容易:
uchar16_t buf[32];
char *str = "Test";
swprintf(buf, sizeof buf, "%s", str);https://stackoverflow.com/questions/3025450
复制相似问题