Cerbo Asked:2020-12-03 22:12:57 +0800 CST2020-12-03 22:12:57 +0800 CST 2020-12-03 22:12:57 +0800 CST 是否从引用 noexcept 中获取指针? 772 是否可以声明noexcept一个从引用接收指针的函数。例如,这个函数: template<typename T> const void * void_pointer(const T & object) noexcept { return &object; } c++ 3 个回答 Voted Best Answer HolyBlackCat 2020-12-03T22:18:55+08:002020-12-03T22:18:55+08:00 是否可以声明noexcept一个函数... 可以做出任何功能noexcept。 函数的要点noexcept是尝试从它们抛出异常会导致std::terminate. 如果您真的想知道地址运算符是否可以抛出异常,答案是否定的,它不能。当然,除非它超载。 αλεχολυτ 2020-12-03T22:17:19+08:002020-12-03T22:17:19+08:00 链接必须指向某个现有对象,因此不能有nullptr地址,我在这里看不到任何问题。除了一个 - 使用&的类型的重载运算符。在这种情况下,您应该使用std::addressof. 如果你点击链接,你可以看到这个函数被声明为noexcept,即 与问题中的基本相同。事实证明,提议表格中的手写模板本身根本不需要。 但是,如果T某些“智能指针”属于该类型(它只有一个用于获取地址的重载运算符)并且您想要获取目标对象的地址,而不是“智能指针”本身,那么您需要使用operator noexcept,这将使模板更加灵活: template<typename T> const void* void_pointer(const T& object) noexcept(noexcept(&object)) { ... 好吧,正如@HolyBlackCat 的回答中所述,它noexcept不会生成无效代码,它只会std::terminate在函数未履行其义务的情况下导致调用。 Andrio Skur 2020-12-03T22:21:02+08:002020-12-03T22:21:02+08:00 不它不是。可以将运算符&重新加载到可以引发异常的用户定义函数中
可以做出任何功能
noexcept
。函数的要点
noexcept
是尝试从它们抛出异常会导致std::terminate
.如果您真的想知道地址运算符是否可以抛出异常,答案是否定的,它不能。当然,除非它超载。
链接必须指向某个现有对象,因此不能有
nullptr
地址,我在这里看不到任何问题。除了一个 - 使用&
的类型的重载运算符。在这种情况下,您应该使用std::addressof
. 如果你点击链接,你可以看到这个函数被声明为noexcept
,即 与问题中的基本相同。事实证明,提议表格中的手写模板本身根本不需要。但是,如果
T
某些“智能指针”属于该类型(它只有一个用于获取地址的重载运算符)并且您想要获取目标对象的地址,而不是“智能指针”本身,那么您需要使用operatornoexcept
,这将使模板更加灵活:好吧,正如@HolyBlackCat 的回答中所述,它
noexcept
不会生成无效代码,它只会std::terminate
在函数未履行其义务的情况下导致调用。不它不是。可以将运算符
&
重新加载到可以引发异常的用户定义函数中