草庐IT

condition-statement

全部标签

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++ - 复制省略 : move constructor not called when using ternary expression in return statement?

考虑以下示例:#includeclassobject{public:object(){printf("constructor\n");}object(constobject&){printf("copyconstructor\n");}object(object&&){printf("moveconstructor\n");}};staticobjectcreate_object(){objecta;objectb;volatileinti=1;//With#if0,object'scopyconstructoriscalled;otherwise,itsmoveconstructor

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

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

C++ : cout with a terenary if-statement

我得到这个错误:“错误:没有上下文类型信息的重载函数”。cout我正在做的事情可行吗?我只是做错了,还是我必须重载 最佳答案 它不会那样工作(即使你修复了优先级错误)。这里有两个问题,第二个比第一个更严重。第一个问题是std::endl是一个模板。它是一个函数模板。模板必须是专门的。为了专门化该模板,编译器必须知道(推断)模板参数。当你做的时候std::coutoperator期望的特定函数指针类型是编译器用来弄清楚如何专门化std::endl的东西模板。但是在您的示例中,您基本上“分离”了std::endl来自operator通过

c++ - std::conditional 如何工作

我们有这个叫做std::conditional的元编程小奇迹描述here.在同一引用文献中,它说可能的实现是templatestructconditional{typedefTtype;};templatestructconditional{typedefFtype;};所以如果在代码中我做类似的事情typenamestd::conditional::typea;编译器将遵循第一个定义,如果我做类似的事情typenamestd::conditional::typeb编译器将采用第二个。为什么这样行得通?这里有什么编译规则? 最佳答案

c++ - 使用 std::atomic 和 std::condition_variable 同步不可靠

在用C++11编写的分布式作业系统中,我使用以下结构实现了一个栅栏(即工作线程池外的线程可能会要求阻塞,直到所有当前计划的作业完成):structfence{std::atomiccounter;std::mutexresume_mutex;std::condition_variableresume;fence(size_tnum_threads):counter(num_threads){}};实现围栏的代码如下所示:voidtask_pool::fence_impl(void*arg){autof=(fence*)arg;if(--f->counter==0)//(1)//weha

c++ - Windows 上的 std::conditional_variable::wait_for、std::thread::sleep_for 受调整时钟的影响

嗯。我有Win10x64和这个非常简单的代码:intmain(){std::conditional_variablecv;std::mutexm;std::unique_locklock(m);while(1){cv.wait_for(lock,1000ms,[](){returnfalse;});std::cout是的。代码就像我期望的那样工作;表明'!'每一秒。但是,如果我更改本地时间(例如减去1小时/分钟),它会永远有效。如果我用WinAPISleep(1000)替换cv.wait_for(...)它工作正常。WinAPISleepConditionVariableCS也能正常工

c++ - 为什么这有效 : C++ last statement as result of expression

这个问题在这里已经有了答案:Arecompoundstatements(blocks)surroundedbyparensexpressionsinANSIC?(2个答案)Warning"UseofGNUstatementexpressionextension"(4个答案)关闭6年前。我在驱动程序实现中发现了奇怪的宏,我无法向自己解释。简化的例子是:cout它将输出10。但是为什么expression变成了右值呢?它似乎适用于C和C++。有人可以解释一下吗?指向关键字和引用会很棒。

c++ - 为什么 std::condition_variable 作为类成员会导致 std::thread 出现编译错误?

我尝试将std::condition_variable作为类成员,但在将此类的对象传递给std::thread时出现了很多编译错误。我从我的实际程序中删除了所有其他代码,并以下面的最小代码结束。删除std::condition_variable不会导致任何问题。我尝试在构造函数中“初始化”变量,并使其成为inline,但都没有帮助。#include#includestructThreadHandler{voidoperator()(){}std::condition_variablecond;};intmain(){ThreadHandlerth1;std::threadt1(th1)

windows - 批处理脚本 - 'If Statements' 中的通配符

我正在编写一个批处理脚本,其中我需要在if语句中使用通配符来将变量与字符串匹配。如果匹配,程序将走得更远。if"!_var!"=="str*"(--SOMECOMMANDS--)这是我用过的语法,但我发现它根本行不通。 最佳答案 echo%var%|findstr/b"str">nul&&(echoyessomemorecommands)||(echonosomemorecommands)寻找(/b=开头的)str,(不写入屏幕>nul),如果找到(&&)做某事,如果找不到(||)做另一件事。您还可以添加/i使其不区分大小写。