C语言输出中文乱码

Python010

C语言输出中文乱码,第1张

提几个建议。1)没给出str的大小,不知道你定义的多大。至少str要保证120以上。考虑用2的倍数最优可以char

str[122]并且因为系统将自动在最后加'\0'。最好设定读取121为好。以免读取半个中文字。2)fgets的用法问题。

追加返回值的判断为好。if(fgets(str,120,fp)!=null){

printf("%s\n",str)}3)关于出现乱码的问题,估计你的文件中有中文汉字。读取到119位的时候正好是某个汉字的前一半。要解决这个if(fgets(str,121,fp)!=null)

这里120

改成读偶数个121。另外文件最好用宽字符的。就可以避免乱码了。

1、汉字乱码是因为缓冲区有字符,需要用fflush(stdin)来清空键盘缓冲区,

使用getch等都是治标不治本的办法,可以多学习一下fflush的使用,对于大批量的手动输入,很用。

2、例程:

#include"stdio.h"

#include"stdlib.h"

#include <conio.h>

main()

{   

    

    char x

    while(1)

    {

        printf("请输入一个小写字母:")

            fflush(stdin)//清空键盘缓冲区

    x = getchar()

    printf("大写字母为:\n")putchar(x - 32)

    }

}

因为中文是占2个字符的 程序可以这么写

#include

#include

void shuchu(char shuchu[])

{

int i=0

while(shuchu[i]){

printf("%c%c",shuchu[i],shuchu[i+1])

printf(" ")

Sleep(1000)

i=i+2}

}

main()

{

char b[]="我们"

shuchu (b)

}