草庐IT

static-initializer

全部标签

c++ - “Default member initializer needed within definition of enclosing class outside of member functions” - 我的代码格式不正确吗?

structfoo{structbar{~bar(){}//noerrorw/othisline};bar*data=nullptr;//noerrorw/othislinefoo()noexcept=default;//noerrorw/othisline};是的,我知道,还有一个题目完全相同,但有点不同的问题(涉及noexceptoperator和没有嵌套类型)。那里建议的解决方案(将foo的构造函数替换为foo()noexcept{})改变了语义,这里没有必要:这里我们有一个更好的答案(因此问题不是重复的)。编译器:AppleLLVM版本9.0.0(clang-900.0.37)

c++ - 仅在实例化时使用 `static_assert` 使类模板特化无法编译的安全、符合标准的方法?

假设我们想要制作一个模板类,它只能用数字实例化,否则不能编译。我的尝试:#includetemplatestructOnlyNumbers{public:structC{};static_assert(std::is_same::value,"Tisnotarithmetictype.");//OnlyNumbers*ptr;};templatestructOnlyNumbers>>{};structFoo{};intmain(){OnlyNumbers{};//Compiles//OnlyNumbers{};//Error}Livedemo-所有三个主要编译器似乎都按预期工作。我知道

c++ - 使用 C++11 initializer_list 实现类 std::array 容器

std::array唯一和imo非常不方便的警告是它不能像内置C数组一样从初始化列表中推断出它的大小,它的大小必须作为模板传递.是否可以使用C++11initializer_list实现类似std::array的容器(围绕内置C数组的薄包装器)?我问是因为,与std::array不同,它会自动从初始化列表中推导出数组的大小,这要方便得多。例如://il_arrayisthehypotheticalcontainer//automaticallydeducesitssizefromtheinitalizerlistil_arraymyarr={2,4,6,7,8};如果没有提供初始化列表

c++ - 二元运算符声明的“static”关键字

在C++中,当LHS是被声明的类时,二元运算符可以被一个或两个运算符覆盖。如果用两个参数声明,则必须是非成员函数。在此代码中,两个声明是相同的。classMyClass{public:MyClassoperator+(constMyClass&);}MyClassoperator+(constMyClass&,constMyClass&);有没有理由不能将后者作为静态成员函数来完成?像这样classMyClass{public:staticMyClassoperator+(constMyClass&,constMyClass&);}这将使编写流输入/输出运算符更容易(我知道您可以使用f

c++ - 空括号调用默认构造函数还是采用 std::initializer_list 的构造函数?

以下引自EffectiveModernC++(第55页):"Supposethatyouuseanemptysetofbracestoconstructanobjectthatsupportsdefaultconstructorandalsosupportsstd::initializer_listconstruction.Whatdoyouremptybracesmean?etc.Theruleisthatyougetdefaultconstruction."我用std::array试过这个:std::arrayarr{};并收到来自g++(版本4.8.2)的警告:warning:m

c++ - std::make_unique(以及 emplace、emplace_back)对 initializer_list 参数的笨拙推导

假设我有这个结构:structposition{intx,y;};和另一个将this作为构造函数参数的类:classpositioned{public:positioned(positionp):pos(p){}private:positionpos;};我怎样才能得到简单的autobla=std::make_unique({1,2});上类?目前,编译器试图通过initializer_list匹配并调用make_unique的数组变体,这很愚蠢,因为positioned只有一个构造函数。emplace出现同样的问题和emplace_back功能。几乎所有将其可变模板参数转发给类的构造

c++ - std::initializer_list 和 c array [] 的优缺点是什么?

假设我有一些假设结构:structX{inti;doubled;}然后我可以写constexprXx_c_array[]{{5,6.3}};或constexprstd::initializer_listx_ilist{{5,6.3}};使用auto是不可能的-编译器必须知道内部类型。这两个版本都有缺点吗?更新:同样值得关注的是,您是否能够使用/将一种类型转换为另一种类型-例如。什么时候构建标准容器? 最佳答案 简单明了:initializer_list不是容器。它是对外部分配元素的不可变View。它完全不适合容器有用的任何场景——考

c++ - consteval 会允许在函数参数上使用 static_assert 吗?

目前您不能使用static_assert来验证constexpr函数的参数,即使对它的所有调用确实都是constexpr。这是有道理的,因为编译器仍然必须创建此函数的非constexpr实例,以防其他模块尝试调用它。遗憾的是,即使函数是static或在匿名命名空间中也是如此。但是,C++20将引入一个新关键字consteval,它类似于constexpr,但它不允许以非constexpr方式调用函数。在这种情况下,编译器可以确定函数参数在编译时总是已知的。因此,理论上应该可以使用static_assert来验证它们。问题是:标准允许吗?例子:#includeconstevalcharo

C++11 static_assert : Parameterized error messages

在mypreviousquestion我想使用static_assert将模板参数限制为特定的子类型。问题回答完毕,归档代码如下:templatestructX{static_assert(std::is_base_of::value,"TmustbederivedfromY!");};现在,我想让错误信息更简洁。即,我想说明哪种类型违反了此约束。例如,如果类A不是来自Y有人实例化了X,则错误消息应打印“类型参数必须从Y派生,但A不是”。这是否可以通过标准库以某种方式实现?我看到两个挑战:在编译时不使用boost::mpl组装字符串检索实例化T的类型的名称。该名称应该有意义,最好与违规

Docker Desktop 安装与无法运行(Docker Desktop failed to initialize)的诊断

1.DockerDesktop安装i.安装WSL首先要安装WSL,docker现在依赖于WSL才能在Windows上运行可以参照微软的官方教程https://docs.microsoft.com/en-us/windows/wsl/install注意WSL2是必须的,所以upgradeversion拿一本分不能跳过哈如果在安装WSL的过程中遇到了问题,可以参考我的另一篇文章https://blog.csdn.net/Antarctic_Bear/article/details/123489609ii.安装DockerDesktop理论上按照官方教程安装就可以了,第一次安装一般不会有什么问题的h