加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

C使用unsigned int调用重载函数

发布时间:2020-12-16 03:29:27 所属栏目:百科 来源:网络整理
导读:这似乎不一致.我为签名类型short,int和long long重载了3个函数.如果你传递一个unsigned short,那么它会被提升为下一个最大的signed类型int.但是,如果你传递unsigned int,那么它不会被提升为signed long long,这是我所期望的,而是编译器抱怨对重载函数的模糊
这似乎不一致.我为签名类型short,int和long long重载了3个函数.如果你传递一个unsigned short,那么它会被提升为下一个最大的signed类型int.但是,如果你传递unsigned int,那么它不会被提升为signed long long,这是我所期望的,而是编译器抱怨对重载函数的模糊调用.
void f(short x) { std::printf("f(short)n"); }
void f(int x) { std::printf("f(int)n"); }
void f(long long x) { std::printf("f(long long)n"); }

int main()
{
    f((unsigned short)0); // Fine: calls f(int)
    // f((unsigned int)0); // Ambiguous: could be f(short),f(int) or f(long long) 
}

解决方法

这是不一致的,是的,但它是语言的方式,你必须应对,例如,如果你想要f((unsigned int)0)来调用long long重载,那么提供一个包装器,
inline void f(unsigned int x) { f((long long)x); }

C的设计者理想地喜欢让你的两种情况都失败超载分辨率.但是有一些传统的东西(一直追溯到“K& R”C),称为“默认参数提升”,基本上说,如果需要匹配,编译器会隐式地将所有比int更窄的整数类型转换为int一个函数签名,所有浮点类型都比double和double都要窄.

所以这是f((无符号短)0)的情况,真是奇怪的人.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读