C++隐式转换问题分析及解决办法

发布时间:2020-10-24 10:05:37 作者:落星无尘_Will
来源:脚本之家 阅读:156

我们先来看下实例代码:

#include <iostream>
#include <string>
using std::cin;
using std::cout;
using std::endl;
using std::string;
int main()
{
  unsigned int a;
  int b = -1;
  while (cin >> a)
  {
    if (a > b)
    {
      cout << "a > b" << endl;
    }
    else if (a < b)
    {
      cout << "a < b" << endl;
    }
    else
    {
      cout << "a == b" << endl;
    }
    
  }
  return 0;
}

C++隐式转换问题分析及解决办法

解释:

如果算术运算或关系运算的运算对象有多种类型,需要转换成同一种类型。

这个涉及到无符号类型的运算对象

如果某个运算符的运算对象不一致,这些运算对象将转换成同一种类型。但是如果某个运算对象的类型是无符号类型,那么转换的结果就要依赖机器中各个整数类型中各个整数类型的相对大小了。

像往常一样,首先执行整型提升。如果结果的类型匹配,无需进行进一步的转换。如果两个(提升后的)运算对象的类型要么都是带符号的、要么都是无符号的,则小类型的运算对象转换成较大的类型。

如果一个运算对象是无符号类型、另外一个运算对象是带符号类型,而且其中的无符号类型不小于带符号类型,那么带符号的运算对象转换成无符号的。如上面的程序中的unsigned int和int,则int类型的运算对象转换成unsigned int类型。如果int型的值恰好为负值,则转换为unsigned int的数值总数去模后的余数。也就造成了a < b的奇怪情况。

例如,8比特大小的unsigned char可以表示0至255区间内的值,如果我们赋了一个区间以外的值,则实际的结果是该值对256取模后所得的余数。因此把-1赋给8比特大小的unsigned char所得的结果是255。

剩下的一种情况是带符号类型大于无符号类型,此时转换的结果依赖于机器,如果无符号类型的所有值都能存在在该带符号类型中,则无符号类型的运算对象转换成带符号类型。如果不能,那么带符号类型的运算对象转换成无符号类型。

到此这篇关于C++隐式转换问题分析及解决办法的文章就介绍到这了,更多相关C++中发现的隐式转换问题内容请搜索亿速云以前的文章或继续浏览下面的相关文章希望大家以后多多支持亿速云!

推荐阅读:
  1. mysql如何实现隐式转换
  2. 6、Scala隐式转换

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

c++ 隐式转换 c+

上一篇:MyBatis源码分析之日志记录详解

下一篇:python实现ip地址查询经纬度定位详解

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》