草庐IT

another_const_ref_t

全部标签

c++ - 为什么 `constexpr const int &a = 1;` 在 block 范围内失败?

N45277.1.5[dcl.constexpr]p9Aconstexprspecifierusedinanobjectdeclarationdeclarestheobjectasconst.Suchanobjectshallhaveliteraltypeandshallbeinitialized.Ifitisinitializedbyaconstructorcall,thatcallshallbeaconstantexpression(5.20).Otherwise,orifaconstexprspecifierisusedinareferencedeclaration,everyf

c++ - lambda 的生命周期在 const lambda 中捕获引用

我有以下API:old_operation(stream,format,varArgs);我想写一个适配器来编写调用如下:stream为此,我使用了一个临时对象,它存储对varArgs的引用并重载operator申请old_operation()如下:templatedecltype(auto)storage(T&&...t){return[&](auto&&f)->decltype(auto){returnstd::forward(f)(t...);};}templateclassOperation{usingStorage=decltype(storage(std::declval

c++ - const 引用的地址可以与引用对象的地址不同吗?

我遇到了等同于以下代码的问题:constauto&const_reference=some_object;assert(&const_reference==&some_object);当我用g++-O3标志编译它时,它没有通过断言。当它在没有优化的情况下编译时,断言通过。据我所知,即使我的项目中有UB,也不应该出现这种情况。在任何情况下,是否存在这种引用行为?编辑:链接到实际代码:https://github.com/Gray0Ed/ggp_thesis/blob/67606021020546b315ad63b7fd5c2203f3e0086f/rule_engine/aligner.

c++ - std::vector::assign/std::vector::operator=(const&) 是否保证重用 `this` 中的缓冲区?

如果我将一个vector分配或复制到另一个vector(其容量与前者的大小相同或更大),我可以假设后者的缓冲区将被重用吗?下面的例子证明我可以,但是,标准保证吗?std::vector::assign和std::vector::operator=在这方面的行为有什么不同吗?#include#include#includeintmain(){std::vectora{1,2,3,4,5};std::vectorb{1,2,3,4};std::vectorc{1,2,3,4,5,6,7,8,9,10};std::coutLiveexample.更新:Thisanswer提到voidassi

c++ - const public 成员有什么问题?

我正在阅读一些代码,其中一个类具有私有(private)const数据成员,然后是一大堆提供对这些数据成员的只读访问的公共(public)方法。这有什么意义呢?为什么不直接公开这些私有(private)数据成员呢?它们是常量,因此根据定义访问是只读的,人们可以通过theClass.theMember而不是theClass.getTheMember()访问它们,后者更容易,另外您可以避免首先创建所有这些公共(public)方法。每个成员变量一个,这意味着O(n)效率低下! 最佳答案 除非访问器方法除了提供引用之外实际上还做了一些事情,

c++ - GCC 模板推导消除 const 错误?

我发现这段代码可以用GCC7.3编译和运行,但不能用clang7编译和运行:conststd::vectorfoo({1,2,3,4});foo.clear();我预计会出现编译器错误,但GCC很乐意清除vector。 最佳答案 这是GCC错误83818;它已通过GCC8修复。不幸的是,那里没有更多信息——唯一的“修复”似乎是不使用类模板参数推导或升级编译器。 关于c++-GCC模板推导消除const错误?,我们在StackOverflow上找到一个类似的问题:

c++ - 带有 const char* 变量的 printf 问题

我陷入了printf问题。如果我能在这里得到一些帮助,我将不胜感激:在下面的代码中,我可以看到字体系列在第一个printf()中被正确置换,但是如果我将它设置为变量,我只会得到一个空字符串。我怎样才能把它放在一个变量中并获得正确的值?我只是不想到处输入“font.family().family().string().utf8().data()”?我用同样的方法做了这个:voidmyMethod(){constchar*fontFamily=font.family().family().string().utf8().data();//getdisplayedcorrectlyprint

c++ - 拥有一个 ref 类型的类成员的目的是什么?

按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭11年前。我有这段代码,但它不是一个实际的例子。例如classAnimal{inti;int&ref;public:Animal():ref(i){}};任何人都可以提供一个现实生活中需要ref作为类(class)成员的例子,以便我更好地理解它吗?

c++ - 关于多线程环境下static const变量的使用

我正在尝试了解潜在的场景以及它是否可能成为问题。所以我有一个当前线程安全的静态函数。函数是这样的:staticthread_safe_func(){...process}现在在此函数中,我添加以下内容:staticthread_safe_func(){staticconstClass::NonThreadSafeClassName()*array[16]={Class::NonThreadSafeClassName(),Class::NonThreadSafeClassName(),Class::NonThreadSafeClassName(),Class::NonThreadSafe

c++ - 统一 const T& 和 T&& 重载

我有以下两个函数模板重载:templateoptionalsome(constT&x){returnoptional(x);}templatetypenamestd::enable_if::value,optional>::typesome(T&&x){returnoptional(std::move(x));}我第一次尝试通过完美转发统一重载失败了:templateoptionalsome(T&&x){returnoptional(std::forward(x));}error:formingpointertoreferencetype'conststd::basic_string&