我有以下代码片段:
#include <algorithm>
#include <iostream>
int main(int argc, char** argv) {
int x[2][3];
int y[2][3];
using std::swap;
std::cout << noexcept(swap(x, y)) << "\n";
return 0;
}
使用GCC 4.9.0,这将打印
0
。我不明白为什么。根据标准,
std::swap
有两个重载:namespace std {
template<class T> void swap(T& a, T& b) noexcept(
is_nothrow_move_constructible<T>::value &&
is_nothrow_move_assignable<T>::value
);
template<class T, size_t N>
void swap(T (&a)[N], T (&b)[N]) noexcept(noexcept(swap(*a, *b)));
}
在我看来,noexcept
修饰符对于数组应该递归地适用于多维数组。
为什么交换多维数组不是noexcept
?
在尝试找到一个最小的示例来演示奇怪行为时,我想到了以下内容:
#include <iostream>
template<class T> struct Specialized : std::false_type {};
template<> struct Specialized<int> : std::true_type {};
template<class T> void f(T& a) noexcept(Specialized<T>::value);
template<class T, std::size_t N> void f(T (&a)[N]) noexcept(noexcept(f(*a)));
int main(int argc, char** argv) {
int x, y[1], z[1][1];
std::cout << noexcept(f(x)) << " "
<< noexcept(f(y)) << " "
<< noexcept(f(z)) << "\n";
}
使用GCC 4.9.0编译后,这将打印出
1 1 0
,但我不太理解为什么会这样。
1 1 0
。使用libc++的clang为原始片段打印出0
。 - user3920237std::swap
和std::move
的两个重载函数,并且标记为noexcept。clang和g++对完全相同的库代码有不同的结果,这让我感到困惑。请注意,使用noexceptstd::swap
的代码甚至都不会生成。 - user3920237