将所有255个ASCII/ANSI/ISO字符输出到文件中 #包括 #包括 int main() { 文件*oFile=fopen(“文件”、“wb”); 对于(int i=255;i>=0;i--) fprintf(文件,“%c”,i); 系统(“暂停”); 返回0; }

将所有255个ASCII/ANSI/ISO字符输出到文件中 #包括 #包括 int main() { 文件*oFile=fopen(“文件”、“wb”); 对于(int i=255;i>=0;i--) fprintf(文件,“%c”,i); 系统(“暂停”); 返回0; },c,file,C,File,现在,“文件”只包含“怪异”字符: ����훗퓕틓탑컏쳍쫋죉웇쓅싃상뺿벽못뢹뚷뒵늳낱꺯겭ꪫꢩꚧ꒥ꊣꂡ麟鲝骛颙隗钕銓邑躏貍誋袉蚇蒅芃肁繿籽穻硹癷瑵牳灱湯汭橫桩晧摥扣恡幟屝婛塙噗呕剓偑乏䱍䩋䡉䙇䑅䉃䁁㸿㰽㨻㠹㘷㐵㈳〱ⸯⰭ⨫⠩☧␥∣‡ḟᰝᨛ᠙ᘗᐕሓထฏ఍਋ࠉ؇Ѕȃ 有趣的是,使用控制台流,一切都正常 #include <stdio.h> #include <iostream> int main() { FILE* oFile=fopen("file","wb");

现在,“文件”只包含“怪异”字符:

����훗퓕틓탑컏쳍쫋죉웇쓅싃상뺿벽못뢹뚷뒵늳낱꺯겭ꪫꢩꚧ꒥ꊣꂡ麟鲝骛颙隗钕銓邑躏貍誋袉蚇蒅芃肁繿籽穻硹癷瑵牳灱湯汭橫桩晧摥扣恡幟屝婛塙噗呕剓偑乏䱍䩋䡉䙇䑅䉃䁁㸿㰽㨻㠹㘷㐵㈳〱ⸯⰭ⨫⠩☧␥∣‡ḟᰝᨛ᠙ᘗᐕሓထฏ఍਋ࠉ؇Ѕȃ

有趣的是,使用控制台流,一切都正常

#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;
}
#包括
#包括
int main()
{
对于(int i=255;i>=0;i--)
printf(“%c”,i);
系统(“暂停”);
返回0;
}
问题是:为什么输出文件中没有“拉丁”字符?即使在记事本++中将UCS-2 little-endian(为什么自动选择它?)转换为ascii之后:


ď™í›—í“•í‹“í‘컏쳍쫋죉웇쓅ě‹ě뺿벽못뢹뚷뒵늳낱꺯겭ꪫꢩꚧ꒥ꊣꂡ麟鲝骛颙隗钕銓邑躏貍誋袉蚇蒅čŠč‚繿籽穻硹癷瑵牳ç±ćąŻć±­ć©«ćˇ©ć™§ć‘Ąć‰Łćˇĺąźĺ±ťĺ©›ĺˇ™ĺ™—呕剓ĺ‘乏䱍䩋䡉䙇䑅ä‰ä㸿㰽㨻㠹ă·ăµăłă€±â¸Żâ°­â¨«â ©â§âĄâŁâ€ˇá¸źá°ťá¨›á ™á—á•á“á€'ŕ1847;ŕŕŕŕŕŕŘŖ272;

是否在支持unicode的编辑器中打开“文件”?由于您在输出流中使用了不可见的字符,我看起来它正在将文件解释为UTF-8或UTF-16。请查看您的编辑器是否有字符编码选项,并尽可能将其设置为纯ASCII。

是否打开“文件”在支持unicode的编辑器中?由于您在输出流中使用了不可见的字符,我看起来它正在将文件解释为UTF-8或UTF-16。请查看您的编辑器是否具有字符编码选项,并尽可能将其设置为纯ASCII。

您将看到的内容将严重依赖于托管操作系统/编辑器的代码页/编码您将看到,您的主机操作系统/编辑器的代码页/编码将严重依赖。我认为您遇到的一个问题是,您碰巧以一个众所周知的“feff”开始文件,这是UTF-16的BOM。这意味着许多编辑器会认为这是UTF16,而他们通常默认为ASCII/UTF8

