草庐IT

conditional-compilation

全部标签

c++ - 错误 : uint64_t was not declared in this scope when compiling C++ program

我正在尝试一个简单的程序来打印steady_clock的时间戳值,如下所示:#include#includeusingnamespacestd;intmain(){cout(steady_clock::now().time_since_epoch()).count();cout但是每当我像这样编译时g++-oabcabc.cpp,我总是会遇到错误:Infileincludedfrom/usr/include/c++/4.6/chrono:35:0,fromabc.cpp:2:/usr/include/c++/4.6/bits/c++0x_warning.h:32:2:error:#er

c++ - 将 std::condition_variable 与 atomic<bool> 一起使用

有几个关于SO处理原子的问题,以及其他处理std::condition_variable的问题。但是我的问题是我下面的用法是否正确?三个线程,一个ctrl线程在取消暂停其他两个线程之前做准备工作。当工作线程(发送者/接收者)处于紧密的发送/接收循环中时,ctrl线程还能够暂停它们。使用atomic的想法是在未设置暂停bool值的情况下使紧密循环更快。classSomeClass{public://...//Disregardthatdataispublic...std::condition_variablecv;//UDPthreadswillwaitonthiscvuntilallo

C++17 原子和 condition_variable 死锁

我有以下代码,它在注释行上死锁。基本上f1和f2在程序中作为单独的线程运行。f1期望i为1并递减它,通知cv。f2期望i为0并递增它,通知cv。我假设如果f2将i递增到1会发生死锁,调用cv.notify(),然后f1读取i的陈旧值(即0),因为互斥锁和i之间没有内存同步,然后等待并且永远不会被唤醒向上。然后f2也进入休眠状态,现在两个线程都在等待一个永远不会被通知的cv。如何编写这段代码才不会发生死锁?基本上我想要实现的是拥有一些由两个线程更新的原子状态。如果其中一个线程的状态不正确,我不想旋转;相反,我想使用cv功能(或类似功能)在值正确时唤醒线程。我正在使用g++-7与O3一起编

C++11 线程 : Multiple threads waiting on a condition variable

我目前正在研究一个模拟扩展生产者-worker模型的问题。在这个问题中,有3个worker和3个工具可用,要让worker工作,他们需要2个工具(和Material,但这些无关紧要)。如果金库中有>=2个工具,worker将拿取2个。否则,他们将等待一个条件变量,该变量将在>=2个时发出信号。这对2个worker来说没问题:一个工作然后将工具归还到金库,另一个等待的worker将被唤醒并拿走2个工具。问题是,有3个worker,总会有一个人饿着肚子去拿工具。经过一些测试后,我注意到等待条件变量的线程是以堆栈形式构建的。有没有可能让它排队?(1等,2等,3等。当1觉醒想再做一个的时候,就

c++ - 在 constexpr 函数中返回一个 C 字符串 : why no warning from the compiler?

考虑以下代码:constexprautof(){autostr="HelloWorld!";returnstr;}intmain(intargc,char*argv[]){staticconstexprautostr=f();std::cout我的编译器不显示任何警告是否正常?它是定义的行为吗?我能保证程序会显示"HelloWorld!"吗?我希望"HelloWorld!"不会超出函数的范围... 最佳答案 在C++中stringliterals有staticstorageduration只要程序运行就可以生存。因此,指向从f返回的

c++ - x86/C++ - 指向指针 : Const being violated by compiler? 的指针

我正在为我的学生项目的游戏引擎开发一个共享指针(称为句柄)实现,我们遇到了一个我们无法解释的错误。出于某种原因,在我们工厂的某个时刻,有一个无效的内部指针通过句柄传递给工厂,这导致我们的原型(prototype)加载期间发生崩溃。我们调试了几个小时的过程,并将任何复杂的语句分解为最简单的版本,以便于调试。我最终将问题归结为Handle类的复制构造函数。但是,似乎仍然存在释放内部指针的中间步骤。我阅读了所有我能找到的关于可能导致此问题的文章,但没有找到任何内容。最后,我决定查看反汇编代码,看看我是否能弄清楚发生了什么。这是没有反汇编的复制构造函数。templateHandle::Hand

c++ - "Conditional"解析命令行参数

假设我有一个可执行文件(在mac、win和linux上运行)a.out[-a][-b][-r-i-o-t-n][]中的参数表示它是可选的。但是,如果设置了最后一个参数-r,则-i、-o、-t和-n也必须提供。有很多优秀的C++库可以解析命令行参数,例如gflags(http://code.google.com/p/gflags/),tclap(http://tclap.sourceforge.net/),simpleopt(http://code.jellycan.com/simpleopt/),boost.program_options(http://www.boost.org/do

c++ - std::condition_variable_any 的 libc++ 实现

条件变量应该有关于notify()的单一顺序和unlock_sleep()(在wait()中使用的一个虚构的函数调用,其中互斥锁被解锁并且线程作为一个原子操作序列休眠)操作。使用任意可锁定器实现此目的std::condition_variable_any实现通常在内部使用另一个互斥体(以确保原子性和休眠)如果内部unlock_sleep()和notify()(notify_one()或notify_all())操作彼此之间不是原子的,您冒着一个线程解锁互斥锁、另一个线程发出信号然后原始线程进入休眠状态并且永远不会醒来的风险。我正在阅读std::condition_variable_an

c++ - Visual Studio 2012 : C++ compiler ignoring user-specified include directories

我遇到常见错误fatalerrorC1083:Cannotopenincludefile:'afxres.h':Nosuchfileordirectory。搜索引擎为此显示了很多匹配项,但没有一个建议的解决方案对我有用。通常这看起来是路径问题。所以,我确保安装了相关的库,并找到了文件。使用绝对路径作为#include工作正常:#include"C:\ProgramFiles(x86)\MicrosoftVisualStudio11.0\VC\atlmfc\include\afxres.h"但是,如果我将目录(C:\ProgramFiles(x86)\MicrosoftVisualStu

c++ - "The C++ compiler "/usr/bin/c++ "is not able to compile a simple test program."尝试安装 OpenCV 时

我正尝试按照此link在我的Mac上安装OpenCV但是,当我在终端上键入cmake-G"UnixMakefiles"..时,会打印出此错误。--TheCXXcompileridentificationisunknown--TheCcompileridentificationisunknown--CheckforworkingCXXcompiler:/usr/bin/c++--CheckforworkingCXXcompiler:/usr/bin/c++--brokenCMakeErrorat/opt/local/share/cmake-3.0/Modules/CMakeTestCXX