草庐IT

function-call-operator

全部标签

c++ - Qt 信号槽 : Signal is sent but Slot is not called

我在C++的VisualStudio2013中使用Qt。我正在尝试将信号连接到插槽。问题是信号已发送,但槽函数从未被调用,我不知道发生了什么。这段代码之前可以工作,但是在我将代码从32位的VisualStudio2012迁移到64位的VisualStudio2013并进行一些更改后,它不再工作了。它打印调试语句:发送前、发送图像和连接,但不打印接收到的图像。有人可以帮忙吗?Streamer.hsignals://SignaltooutputframetobedisplayedvoidprocessedImageStream(constvector&imgs,constQImage&im

c++ - C++ 中的 __builtin__functions 有什么用?

我正在调试一个对性能敏感的事务处理系统。我找到了一个使用__builtin_memcpy和__builtin_memset而不是memcpy和memset的代码。__builtin_functions有什么用?,以防止对体系结构或编译器的依赖性问题?或者..__builtin_functions更受欢迎是否有任何性能原因?谢谢你:D 最佳答案 传统的库函数,标准的memcpy只是对一个函数的调用。不幸的是,memcpy通常会为每个小拷贝调用,调用函数、打乱几个字节并返回的开销是相当大的开销(特别是因为memcpy添加了在函数的开头添

c++ - c++ operator |= atomic 是多核处理器吗?

我目前正在与另一位开发人员争论,他向我保证以下c++语句是原子的:x|=0x1;//xissharedbymultiplethreads在Release模式下用VC++11编译生成以下程序集:01121270ordwordptrds:[1124430h],1另一个开发者说位操作是原子的,因此是线程安全的。我对英特尔i7处理器的体验与此相反。我认为对于多核处理器,任何共享内存写入都是不安全的,因为有单独的处理器缓存。但经过更多研究后,似乎x86处理器提供了一些与处理器/内核之间的内存操作顺序相关的保证,这表明它应该是安全的......同样,这不是根据我的经验,情况似乎是这样。由于我没有关

c++ - 通过 operator[] 访问静态成员 unordered_map

作为C++的新手,我遇到了一些我不太理解的行为,并且即使通过大量谷歌搜索也无法找到解释,所以我希望有人能解释这里到底出了什么问题。//test.h#includetypedefstd::unordered_maptest_type;classtest{public:staticconsttest_typetmap;};//test.cpp#include"test.h"consttest_typetest::tmap={{1,1}};//main.cpp#include"test.h"intmain(){//Attempt1:accesskeyviaoperator[]std::cou

c++ - operator[] for std::map 什么情况下可以返回0?

我正在使用LLVM,但我遇到了以下我没有编写的代码段的问题:staticstd::mapNamedValues;...//LotsofothercodeValue*V=NamedValues["Demostring"];returnV?V:ErrorV("VisnotinNamedValuesmap.");根据我对std::map的理解,它永远不应该返回空指针(除非它内存不足?),所以我很难理解V为0如何表示V不在映射中。照原样,我的程序总是在这里出错,但我不明白为什么。对这里发生的事情有什么帮助吗? 最佳答案 std::map::

C++ 为什么当它们 100% 看起来匹配时会出现错误 "no matching function"?

我不明白为什么我会收到一条错误消息,指出我的函数与我定义的模板函数不匹配。在我看来,它们看起来完全一样。这是我调试中的错误:错误:没有匹配函数来调用'mergesort'newVec=mergesort(vec.begin(),vec.end());所以我可以学习和编写更好的通用函数和模板,我需要更改什么才能消除该错误?(需要说明的是,我并不是在寻求有关我的归并排序算法的帮助-我知道它有问题,但我会解决它们。)#include#includeusingnamespacestd;templatevectormergesort(typenamevector::iterator,typena

c++ - std::functions 和 lambda 函数传递

我有一个将std::function作为参数的类,我分配了一个lambda函数。它在构造函数中工作,但之后停止工作。调试器在运行第一行后说f是“空的”。为什么?#include#include#includetypedefstd::functionconst&fn;classTestClass{public:TestClass(fn_f):f(_f){F();}voidF(){f("hello");};private:fnf;};intmain(){TestClasst([](std::stringstr){std::cout调用t.F()会导致错误。为什么?我可以通过将其更改为以下内

c++ - 用于收集可调用对象的 std::function 的替代方法

除了求助于std::function之外,还有其他方法可以存储可调用对象的同类集合吗?即,替换以下代码中的类型TusingT=std::function;std::vectorv{some_lambda,some_fn_ptr,some_pmf,some_functor};还有别的吗?当将单个可调用对象作为参数传递给高阶函数时,我尽可能使用模板来避免std::function的开销。但是对于收藏,我不知道有什么可以做的。 最佳答案 直接类型减少开销的最大来源是内联函数的能力。在重复应用的紧密循环中,有时可以对内联函数进行矢量化或以其

c++ - 右值引用绑定(bind)到 std::function 类型的左值

为什么下面的代码在(@)处没有编译错误?我认为lamb是左值,因此它不会绑定(bind)到右值引用。usingFunctionType=std::function;usingIntType=int;structFoo{voidbar(FunctionType&&){}voidbaz(IntType&&){}};Foofoo;foo.bar([](){});//OKautolamb=[](){};foo.bar(lamb);//(@)Nocompilationerror?!foo.baz(5);//OKinti=5;foo.baz(i);//Error 最佳答

c++ - 重载 operator= 中断 std::sort

可能是个骗子,但我找不到。在用双节棍敲打我的键盘两天后,我发现重载等号运算符(operator=)显然会破坏std::sort。也许我错误地重载了operator=?这是我的MCVE:#include#include#include#include#include#includestructPerson{std::stringname;uint32_tage;booloperatorage&people){std::coutpeople={{"james",12},{"jada",4},{"max",44},{"bart",7}};PrintPeople(people);std::so