查看您的十六进制文件:

#include <stdio.h>
#include <iostream>




int main()
{


    for(int i = 255; i>=0; i--)
        printf("%c",i);

    system("pause");
    return 0;
}
00000000 ff fe fd fc fb fa f9 f8 f7 f6 f5 f4 f3 f2 f1 f0 ||
000000 10 ef ee ed ec eb ea e9 e8 e7 e5 e4 e3 e2 e1 e0 ||
00000020 df de dd dc db da d9 d8 d7 d6 d5 d4 d3 d2 d1 d0 ||
000000 30 cf ce cd cc cb ca c9 c8 c7 c6 c5 c4 c3 c1 c0|
000000 40高炉为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 a2 a0 ||
00000060 9f 9e 9d 9c 9b 9a 99 98 97 96 95 94 92 90 ||
000000 70 8f 8e 8d 8c 8b 8a 89 88 87 86 85 84 82 80 ||
00000080 7f 7e 7d 7c 7b 7a 79 78 77 76 75 74 73 72 71 70 ~}{zyxwvutsrqp|
000000 90 6f 6e 6d 6c 6b 6a 69 68 67 66 65 63 62 60 | onmlkhgfedcba`|
000000 A0 5f 5e 5d 5c 5b 5a 59 58 57 56 55 54 53 52 50 | ^]\[ZYXWVUTSRQP|
000000 b0 4f 4e 4d 4c 4a 49 48 47 46 45 44 42 40 | onmlkhgfedcba@|

000000 C0 3f 3e 3d 3c 3b 3a 39 38 37 36 35 34 33 32 31 30 |?>=我认为您遇到的一个问题是,您的文件刚开始时使用了一个众所周知的“feff”,这是UTF-16的BOM。这意味着许多编辑会认为这是UTF16,通常默认为ASCII/UTF8

查看您的十六进制文件:

#include <stdio.h>
#include <iostream>




int main()
{


    for(int i = 255; i>=0; i--)
        printf("%c",i);

    system("pause");
    return 0;
}
00000000 ff fe fd fc fb fa f9 f8 f7 f6 f5 f4 f3 f2 f1 f0 ||
000000 10 ef ee ed ec eb ea e9 e8 e7 e5 e4 e3 e2 e1 e0 ||
00000020 df de dd dc db da d9 d8 d7 d6 d5 d4 d3 d2 d1 d0 ||
000000 30 cf ce cd cc cb ca c9 c8 c7 c6 c5 c4 c3 c1 c0|
000000 40高炉为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 a2 a0 ||
00000060 9f 9e 9d 9c 9b 9a 99 98 97 96 95 94 92 90 ||
000000 70 8f 8e 8d 8c 8b 8a 89 88 87 86 85 84 82 80 ||
00000080 7f 7e 7d 7c 7b 7a 79 78 77 76 75 74 73 72 71 70 ~}{zyxwvutsrqp|
000000 90 6f 6e 6d 6c 6b 6a 69 68 67 66 65 63 62 60 | onmlkhgfedcba`|
000000 A0 5f 5e 5d 5c 5b 5a 59 58 57 56 55 54 53 52 50 | ^]\[ZYXWVUTSRQP|
000000 b0 4f 4e 4d 4c 4a 49 48 47 46 45 44 42 40 | onmlkhgfedcba@|

000000 C0 3f 3e 3d 3c 3b 3a 39 38 37 36 35 34 33 32 31 30 |?>=您忘记实际提问。您如何阅读文件?使用标准windows7记事本和记事本++时,您忘记实际提问。您如何阅读文件?使用标准windows7记事本和记事本+(如果解释为UTF)-8我希望在某个地方看到一些ASCII字符。如果是UTF-16,我只希望看到128个字符。@MarkRansom“怪异字符”OP询问的似乎只有128个字符(我没有计算所有字符,但肯定比256更接近128个字符)。我猜是UTF-16。@AaronDufour,仔细看一看之后,我会同意你们两人的看法。UTF-16是最有可能的解释。文件以0xff开始,0xfe是UTF-16的字节顺序标记。问题更新了。为什么在转换为ASCII后