在基于范围的循环范围内的双/整数使用和数据缩小

Double/Integer use and data narrowing within a Range-Based for loop

本文关键字:整数 缩小 数据 循环 于范围 范围 范围内      更新时间:2023-10-16

我正在通过Bjarne Stroustrup的编程原理和实践努力,并且遇到了困难。我目前正在向矢量阅读,并已被引入基于范围的循环。在下面,我有一些代码,从我的眼中看,似乎正在读一遍int to int。我认为这会导致变窄。

int main()
{
    vector<double> temps;               // temperatures
    for (double temp; cin >> temp; )    // read into temp
        temps.push_back(temp);          // put temp into vector
                                        // compute mean temperature:
    double sum = 0;
    for (int x : temps) sum += x;
        cout << "Average temperature: " << sum / temps.size() << 'n'; 
                                        // compute median temperature:
    sort(temps);                        // sort temperatures
    cout << "Median temperature: " << temps[temps.size() / 2] << 'n';
    keep_window_open();
    return 0;
}

尝试了几次使用不同的输入,我得出了结论,这确实正在缩小。我正在创建一个双打和for(int x:temps(循环的矢量,将第一个元素置于温度内,将其放在x中,而不是将其递增到下一个元素并重复。因为元素(双重(被读取为X(整数(,导致狭窄。

我的主要问题是,如果我确实确实正确,它正在缩小向量内的元素(也许它实际上没有读取x,而int x正在描述其他内容(,我可以简单地替换(int x:temps((for(double x:temps(避免这种缩小,或者是在基于范围的循环参数中使用整数的使用(也许是这样设计的(。任何想法,谢谢。

这是一个狭窄的转换,是的(第11.6.4节A.K.A. [dcl.init.list],c 标准,项目7.1(。我猜这是一个错误的类型。假装它说double x(或auto x,如果您已经知道auto关键字,则可以使编译器推论类型(如果可能((。

我找不到第二版Errata。实际上,我实际上放弃了Stroustrup教授并问他(不要害羞 - 如您所见,这本书有很多错误,他应该对这个问题表示赞赏(。

  1. 是的,您可以使用任何类型来初始化您的for循环变量(其任何版本(。
  2. 是, c/c 中的浮点类型转换为整数类型,始终返回此数字的截断值(floor操作(。

请看一下C 铸造规则:

如果转换是从浮点类型到整数类型的,则该值被截断(去除小数部分(。如果结果不在类型的代表值范围之内,则转换会导致不确定的行为。