Crez.晔霖 发表于 2020-1-22 02:26:39

C++的char相同的文字有两种编码?但最后判断不一样

#include<iostream>
using namespace std;
int main()
{
        char ABC[] = { 178        ,227        ,0 };
                                //-256, -256,结尾符号
        char DEF[] = { -78,       -29,    0 };
        cout << ABC << endl << DEF << endl;
        if (ABC == DEF)
        {
                cout << "一样";
        }
        else {
                cout << "不一样";
        }
       
        return 0;
}
输出结果:


不一样


这是什么原因?是不同的字有不同的编码么?在正常写的时候中文转成字节应该咋写?

我真的是小白 发表于 2020-1-22 16:40:29

如果实在msvc编译器下,你不指定char保存字符串时候的编码或者没有宏定义开关设定,那么就是以默认的代码页保存字符串,比如在简体中文就是cp936(GBK)编码, 中文字符两个字符,英文字符一个字节,如果你用C++11之后的标准可以追加u8指定为utf-8编码,或者在工程配置属性里设置开关

我真的是小白 发表于 2020-1-22 16:36:40

因为数组名在很多时候是会退化成指针的,指针比较你说呢,至于什么时候不会退化指针,这个你自己查下吧
页: [1]
查看完整版本: C++的char相同的文字有两种编码?但最后判断不一样