#include <stdio.h>
#include <iostream>
int main()
{
FILE* oFile=fopen("file","wb");
for(int i = 255; i>=0; i--)
fprintf(oFile,"%c",i);
system("pause");
return 0;
}
现在,“文件”只包含“怪异”字符:
훗퓕틓탑컏쳍쫋죉웇쓅싃상뺿벽못뢹뚷뒵늳낱꺯겭ꪫꢩꚧ꒥ꊣꂡ麟鲝骛颙隗钕铨邑躏狸誋袉蚇蒅芃肁繿籽穻硹癷瑵牳灱汤汭横桩晧摥扣恡帜屝婛塙噗呕剓偑乏䱍䩋䡉䙇䑅䉃䁁㸿㰽㨻㠹㘷㐵㈳〱ⸯⰭ⨫⠩☧␥|‡ḟᰝᨛ᠙ᘗᐕሓထฏࠉ؇Ѕȃ
对我来说很有趣,使用控制台流,一切都很好。
#include <stdio.h>
#include <iostream>
int main()
{
for(int i = 255; i>=0; i--)
printf("%c",i);
system("pause");
return 0;
}
问题是:为什么输出文件中没有“拉丁”字符?即使从UCS-2小端(为什么自动选择?)转换为记事本中的ascii ++:
DLD«»DLAD>·d“μD
答案 0 :(得分:6)
你是否在unicode感知编辑器中打开'file'?由于您在输出流中使用了不可见的字符,我看起来正在将文件解释为UTF-8或UTF-16。查看您的编辑器是否具有字符编码选项,并在可能的情况下将其设置为纯ASCII。
答案 1 :(得分:6)
我认为你遇到的一个问题就是你碰巧用一个众所周知的byte order mark,“feff”开始你的文件,这是UTF-16的BOM。这意味着许多编辑会认为这是UTF16,他们通常默认为ASCII / UTF8。
以十六进制查看您的文件:
00000000 ff fe fd fc fb fa f9 f8 f7 f6 f5 f4 f3 f2 f1 f0 |................|
00000010 ef ee ed ec eb ea e9 e8 e7 e6 e5 e4 e3 e2 e1 e0 |................|
00000020 df de dd dc db da d9 d8 d7 d6 d5 d4 d3 d2 d1 d0 |................|
00000030 cf ce cd cc cb ca c9 c8 c7 c6 c5 c4 c3 c2 c1 c0 |................|
00000040 bf be bd bc bb ba b9 b8 b7 b6 b5 b4 b3 b2 b1 b0 |................|
00000050 af ae ad ac ab aa a9 a8 a7 a6 a5 a4 a3 a2 a1 a0 |................|
00000060 9f 9e 9d 9c 9b 9a 99 98 97 96 95 94 93 92 91 90 |................|
00000070 8f 8e 8d 8c 8b 8a 89 88 87 86 85 84 83 82 81 80 |................|
00000080 7f 7e 7d 7c 7b 7a 79 78 77 76 75 74 73 72 71 70 |.~}|{zyxwvutsrqp|
00000090 6f 6e 6d 6c 6b 6a 69 68 67 66 65 64 63 62 61 60 |onmlkjihgfedcba`|
000000a0 5f 5e 5d 5c 5b 5a 59 58 57 56 55 54 53 52 51 50 |_^]\[ZYXWVUTSRQP|
000000b0 4f 4e 4d 4c 4b 4a 49 48 47 46 45 44 43 42 41 40 |ONMLKJIHGFEDCBA@|
000000c0 3f 3e 3d 3c 3b 3a 39 38 37 36 35 34 33 32 31 30 |?>=<;:9876543210|
000000d0 2f 2e 2d 2c 2b 2a 29 28 27 26 25 24 23 22 21 20 |/.-,+*)('&%$#"! |
000000e0 1f 1e 1d 1c 1b 1a 19 18 17 16 15 14 13 12 11 10 |................|
000000f0 0f 0e 0d 0c 0b 0a 09 08 07 06 05 04 03 02 01 00 |................|
00000100
答案 2 :(得分:0)
您将看到的内容将更多地取决于托管操作系统/编辑器的代码页/编码