草庐IT

const修饰符的增加

全部标签

c++ - 对 'cv::viz::Viz3d::Viz3d(std::string&const)' 的 undefined reference

我已经使用qtcreator运行了我的opencv代码,当我尝试使用Viz库时得到了这个答案。代码:#include#include#include#include#include///Createawindowviz::Viz3dmyWindow("VizDemo");///StarteventloopmyWindow.spin();///Eventloopisoverwhenpressedq,Q,e,Eprintf("Firsteventloopisover\n");///Accesswindowviaitsnameviz::Viz3dsameWindow=viz::getWind

c++ - 按值或 const 引用传递函数?

我应该按值还是按对一个函数的引用来传递std::string。此函数将此值存储在类的成员变量中。当谈到值传递或引用传递时,我总是感到困惑。请消除我对此的困惑。代码如下:classDataStore{public:voidaddFile(conststring&filename,constset&filePaths){if(dataStoreMap.insert(make_pair(filename,filePaths)).second){cout>dataStoreMap;};我应该像这样声明函数吗:voidaddFile(conststring&filename,constset&f

c++ - 为什么 const 类成员必须是静态的才能得到适当的优化?

给定:classFoo{constintx=5;public:inlineintget(){returnx;}};classBar{staticconstintx=5;public:inlineintget(){returnx;}};intfn0(Foo&f){returnf.get();}intfn1(Bar&b){returnb.get();}编译后的输出提供内存获取以读取fn0()中x的值,而添加static结果是文字5被内联到fn1()中。这意味着只有当整数常量为静态时,get()的调用方才可以像使用常量代替get()一样进行优化。我有更复杂的情况,其中static不合适。派生

c++ - MPI - 随着进程数量的增加没有加速

我正在编写程序来测试数字是否为素数。一开始我计算分配给每个进程的数字,然后将这个数量发送给进程。接下来,执行计算并将数据发送回保存结果的进程0。下面的代码有效,但是当我增加进程数时,我的程序不会加速。在我看来,我的程序不能并行运行。怎么了?这是我在MPI的第一个项目,因此欢迎任何建议。我使用mpich2,并在IntelCorei7-950上测试我的程序。主要.cpp:if(rank==0){intworkers=(size-1);readFromFile(path);intelements_per_proc=(N+(workers-1))/workers;intrest=N%eleme

c++ - 自动转换模板<T>到模板<const T>

下面的这段应该主要用于T={char,constchar}的字符串View是主要的预期模板实例化目标。cmp函数应该类似于strcmp来比较View。.问题是虽然char*愉快地转换为constchar*我不知道如何获得SVec转换为SVec一样开心。最后一行(cout)无法编译。我必须明确地进行转换(cmp(SVec(rv),rvc))。它可以像char*一样自动吗?至constchar*?代码(大大简化):templateclassSVec{protected:T*begin_;size_tsize_;public:SVec(T*begin,size_tsize):begin_(b

c++ - 为什么 static const char * template struct 成员没有初始化

我有一些C++11模板代码,我正在尝试移植到VisualC++Compiler2015。原始代码工作得很好,但是我需要重写它以解决constexpr的问题。Theoriginalcode(simplifiedexample)#includestructString{staticconstexprconstchar*value{"STRING"};};templateclassDerived{public:staticconstexprconstchar*value{Base::value};};templatestructFoo{staticconstexprconstchar*val

c++ - 类型的模板特化和 const 限定符

为什么编译器期望模板在(具体)类型上单独特化T和constT?让我举个例子。我有一个由类类型键控的无序映射Keystd::unordered_mapdata;要编译它必须专门化std::hash在类型上Key作为namespacestd{templateclasshash{/*implementation*/};}但是,当我将map类型更改为std::unordered_mapdata;编译器没有使用我的特化,而是选择了通用的std::hash,这只不过是一个编译时断言,直到我专门化std::hash.撇开使用const限定映射键类型的实用程序,为什么不constT折叠到T在寻找这种情

c++ - 期望 const std::string & 的函数的链接器错误

尝试链接共享库(gtkmm)时,我收到其签名包含std::stringconst&的函数的链接器错误。例如,如果函数声明为voidset_icon_from_file(conststd::string&);g++报告undefinedreferenceto`Gtk::Window::set_icon_from_file(std::stringconst&)'我正在使用pkg-config中的链接器标志,而其他函数(例如,将基本类型作为参数的函数)不会发生这种情况,因此我怀疑链接器配置正确。readelf我的目标文件给了我45:00000000000000000NOTYPEGLOBALD

c++ - const 应该用于捕获错误还是用于文档?

假设我有一个不可变类C。从用户的角度来看,我们永远无法更改任何C对象的功能行为。但是,出于性能原因,假设我们有一个toString方法可以将对象转换为字符串并返回它。我不想每次都做这个计算,所以我将结果存储在一个成员变量中,这样如果用户再次调用toString,它会很快。我是否使toString函数成为const(并且只使用const_cast来存储结果),因为只要我们将接口(interface)与实现,toString应该被视为不修改对象,或者我应该将它设为非常量,因为它会帮助编译器捕获错误? 最佳答案 拥有const对象的要点是

c++ - 混合函数 - 增加 float

我正在浏览代码库并找到以下模板函数:templateTmix(constT&a,constT&b,constT2&interp){staticconstexprT2one=((T2)1);return(a*(one-interp))+(b*interp);}和下面的评论//You'dthinkinsteadofdoingthea*(1-t)+b*t,it'dbefaster//andonelessmultiplytodoa+(b-a)*t,right?Bad!Increasesfloating//pointexceptionoccurances.SameasLERP有人可以强调为什么这