草庐IT

thread_no

全部标签

c++ - 连接到共享库时 cmake 中出现 "No rule to make target"错误

在Ubuntu中,我下载了一个第三方共享库,mylibrary.so,我将其放在目录/home/karnivaurus/Libraries中。我还将关联的头文件myheader.h放在目录/home/karnivaurus/Headers中。我现在想使用CMake在我的C++代码中链接到这个库。这是我的CMakeLists.txt文件:cmake_minimum_required(VERSION2.0.0)project(DemoProject)include_directories(/home/karnivaurus/Headers)add_executable(demodemo.c

c++ - C++ 程序末尾的 thread_local vector 段错误

我正在尝试制作一个多线程程序,但在线程局部vector方面遇到了一个奇怪的问题。这是(精简到只有错误)代码:#include#includethread_localstd::vectorvec;intmain(){vec.push_back(3);std::cout程序编译正常,运行基本正常,但在我按回车键后,我收到“程序已停止工作”消息。我在gdb中运行它并得到了这个错误:ProgramreceivedsignalSIGSEGV,Segmentationfault.0x004030b0instd::vector>::~vector()()不知何故,vector的析构函数中存在错误。使

c++ - std::condition_variable::wait_until 相对于 std::this_thread::sleep_for 有什么优势吗?

在时间等待场景中:oursoftwareworksinthebackground,andsynchronizesdatawiththeserverinevery20-30minutes.我想用std::this_thread::sleep_for但我的上级强烈反对任何形式的sleep功能。他推荐std::condition_variable::wait_until(lock,timeout-time,pred)不知道在这种情况下sleep_for有什么缺点吗? 最佳答案 正如评论中已经指出的那样,这仅取决于您的用例。两者之间的主要区

c++ - 调试boost::thread应用,误报率高

我编写了一个boost::thread应用程序,其中可能存在一些竞争条件。我想调试这个程序。因此,我使用了以下valgrind工具:哈尔格林德博士不幸的是,他们的误报率非常高。因此,使用下面的非常简单的程序valgrind--tool=drd会提示94个错误,而本不该出现的错误。因此,在我的复杂程序中,我得到了大约15000个错误。所以很难找到真正的错误。我可以使用以下boost库1.46.0和1.47.0重现此行为。以及valgrind3.7.0SVN和valgrind3.8.0SVN。我试用的操作系统是Ubuntu11.10和MacOSX10.7。gcc4.2.1和gcc4.6.1

c++ - 使用来自matlab的boost::threads时挂起和/或segfault,而不是直接调用时

问题出在人们有类似问题的情况下:经过与Mathworks支持的一些讨论之后,原来是系统boost和Matlab附带的boost库之间的冲突:当我使用systemboostheader进行编译并与(较旧)的MatlabBoost库,它已分段。当我编译并与系统boost动态链接时,然后它动态加载Matlabboost库时,它将永远挂起。静态链接到系统boost的工作原理,以及为Matlab随附的boost版本下载正确的header并进行编译时也是如此。当然,Mac版本的Matlab的文件名中没有版本号,尽管Linux和据说的Windows版本都有。R2011b使用boost1.44作为引用

c++ - 视觉 C++ : No devirtualization in obvious cases?

在看visualc++(VS2017RC)生成的代码看到简单情况下的动态分支(虚拟调用)时,我感到非常惊讶。所以我用编译器资源管理器尝试了以下代码:structBase{virtualvoidfoo()=0;};structImpl:Base{voidfoo()override;};Implg_impl;voidglobalCall(){g_impl.foo();}voidlocalCall(){Impli;i.foo();}voidtempCall(){Impl().foo();//dynamicbranchinggenerated!}structClass{voidmemberCa

c++ - 为什么在 C++0x 或 Boost.Thread 中没有针对多个互斥锁的作用域锁?

C++0x线程库或Boost.thread定义非成员变量模板函数,锁定所有锁避免死锁。templatevoidlock(L1&,L2&,L3&...);虽然此功能有助于避免死锁,但标准不包括用于编写异常安全代码的关联作用域锁。{std::lock(l1,l2);//dosomething//unlocklil2exceptionsafe}这意味着我们需要使用其他机制作为try-catchblock来制作异常安全的代码,或者我们自己在多个互斥锁上定义我们自己的作用域锁,甚至这样做{std::lock(l1,l2);std::unique_locklk1(l1,std::adopted);

c++ - 如何用 "-pthread"而不是 "-mthread"编译 boost_thread?

我有一个操作系统,编译时没有可用的-mthread。我有-pthread。如何用-pthread而不是-mthread编译boost_thread?我当前的编译器构建日志:./b2-j1--with-threadlink=static--prefix=./install-dirreleasethreading=multi--builddir=./build-dirinstallComponentconfiguration:-chrono:notbuilding-context:notbuilding-date_time:notbuilding-exception:notbuilding

c++ - 替代 std::this_thread::sleep_for()

我有一个循环,我想确保它在每个循环中运行(大约)固定的时间量。我正在使用sleep_for来实现此行为,但我也希望程序能够在不完全支持标准线程库的环境中编译。现在我有这样的东西:usingnamespacestd;usingnamespacestd::chrono;//while(!quit){steady_clock::time_pointthen=steady_clock::now();//...doloopstuffsteady_clock::time_pointnow=steady_clock::now();#ifdefNOTHREADS//versionforsystemsw

「SQL面试题库」 No_47 买下所有产品的客户

🍅1、专栏介绍「SQL面试题库」是由不是西红柿发起,全员免费参与的SQL学习活动。我每天发布1道SQL面试真题,从简单到困难,涵盖所有SQL知识点,我敢保证只要做完这100道题,不仅能轻松搞定面试,代码能力和工作效率也会有明显提升。1.1活动流程整理题目:西红柿每天无论刮风下雨,保证在8am前,更新一道新鲜SQL面试真题。粉丝打卡:粉丝们可在评论区写上解题思路,或者直接完成SQL代码,有困难的小伙伴不要着急,先看别人是怎么解题的,边看边学,不懂就问我。交流讨论:为了方便交流讨论,可进入数据仓库。活动奖励:我每天都会看评论区和群里的内容,对于积极学习和热心解答问题的小伙伴,红包鼓励,以营造更好的