wprintf输出可以在Windows上正确地重定向到UTF-16吗?

Erw*_*der 14 encoding redirect utf-16

在C程序中,我使用wprintf在Windows控制台中打印Unicode(UTF-16)文本.这很好,但是当程序的输出重定向到日志文件时,日志文件的UTF-16编码已损坏.在Windows命令提示符中完成重定向时,所有换行符都编码为窄ASCII换行符(0d0a).在PowerShell中完成重定向时,将插入空字符.

是否可以将输出重定向到正确的UTF-16日志文件?

示例程序:

#include <stdio.h>
#include <windows.h>
#include <fcntl.h>
#include <io.h>

int main () {

  int prevmode;

  prevmode = _setmode(_fileno(stdout), _O_U16TEXT);
  fwprintf(stdout,L"one\n");
  fwprintf(stdout,L"two\n");
  fwprintf(stdout,L"three\n");
  _setmode(_fileno(stdout), prevmode);


  return 0;
}
Run Code Online (Sandbox Code Playgroud)

在命令提示符中重定向输出.参见0d0a,它应该是0d00 0a00:

c:\test>.\testu16.exe > o.txt

c:\test>xxd o.txt
0000000: 6f00 6e00 6500 0d0a 0074 0077 006f 000d  o.n.e....t.w.o..
0000010: 0a00 7400 6800 7200 6500 6500 0d0a 00    ..t.h.r.e.e....
Run Code Online (Sandbox Code Playgroud)

在PowerShell中重定向输出.查看所有插入的0000.

PS C:\test> .\testu16.exe > p.txt
PS C:\test> xxd p.txt
0000000: fffe 6f00 0000 6e00 0000 6500 0000 0d00  ..o...n...e.....
0000010: 0a00 0000 7400 0000 7700 0000 6f00 0000  ....t...w...o...
0000020: 0d00 0a00 0000 7400 0000 6800 0000 7200  ......t...h...r.
0000030: 0000 6500 0000 6500 0000 0d00 0a00 0000  ..e...e.........
0000040: 0d00 0a00                                ....
Run Code Online (Sandbox Code Playgroud)

gj1*_*j13 1

">" 始终会将您的控制台 UTF16 重定向为可打印的“ASCII”,即使您在输出中添加了 BOM 或使用prevmode = _setmode(_fileno(stdout), _O_BINARY);. 我在 windows7 上也有同样的问题,没有办法用 fwprintf 来做到这一点。