字符编码,linux使用指定的编码方式编译程序-finput-charset,-fexec-charset

相同的字符用不同的编码方式保存,数据不同。 

 

字符编码,linux使用指定的编码方式编译程序-finput-charset,-fexec-charset_第1张图片

 源文件用不同的编码方式编写,会导致执行结果不一样。编译程序时,要指定字符集就可以解决这个问题。在Linux下:

man gcc , /charset
-finput-charset=charset  表示源文件的编码方式, 默认以UTF-8来解析
-fexec-charset=charset   表示可执行程序里的字时候以什么编码方式来表示,默认是UTF-8

下面以实例说明: ansi.c和utf8.c的内容如下,分别保存为ansi,utf-8格式.

字符编码,linux使用指定的编码方式编译程序-finput-charset,-fexec-charset_第2张图片

分别用下面的命令编译程序,查看运行结果。

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

字符编码,linux使用指定的编码方式编译程序-finput-charset,-fexec-charset_第3张图片

编译成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.c

clean:
        rm *_arm

字符编码,linux使用指定的编码方式编译程序-finput-charset,-fexec-charset_第4张图片

你可能感兴趣的:(Linux)