当功能采用签名的int时,将浮点参数施放为未符号
Casting a float argument to unsigned when the function takes a signed int
我有一个很大的代码库,我需要对其进行消毒,并且遇到了类似于GCC警告我的代码,这对我来说没有任何意义。
void SetValue(int32_t value); // implementation not important
int main()
{
//...
float val = -10.0f; // real value comes from a function, but can be negative
//...
SetValue(uint32_t(val)); // huh?
//...
}
如果功能采用signed int
,则有任何理由将施放到unsigned int
吗?
这在整个代码库中发生了几次,因此不是一种情况。
这只是一个简单的错误,还是我缺少一些技巧?
编辑:要清楚,GCC消毒剂抛出runtime error: value -10 is outside the range of representable values of type 'unsigned int'
。
在显示的代码中,铸件似乎没有意义。将浮动点转换为一个整数类型,其中该值超出表示的界限具有未定义的行为。您不想要UB。
我的猜测是:演员表明确显示浮子被转换为整数,但是类型是错误的。
使用显式铸造可以防止许多编译器吐出有关隐式转换和可能丢失数据的警告。放入铸件以减少编译器警告的数量并不少见:您让编译器知道您对封面都很好。
在这种情况下,该值将被施加到未签名的int,然后将其施放回签名的int。可能根本没有理由这样做。我的猜测是,该功能曾经进行过未签名的INT,并且演员阵容与该功能有关(明确的铸件以减少警告),但是后来函数配置文件更改了,但另一部分未更新。
相关文章:
- 如何反转整数参数包
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用默认参数等选择模板专业化
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 函数调用中参数的顺序重要吗
- 部分定义/别名模板模板参数
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- 使用不带参数的函数访问结构元素
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 如何使用Luacneneneba API正确读取字符串和表参数
- 在派生函数中指定void*参数
- 视图中的参数推导失败:take_while
- 模板对象的C 数组:施放到常见的非类型模板参数是UB吗?
- 如何基于模板参数类型施放类模板
- 如何施放转发参数包
- 当功能采用签名的int时,将浮点参数施放为未符号