草庐IT

c++ - abs 的溢出是否定义明确?

以下代码的行为是否定义明确?int32_ti=-0x80000000;uint32_tu=abs(i);第一行可能有上溢/下溢。但是在可以的平台上,第二行是否有定义的行为? 最佳答案 你是说-0x80000000有七个0吗?abs(-0x8000000)的行为肯定是明确定义的(uint32_t和int32_t都包含±0x8000000它们的有效范围如果这些类型存在。当标准说一种行为未定义时,即使某些特定平台以某种已定义的方式工作,它也是未定义的。C++的abs函数取自C,C标准说(§7.20.6.1/2):Theabs,labs,a

c++ - 在函数完整性检查期间如何处理整数溢出?

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:BestwaytodetectintegeroverflowinC/C++我正在用C编写一个函数,但问题是通用的。该函数接受三个整数并返回有关这三个整数的一些信息。我怀疑这里的问题是整数可以达到最大值,这会导致溢出。例如:如果我将a作为最大值传递并且b可以是1-max的任何值,那么在这种情况下,if条件中的表达式(a+b)>c会导致溢出吗?如果是这样,我该如何处理?我的解决方案是保留一个长整数作为临时变量以保留a+b的值并在表达式中使用它,但这听起来很脏。引用这个片段:inttriangle_type(int

c++ - std::regex_replace 期间的堆栈溢出

我正在尝试执行以下基于C++STL的代码来替换相对较大的SQL脚本(~8MB)中的文本:std::basic_regexreProc("^[\t]*create[\t]+(view|procedure|proc)+[\t]+(.+)$\n((^(?![\t]*go[\t]*).*$\n)+)^[\t]*go[\t]*$");std::basic_stringreplace=_T("ALTER$1$2\n$3\ngo");returnstd::regex_replace(strInput,reProc,replace);结果是堆栈溢出,并且很难在该特定站点上找到有关该特定错误的信息,因为

【解决方案】Java 互联网项目如何防止集合堆内存溢出(一)

目录前言一、代码优化1.1Stream流自分页1.2数据库分页1.3其它思考二、硬件配置2.1云服务器配置三、文章小结前言OOM几乎是笔者工作中遇到的线上bug中最常见的,一旦平时正常的页面在线上出现页面崩溃或者服务无法调用,查看服务器日志后你很可能会看到“Causedby:java.lang.OutOfMlemoryError:Javaheapspace”这样的提示,那么毫无疑问表示的是Java堆内存溢出了。其中又当属集合内存溢出最为常见。你是否有过把整个数据库表查出来的全字段结果直接赋值给一个List对象?是否把未经过过滤处理的数据赋值给Set对象进行去重操作?又或者是在高并发的场景下创建

c++ - 如何在 C++ 中捕获整数溢出?

这个问题在这里已经有了答案:HowdoIdetectunsignedintegeroverflow?(31个答案)关闭5年前。我有一个sum()函数。我需要捕获所有溢出。我搜索了网站,但没有找到这样做的好方法。那么……有什么想法吗?

c++ - 避免在 "simple Summation"上加倍溢出/溢出

我正在努力解决求和问题,该问题因不足或溢出而失败。我有超过8271571个double值,我需要从中求算术平均值。但主要问题是,我似乎不够聪明,无法做到这一点。目前我只是将它们相加并除以大小。这在大多数情况下都失败或溢出,给我-1.#INF或1.#INF。for(size_tj=0;jsize();i++){a+=Features->at(i)->at(j);}meanVector[j]=a/Features->size();}但是没有可能说它只是正值或负值,所以我不能设置要签名的数据类型。我还尝试在求和中使用除法常数,或者在将它们相加时除以大小,但这也无济于事。根据我快速浏览所见,值

java - 发生整数溢出时无符号整数和有符号整数的行为差异

按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭10年前。在维基百科上阅读这篇关于IntegerOverflow的文章我不太明白为什么有符号整数的溢出会导致未定义的行为,而无符号整数的溢出会导致回绕。为什么它们的行为会有所不同?另一个问题:一般的编程语言是否有任何防止整数溢出的保护措施?

c++ - 提振 spirit ,递归和堆栈溢出

为什么下面的代码会在运行时崩溃(它会给出堆栈溢出错误)?#include#include#include#include#include#include#include#include#include#includenamespaceqi=boost::spirit::qi;//Helperstructs//typesenumclasstypes{void_t,int_t,double_t,bool_t,string_t};structtypes_:qi::symbols{types_(){add("void",types::void_t)("int",types::int_t)("d

c++ - 基于编译时元编程的定点算法。乘法溢出?

我目前正在通过模板元编程实现编译时3d光栅。在实现了代数基础知识(2d/3d/4dvector、3x3/4x4矩阵运算、用于剔除目的的aabb2d/3d等)之后,我注意到整数运算对于vector转换来说不够好。于是开始写定点实现:该库有一个基本header,其中包含代数函数的通用元函数声明类型将实现(提供统一的接口(interface))。这是定点实现使用的一组定义:templatestructzero;//Getsthezerovalueofatypeofdata.Forexample,zero>returnsstd::integral_constanttemplatestructo

c++ - 迭代中的指针算法是否溢出安全?

即使在较新的C++代码中,我也经常看到使用普通指针算法进行数组迭代。我想知道它们到底有多安全,使用它们是否是个好主意。考虑这个片段(如果你用calloc代替new,它也会在C中编译):int8_t*buffer=newint8_t[16];for(int8_t*p=buffer;p当buffer发生分配到地址0xFFFFFFF0时,这种迭代不会导致溢出并完全跳过循环吗(在32位地址空间中)或0xFFFFFFFFFFFFFFFF0(64位)?据我所知,这是一种非常不幸但仍有可能出现的情况。 最佳答案 这是安全的。C和C++标准明确允许