为什么对Chrono :: Nanseconds的表示类型是签名的整数类型
why is representation type for chrono::nanoseconds a signed integer type?
在file/usr/include/c /4.8中的gcc 4.84中
namespace std
{
typedef duration<int64_t, nano> nanoseconds;
为什么纳秒的表示类型是签名的整数类型?为什么不签名?我们什么时候可以有一个持续时间对象具有负值?
什么时候可以有一个负值的持续时间对象?
任何时候要表示负持续时间!
例如。"提前十秒钟"是std::chrono::seconds(-10)
,如果将其添加到某些time_point t
中,那么您会在t
之前获得十秒钟的time_point
。
标准显示" duration
类型测量两个时间点之间的时间(time_points
)。"它并不是说它只能在不淘汰时间点之间测量时间。因此,这意味着它可以用于测量t1
和t2
之间的时间,即使t2 < t1
。为此,您需要一个负值。
如果无法签署持续时间,则表示偏移表示"较早的"不是"以后",您必须使用诸如std::pair<bool, duration>
之类的东西,其中bool
在其中说是正还是负偏移,然后您'必须这样做:
chrono::time_point adjust(chrono::time_point t, pair<bool, duration> offset)
{
if (offset.first) // positive
return t + offset.second;
else // negative
return t - offset.second;
}
这很愚蠢。语言和硬件已经通过使用签名的整数已经更有高效地支持了这一点。
如果定义了两个对象a
和b
,以使a - b
是持续时间,那么希望拥有a - b = -(b - a)
。
要实施该反交通属性,需要签署持续时间。
它不仅是GCC实现,而且是标准([time.syn])所要求的:
typedef duration<signed integer type of at least 64 bits, nano> nanoseconds;
持续时间代表两个时间点A和B之间的时间差。
相关文章:
- 将超出范围的整数分配给有符号字符类型
- 当我输入字符类型的数字时,为什么我无法获得整数?
- 整数类型应该显式转换(例如"int"到"无符号")还是只会增加混乱?
- 在 c++ 中,能够将浮点类型加 1 的最大整数是多少?
- 为什么 Clang 和 GCC 中两个无符号整数之和的结果类型不同
- 比较两个整数在C++中与未知 int 类型的相等性
- 如何在不给它任何类型(如整数)的情况下定义某物?
- 通过编译时值推断整数的类型
- C++/错误:表达式必须具有整数或无作用域枚举类型
- 从双精度转换为整数的显式类型是否始终检查整数溢出?
- 有没有办法将字符类型转换为整数?
- C++,概念不适用于无符号整数作为结果类型?
- 如何将整数分配给 char 类型的变量
- 类型转换问题:返回为整数而不是浮点/类型
- 涉及旧式枚举和整数类型的重载解析
- 将字符串转换为整数类型T,检查是否存在溢出
- 如何判断 c++ 向量中的值类型(整数或双精度)?
- 在 C/C++ 中,混合类型整数数学所需的最小类型向上转换是多少?
- 如何将字节数组转换为整数类型(整数、长整型、短型等)"安眠安"?
- 我可以在C++中制作一个强类型整数吗?