短不会溢出 Visual C++ 2017

问题描述

输入 32760 和 9 打印出 32769,而不是 -32767。

我不知道还能做什么,这是一个简单的程序,但它不能按我想要的方式工作。

#include <iostream>
using namespace std;

int main()
{
    short a,b;
    cin >> a;
    cin >> b;
    cout << a+b;
}

解决方法

算术运算 CreateProcess 的结果不是 a+b 类型。相反,integer promotion 的规则规定,在加法之前,操作数首先被提升为更大的整数类型。

为了让它“工作”,就像你想要的那样,这样的事情会强制整数溢出(你似乎想看到):

short