草庐IT

const_buffers

全部标签

c++ - float 的类内静态 const 初始化与 C++ 中的 int 有何不同?

我有一个包含staticconst成员的类,我正在类声明中对其进行初始化:#includeclassFoo{public:staticconstinti=9;staticconstfloatf=2.9999;};intmain(){std::cout当使用带有选项--std=c++11的GCC4.8.2编译时,它给出了这个编译错误:foo.cpp:7:32:error:‘constexpr’neededforin-classinitializationofstaticdatamember‘constfloatFoo::f’ofnon-integraltype[-fpermissive]

c++ - 我不明白在下面的代码中将 char buffer[] 与 X 类型的对象对齐的原因

Stroustrup在他的新书第151页中展示了以下使用类型说明符alignas的示例:Sometimes,wehavetousealignmentinadeclaration,whereanexpression,suchasalignof(x+y)isnotallowed.Instead,wecanusethetypespecifieralignas:alignas(T)means"alignjustlikeaT."Forexample,wecansetasideuninitializedstorageforsometypeXlikethis:voiduser(constvector

c++ - 模板中右值引用和 const 左值引用之间的重载

我想根据参数是否为临时对象来重载两个函数,所以我这样写代码:#includevoidf(int&&){std::cout它正确地输出:const&&&但是,当我更改代码以使用这样的模板时:#includetemplatevoidf(T&&){std::coutvoidf(constT&){std::cout输出变为:&&&&有什么问题?使用模板时如何针对可移动的临时对象进行优化?编辑:其实这是我看C++Primer时的测试代码。它说:templatevoidf(T&&);//bindstononconstrvaluestemplatevoidf(constT&);//lvaluesan

c++ - 访问 Protocol Buffer 扩展字段

我正在使用C++中的ProtocolBuffer。我的消息只有一个扩展范围。我想在不知道他们的名字的情况下访问所有的扩展字段,只使用他们的号码。我该怎么做??messageBase{optionalint32id=1;extensions1000to1999;}extendBase{optionalint32id2=1000;}到目前为止,我已经获得了ExtensionRange。constgoogle::protobuf::Descriptor::ExtensionRange*rng=desc->extension_range(0);std::cerrstartend但我不知道如何获

c++ - 重载解析和指向 const 的共享指针

我正在将大型代码转换为使用自定义共享指针而不是原始指针。我在重载解析方面有问题。考虑这个例子:#includestructA{};structB:publicA{};voidf(constA*){std::cout此代码正确写入“非常量版本”,因为qualificationconversions在隐式转换序列的排名中发挥作用。现在看一下使用shared_ptr的版本:#include#includestructA{};structB:publicA{};voidf(std::shared_ptr){std::cout){std::coutb;f(b);}此代码无法编译,因为函数调用不明

c++ - std::clamp - 检测函数返回值是否绑定(bind)到 const T&

最好不要将std::clamp返回值绑定(bind)到constref,如果它的min或max参数之一是右值.std::clamp的典型实现(非常简化):templateconstexprconstT&clamp(constT&value,constT&min,constT&max){returnvalue正如cppreferenceforstd::clamp中所述当有人写下时,情况很危险:intn=-1;constint&r=std::clamp(n,0,255);//risdangling有没有办法在编译时检测这些情况? 最佳答案

c++ - JNI_CreateJavaVM : Buffer overrun if I throw an exception in case of failure

在C++项目中,我使用JNI调用API来启动JVM。我已经围绕JVM做了一些包装,因此我可以以面向对象的方式使用所有需要的部分。到目前为止效果很好。现在,如果JVM没有启动(JNI_CreateJavaVM返回值JNI_CreateJavaVM之后抛出异常,我遇到缓冲区溢出。如果我在没有JNI_CreateJavaVM调用的情况下引发异常,它会按预期工作。有人知道这里的问题是什么吗?或者如何调试?环境:Windows、VisualStudio2008JDK:jrockit27.6jdk16005,但也发生在SUNstockone上干杯多米尼克 最佳答案

c++ - const 元素数组的类型

标准中是否规定常量元素数组与非常量元素数组的类型不同?这是我的代码和VC2010和GCC4.8.0的输出。谢谢。#include#include#includeintmain(){intarr_a[]={1,2};intconstarr_b[]={3,4};//orconstintarr_b[]={3,4};std::cout 最佳答案 C++11标准实际上说(3.9.3/1)(强调我的)[...]Thecv-qualifiedorcv-unqualifiedversionsofatypearedistincttypes;howev

c++ - 在实现 iterator 和 const_iterator 类时避免代码重复的最佳实践

关闭。这个问题需要更多focused.它目前不接受答案。想改进这个问题吗?更新问题,使其只关注一个问题editingthispost.关闭6年前。Improvethisquestion在实现诸如iterator和const_iterator或类似的类对时,避免代码重复的最佳实践是什么?人们是否通常使用大量const_casts根据const_iterator来实现迭代器?是否使用了某种特征类并最终将iterator和const_iterator定义为通用模板的不同实例?这似乎是一个足够普遍的问题,需要一个规范的解决方案,但我没有找到任何专门针对该问题的文章。

c++ - 我应该返回 gsl::span<const T> 而不是 const std::vector<T>&

我有一个带有std::vector成员的类和一个返回对该vector的const引用的成员函数。classdemo{public://...conststd::vector&test()const{returniv;}private:std::vectoriv;};我计划将成员类型更改为不同的数组,如具有足够功能和较小内存占用的容器类型(例如std::experimental::dynarray、std::unique_ptr)。因此,我认为最好不要将真正的容器作为const引用返回,而是将View作为gsl::span返回给元素。classdemo{public://...gsl::