转 gcc源码 编码格式转换

转 gcc源码 编码格式转换
gcc
        GNU   C/C++编译器也可以正确支持wchar_t字符和字符串,但是源代码的保存格式必须符合
下面条件:
        一、源代码文件的保存编码必须是UTF-8
        二、UTF-8编码格式的源代码文件,不能有BOM标志头。
        只有源代码文件符合上面两个条件,gcc才会正确支持wchar_t字符和字符串。如果不符合
上面两个条件的话,有可能会编译出错,有可能会产生错误的wchar_t字符和字符串。
        gcc在Windows平台下,wchar_t是16位类型,在Linux平台下,wchar_t是32位类型。
       
        另外,GCC提供了以下的参数开关来支持其它文字编码的源文件:
        (a)-finput-charset=charset
            gcc在默认情况下,总是假设源代码的编码是UTF-8,如果是其它编码的源代码文件,
            源代码里面又用到了wchar_t的类型,则可以使用-finput-charset=charset这个参数
            来实现。
            例如通常使用GBK编码的源代码可以假如参数:-finput-charset=GBK
         (b)-fwide-exec-charset=charset
            默认情况下,gcc在Windows平台下,宽字符串串常量的每个字符是16位UTF-16类型,
            在Linux平台下,宽字符串串常量的每个字符是32位UTF-32类型,
            使用这个参数,可以改变宽字符串串常量的类型。
            例如在x86的机器环境,Linux操作系统下,要使例如 L"汉字" 编译后保存为UTF-16
            的字符串,则可以使用 -fwide-exec-charset=UTF-16LE 

你可能感兴趣的:(转 gcc源码 编码格式转换)