- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我在尝试保持原子时间点时遇到了这个问题,看(如果默认构造函数可用,atomic 需要 noexcept 默认构造函数): http://cplusplus.github.io/LWG/lwg-active.html#2165
简单的问题是 std::atomic 或类似的将无法在当前 std 下编译。
考虑到 std::chrono::clock_type::now() 是无异常(exception)的。时间点本身不是,这似乎很奇怪。
最佳答案
在我看来,它们应该是有条件的 noexcept
.为了描述正确的条件,我们需要备份和讨论 duration
的构造函数.
首先是特殊构造函数:默认和复制。
这些构造函数被正确指定为 = default
.这意味着如果基础 rep
有特价noexcept
构造函数然后是 duration
也会。这正是我们想要的。
现在怎么样:
template <class Rep2>
constexpr explicit duration(const Rep2& r);
template <class Rep2, class Period2>
constexpr duration(const duration<Rep2, Period2>& d);
这些目前不是noexcept
, 但如果他们调用的结构是 noexcept
我们希望他们是.例如:
template <class Rep2>
constexpr explicit duration(const Rep2& r)
noexcept(is_nothrow_constructible<rep, Rep2 const&>{});
template <class Rep2, class Period2>
constexpr duration(const duration<Rep2, Period2>& d)
noexcept(noexcept(is_nothrow_copy_constructible<rep>{}) &&
noexcept(std::chrono::duration_cast<duration>(d)));
这意味着除了常见的用例,它们将是唯一的。但是,如果您创建一个 Rep
这是一个可能(例如)引发溢出的算术模拟器,那么这些构造函数将正确地不是 noexcept
.
为了使这些构造函数真正起作用,成员函数count()
需要有条件noexcept
, 和函数 duration_cast
有条件需要做noexcept
.
现在(也只有现在)可以开始处理 time_point
具有类似严谨性的构造函数。
这一切都是可行的。我刚刚制作了它的原型(prototype),以确认我实际上在这个答案中提供了很好的信息。然而,要使这一切成为标准,必须:
迄今为止,委员会已申请有条件的 noexcept
极其节制地发挥作用。
标题中问题的答案很简单:
No one has put all this work into it. However I would encourage people to do so. I believe this would benefit the clients of
<chrono>
.
关于c++ - std::chrono::...::time_point 上的构造函数应该是 noexcept 吗? (或者他们为什么不呢?),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22701617/
考虑: class test { private: int n; int impl () const noexcept { return
#include class A { std::vector vec; void swap( A & other) noexcept(noexcept(vec.swap(other.
在 the C++ standard有如下定义: template void swap(T (&a)[N], T (&b)[N]) noexcept(noexcept(swap(*a,
从 c++20 开始,我们可以使用 consteval 说明符定义立即数函数。当一个函数被声明为 consteval 时,对该函数的每次调用都必须产生一个编译时常量,否则该程序就是病式的。此外,由于
为什么 noexcept 运算符采用表达式而不是函数签名/声明? 考虑以下虚拟示例: #include void strProcessor(const std::string& str) noexc
我有一段通用代码,其性能对我来说很重要,因为我面临着与用 C 编写的著名手工代码的运行时间相匹配的挑战。在开始使用 noexcept 之前,我的代码运行时间为 4.8 秒。通过将 noexcept 放
如果我将函数标记为 noexcept(false),或任何其他计算结果为 false 的表达式,这意味着什么? (1) 我是否向编译器保证该函数可以抛出异常?,(2) 还是我不保证它是否可以抛出异常?
我们遇到过这种情况,想知道解决它的最佳方法 template struct A : T { A(T &&t) noexcept(noexcept(T(std::move(t)))) :T
此代码使用 gcc 4.8.2 (-std=c++11) 编译失败,但使用 clang 3.4 (trunk) (-std=c++11) 编译: #include #include struct
当函数标记为 noexcept 时,GCC 或 Clang 中是否有一个标志会抛出编译时错误(或警告)尝试调用未标记为 noexcept 的函数? 如果不是,那么当您删除 noexcept 时,您应该
假设我有一个类 class C : public B { public: C() noexcept; } noexcept 说明符是否需要基类的相同 promise ?也就是说,当我考虑使
长标题:为什么 std:variant 的 operator=(T&& t) 的 noexcept 规范不依赖于内部类型的析构函数的 noexcept 规范? 我可以在 cppreference 上看
在下面的代码中,我尝试对函数使用条件异常规范,但编译失败,尽管如果在函数外部使用它就可以了。 void may_throw(); // ERROR: expression must have bool
目前在C++这些都不可能,编译器提示它需要一个表达式。 这对我来说似乎微不足道,如果您正在构建一个具有可变数量类型的类似元组的对象,如何检查所有这些类型是否都是 nothrow default/mov
在 The C++ Programming Language 一书中写道,您可以将函数声明为有条件的 noexcept .例如: template void my_fct(T& x) noexcept
根据this question的回答,默认移动构造函数可以定义为 noexcept在一定条件下。例如,下面的类生成一个 noexcept移动构造函数: class C {}; 根据对this ques
拿这个代码: template void my_func() { T::some_method(); } int main() { std::cout ()) ? "noexcept" :
这个声明没问题: void memberFunction(T& functor, double value)noexcept(noexcept(functor(value))); 对于一个 templ
我在思考 noexcept 时遇到了一些麻烦。 template int pop(int idx) noexcept(noexcept(SIZE > 0)) // this is what I do
为什么 std::decay 不从函数指针中移除 noexcept 说明符? 例如这符合 c++17 #include template struct is_noexcept {}; templat
我是一名优秀的程序员,十分优秀!