测试达到最大uint64_t C++大小的有效方法
Efficient way to test for reaching max size of uint64_t C++
我有一个类,有两个类成员:
uint64_t m_numOfOperations; // how many times an operation was done
uint64_t m_someOtherMember; // will be divided by m_numOfOperations
在某个函数 updateNumberOfOperations() 中,我将这个计数器递增 1 并将m_someOtherMember除以计数器 (m_numOfOperations)y,如下所示:
m_someOtherMember = m_someOtherMember / m_numOfOperation;
现在,这个函数将被调用很多次,最终将导致 numOfOperation 达到其最大值,然后在下一次调用中达到零 - 这会导致除以零的错误。
现在,我想以下直接的实现可以解决问题,但是,每次检查零UINT64_MAX有点效率不高。
所以我的问题是 – 有没有更有效的方法来实现我的 updateNumberOfOperations() 方法的当前实现的功能?
谢谢家伙。
我的类的当前实现:
#include <cstdint>
class MyClass
{
public:
void updateNumberOfOperations()
{
if (UINT64_MAX == m_numOfOperations)
{
++m_numOfOperations;
}
++m_numOfOperations;
m_someOtherMember = m_someOtherMember / m_numOfOperations;
}
private:
uint64_t m_numOfOperations; // how many times an operation was done
uint64_t m_someOtherMember; // will be divided by numOfOperations
};
您可以使用以下函数在换行时跳过 0 值来递增无符号数字:
inline uint64_t inc(uint64_t a) {
++a; // Wrapping unsigned numbers is well-defined.
return a + !a;
}
它在代码中不生成分支。
另请注意,如果您每纳秒增加一次uint64_t
,则需要 ~584 年才能包裹它。
相关文章:
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- 通过方法访问结构
- 最小硬币更换问题(自上而下方法)
- C++为构建时间获取QDateTime的可靠方法
- 在C#中处理C++指针而不使用unsafe的最佳方法
- 处理多个异常集合的C++方法
- 如果C++类在类方法中具有动态分配,但没有构造函数/析构函数或任何非静态成员,那么它仍然是POD类型吗
- 有什么方法可以遍历结构吗
- 当类在C++中定义时,有什么方法可以"register"类吗?
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 实现无开销push_back的最佳方法是什么
- 使用std::函数映射对象方法
- 有符号的int和int-有没有一种方法可以在C++中区分它们
- C++从另一个类访问公共静态向量的正确方法是什么
- C++优先级队列,按对象的唯一指针的特定方法升序排列
- 没有为自己的结构调用列表推回方法
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- 在类定义之后定义一个私有方法
- 枚举环境变量的惯用C++14/C++17方法
- 初始化具有非默认构造函数的std::数组项的更好方法