相同的字符用不同的编码方式保存,数据不同。
源文件用不同的编码方式编写,会导致执行结果不一样。编译程序时,要指定字符集就可以解决这个问题。在Linux下:
man gcc , /charset
-finput-charset=charset 表示源文件的编码方式, 默认以UTF-8来解析
-fexec-charset=charset 表示可执行程序里的字时候以什么编码方式来表示,默认是UTF-8
下面以实例说明: ansi.c和utf8.c的内容如下,分别保存为ansi,utf-8格式.
分别用下面的命令编译程序,查看运行结果。
gcc -o ansi_pc ansi.c
gcc -o utf8_pc utf8.c
gcc -finput-charset=gbk -fexec-charset=utf-8 -o ansi_a_u_pc ansi.c
gcc -finput-charset=utf-8 -fexec-charset=gbk -o utf8_u_a_pc utf8.c
编译成arm版本,运行
makefile 文件如下:
CC = arm-none-linux-gnueabi-gcc
all:
$(CC) -o ansi_arm ansi.c
$(CC) -o utf8_arm utf8.c$(CC) -finput-charset=gbk -fexec-charset=utf-8 -o ansi_a_u_arm ansi.c
$(CC) -finput-charset=utf-8 -fexec-charset=gbk -o utf8_u_a_arm utf8.cclean:
rm *_arm