c – 防止C整数溢出
发布时间:2020-12-13 19:24:23 所属栏目:Linux 来源:网络整理
导读:我在函数中有一些代码,它将使用递增/递减运算符更改/更新值.例如: static void update_value(char op){ if (op == '+') value++; // uint32_t global value else value--;} 该函数不会检查我们是否超过/低于最大/最小值.因此,当值为16时,调用者可以将其调用
我在函数中有一些代码,它将使用递增/递减运算符更改/更新值.例如:
该函数不会检查我们是否超过/低于最大/最小值.因此,当值为16时,调用者可以将其调用20次.结果为2 ^ 32 – 1 – 4. 我想提防,但我想使用标准库常量.我记得有一个size_t(或类似)变量代表uint32_t可以容纳的最大数字. 我不记得确切的常数和它们被定义的标题.有帮助吗? 最佳答案
我发现最常见的解决方案是检查递增的值是否实际上大于先前的值,或者递减的值是否小于先前的值.这仅在值无符号时才有效,与变量的大小无关,并且与C代码一样可移植.
请注意,代码可能碰巧使用有符号值,但根据C标准,这将是未定义的行为,并且编译器可以自由替换if(value 1> value)… with if(0)….您不应将此代码与签名值一起使用,除非您有一个流程来在链接后审核生成的目标代码. 使用gcc和clang,您需要添加-fwrapv选项以使此代码适用于签名值;与其他编译器,您的里程可能会有所不同 这样做的唯一理智方法是特定于类型并使用来自limits.h的常量.例如:
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |