wchar_t阅读

我在读取文件的函数中有错,但我不知道出了什么问题。 当符号超出ASCII表时,所有符号都被正确读取。

while ((c = fgetwc(file)) != WEOF) { if (c != L'\n') { if (i == buf_length) { buf_length += BUF; wchar_t *rebuf = realloc(tmp, buf_length * sizeof(wchar_t)); if (rebuf == NULL) { free(tmp); tmp = NULL; buf_length = 0; return EALLOC; } else { tmp = rebuf; } } tmp[i] = (wchar_t)c; i++; } else { list->size++; tmp[i] = L'\0'; insertLast(list, tmp); i = 0; } 

是_UNICODE定义了吗? 另外,当你遇到WEOF时,检查你是否没有得到错误(使用ferror和feof),因为它可能意味着。

http://msdn.microsoft.com/en-us/library/c7sskzc1%28v=vs.71%29.aspx