我有一个经过模板化的函数,我想static_assert
它的类型有一个3的大小。这段代码说明了我想要做的事情,但不起作用:
template < typename T >
void foo( T& param )
{
// This line is the one that I need to figure out how to write
static_assert( 3 == std::extent< T >::value, "param must have a size of 3" );
}
int main( void )
{
int cArray[3];
std::array< int, 3 > stdArray;
foo( cArray );
foo( stdArray );
}
发布于 2014-03-28 14:06:40
这建立在艾弗尔的解决方案之上。
template < typename T >
void foo( T& param )
{
static_assert( 3 == ( std::is_array< T >::value ? std::extent< T >::value : std::tuple_size< T >::value ), "param must have a size of 3" );
}
发布于 2014-03-28 12:43:55
std::extent
是为内置数组定义的.对于std::array
,使用std::tuple_size
代替。我不知道两者都适用的一些特性,但写一个很容易:
template<typename T>
struct array_size : std::extent<T> { };
template<typename T, size_t N>
struct array_size<std::array<T,N> > : std::tuple_size<std::array<T,N> > { };
下面是您的foo
,更正/概括(实例化):
template < typename T >
void foo( T&& param )
{
using U = typename std::remove_cv<typename std::remove_reference<T>::type>::type;
static_assert( 3 == array_size<U>::value, "param must have a size of 3" );
}
首选通用引用T&& param
,否则只能使用lvalue。
发布于 2014-03-28 12:50:53
我想不出有一种方法可以同时处理这两种情况,但这就是重载的目的。
template <std::size_t N, typename T, std::size_t Bound>
void check_array_size( T (&)[Bound] )
{
static_assert(Bound == N, "incorrect array size");
}
template <std::size_t N, typename T, std::size_t Bound>
void check_array_size( const std::array<T,Bound>& )
{
static_assert(Bound == N, "incorrect array size");
}
template <std::size_t N>
void check_array_size( ... )
{
static_assert(N<0, "argument is not an array");
}
template <typename T>
void foo(T& param)
{
check_array_size<3>(param);
// actual function implementation...
}
https://stackoverflow.com/questions/22712965
复制相似问题