VS2015中,{1,2,3}能转换成constexpr std::initializer_list吗?

发布于 2022-09-04 10:28:01 字数 594 浏览 18 评论 0

我看到vs2015中的std::initializer_list已经声明成constexpr了。
那么

template<class T>
constexpr bool assert_elementof(std::initializer_list<T> v, int N)
{
    //static_assert(N == v.size(),"xxx");
    return N == v.size();
}

int main()
{
    constexpr int v[] = { 1,2,3 };
    static_assert(assert_elementof<int>(std::initializer_list<int>(v, v + sizeof(v) / sizeof(v[0])), 3), "eee");
    //static_assert(assert_elementof<int>({ 1,2,3 }, 3), "eee");
    return 0;
}

我的是问题,为什么上面两处注释掉的代码不能在VS2015下编译通过?是我的代码有问题呢,还是VS2015的问题。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

笙痞 2022-09-11 10:28:01

关于

static_assert(assert_elementof<int>({ 1,2,3 }, 3), "eee");

由于static_assert的第一个参数必须是一个const表达式,对于constexpr bool assert_elementof(std::initializer_list<T> v, int N),只有当两个参数都是const的时候,他的返回值才是const。所以两个参数{ 1,2,3 }, 3都是常量,所以这一段没有问题。

关于

template<class T>
constexpr bool assert_elementof(std::initializer_list<T> v, int N)
{
    //static_assert(N == v.size(),"xxx");
    return N == v.size();
}

去掉那个注释为什么就不行了,因为N是一个变量,不是一个常量表达式,所以违反static_assert的要求:第一个参数必须是一个const表达式。

c++ primer里面有一段摘录如下:

constexpr int scale(int N) {return N * 2; }

int main()
{
    int arr[scale(2)];
    int i = 2;
    int arr2[scale(i)];//这里应该会报错,虽然G++不报错。
    return 0;
}

不报错的原因参考这里

偏爱你一生 2022-09-11 10:28:01

应该没问题,记得加头文件

#include <initializer_list>
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文