草庐IT

gravity_value_t

全部标签

c++ - 输入参数传递 : is there a size threshold for efficient pass-by-value?

在C++中,当输入参数复制成本低时(例如,int、float等),它通常被传递只需按值。相反,复制起来并不便宜的输入“观察到的”参数(例如std::string)由const&传递。我想知道像POD这样的类型表示具有int坐标的二维vector,例如structVec2i{intX;intY;};在32位MSVC编译器上,它只有8个字节(2*sizeof(int))。您会按值还是按const&传递它?那么Vec2d有double类型的坐标呢?(在MSVC上它将是2*sizeof(double),所以2*8=16字节。)是否有“大小阈值”(例如16字节?)用于放置一行并说:“对于超过X大

c++ - 使用 std::move 返回时 "return-by-rvalue-ref"和 "return-by-value"之间的区别?

考虑以下代码:#includeusingnamespacestd;structI{I(I&&rv){coutC包含I。而C::foo()允许您将I移出C。上面使用的成员函数有什么区别:I&&foo(){returnmove(i)};//returnrvalueref和以下替换成员函数:Ifoo(){returnmove(i)};//returnbyvalue对我来说,它们似乎做同样的事情:Ii=c.foo();导致调用I::I(I&&);.本例未涉及的会有什么后果? 最佳答案 撇开您编写的程序是否真正有意义的考虑因素(从数据成员移动

c++ - std::is_constructible<void()>::value 的正确结果是什么?

std::is_constructible::value的结果不一致.我对该标准的解释是它应该是错误的。然而,Clang,同时具有libc++和libstdc++*,给出了true。GCC和MSVC都给出false。哪个结果是正确的?标准语这是标准的N4527[meta.unary.prop]/7:Giventhefollowingfunctiondeclaration:templateadd_rvalue_reference_tcreate()noexcept;thepredicateconditionforatemplatespecializationis_constructibl

c++ - 无论如何有一个 valgrind 消息 "Conditional jump or move depends on uninitialized value"可以是所谓的 'false positive'

我在这里找到的大多数问题都提供一段代码,并由指出实际错误的人回答。我的问题是关于一般未初始化值的条件跳转。我可以理解,如果确定此分配仅完成一次并且在程序的生命周期内可能需要,则不必在程序结束时清理一block内存。据我所知,当程序终止时,GType系统会留下大量未释放的内存。这些未释放的block可以被视为“误报”。但是“有条件的跳跃或移动未初始化的值”会是误报吗?我唯一能想出的是有人通过读取随机地址来实现(坏的)随机函数(其中随机地址本身是棘手的部分;)。另一个例子可能是硬件映射到内存的一部分然后被读取,但这主要是由驱动程序而不是由普通用户应用程序完成的。是否有任何其他示例(最好是C

c++ - Lambda 捕获列表 : capturing object's member field by value not possible without capturing the whole object?

下面的代码voidCMainWindow::someMethod(constCLocationsCollection&parentItem){autof=[this,parentItem.displayName](){};}给我一​​个错误:errorC2143:syntaxerror:missing']'before'.'如果我想通过ref捕获parentItem.displayName,我会为它创建一个非依赖别名标识符:constQString&name=parentItem.displayName;autof=[this,&name](){};//Orshoulditbe[thi

C++/Boost 文件系统 - 检测到 '_MSC_VER' 不匹配 : value '1700' doesn't match value '1600'

我是C++和Boost的新手。我正在做一个简单的小程序来尝试学习BoostFilesystem库。我已经按照说明构建了Boost库。现在,当我尝试编译这个简单的代码时,我遇到了其中的6个错误。Error5errorLNK2038:mismatchdetectedfor'_MSC_VER':value'1700'doesn'tmatchvalue'1600'inApp.objC:\SOURCE\ConsoleApp2\ConsoleApp2\libboost_filesystem-vc110-mt-gd-1_51.lib(codecvt_error_category.obj)Consol

c++ - 当将 `key/value` 插入到 `std::map` 时,它会制作自己的对象拷贝吗?

这受到EffectiveC#第一版中的一个项目的启发,警告不要天真地覆盖GetHashCode()。抱歉,我没有支持代码。顺便说一下,这不是作业,我只是不太熟悉C++/STL,也找不到有关实现的信息。假设我创建了自己的名为person的类,它有3个公共(public)可变字符串字段:名字,中间名缩写姓氏它还提供了一个小于运算符来比较一个人与另一个人,首先是名字,然后是中间名,然后是姓氏-仅此而已。我创建了一个从人到整数(比如年龄)的映射,并用大约20个键/值对填充它。我还将指向我的键的指针存储在一个数组中。然后我更改第五个指针指向的对象的名字,并尝试使用这个修改后的键查找相应的年龄(记

c++ - 初始化全局 <Key, Value> 哈希

我想将QHash初始化为全局变量。因为它是全局性的,所以我不能写类似的东西QHashMY_HASH;MY_HASH["one"]=1;MY_HASH["two"]=2;但我不确定如何在初始化时为MY_HASH赋值。 最佳答案 如果你使用c++0x,你可以使用一个initializer_list,它看起来像这样:QHashMY_HASH({{"one",1},{"two",2}});在gcc中,使用命令行标志-std=c++0x启用c++0x 关于c++-初始化全局哈希,我们在StackO

c++ - gcc 无效版本(最大)错误添加符号 : Bad value

我已经在Linuxx86_x64上成功地构建了几个32位的静态和共享库,现在我试图将它们链接到一个可执行文件中,但我收到以下错误:/usr/bin/ld:foo.so:__moddi3:invalidversion21(max0)foo.so:erroraddingsymbols:Badvaluecollect2:error:ldreturned1exitstatus其中foo.so是我构建的共享库之一。__moddi3函数是libgccIntegerLibraryRoutines的一部分.它的签名是:—RuntimeFunction:long__moddi3(longa,longb)

c++ - LLVM 字符串值对象 : How can I retrieve the String from a Value?

当从现有的AST构建IR时,我的AST有一些字符串值(在编译时它们是从std::string构建的)并且我想将它们安全地设置为llvm::Value用作表达式的一部分。在这种情况下,我不需要在运行时绑定(bind)字符串,因为字符串值仅用于在编译时将内容解析为变量、函数或类(该语言不支持native字符串类型)。什么是将我的字符串内容保持为llvm::Value并且仍然能够在编译的后期阶段检索它的最佳方法(当构建嵌套表达式时)?更具体地说,如果我将llvm::Value设置为:llvm::Value*v=llvm::ConstantArray::get(llvmContext,mySt