草庐IT

expected_conditions

全部标签

c++ - 无法在 VS 14 CTP : conditional expression of type 'void' is illegal 中使用 auto 声明 lambda

使用VisualStudio2014CTP、C++(v140)编译器:autogp=[&](BYTE*buff){autogp1=[](char*bff,char**p1){*p1=strstr((char*)bff,"(");return(*p1);};};错误:conditionalexpressionoftype'void'isillegal(也许auto真的输入错误?)如果我将内部lambda声明为std::functiongp1然后就可以了是我做错了什么还是编译器错误? 最佳答案 我没有运行2014,但您可能需要指定内部l

c++ - boost::condition 会 boost 性能吗?

我们有一个多线程应用程序。在当前的实现中,thread1在启动时创建并定期(大约每秒,可配置)唤醒以检查磁盘是否有可能保存的文件。这些文件由另一个线程保存,thread2。正在运行的thread1及其定期唤醒可能会降低应用程序的速度。现在我们有机会使用boost::condition变量将thread1阻塞,直到thread2通知它。通过这样做,需要创建一个标志以避免来自thread2的不必要通知,并且该标志需要同步并由thread2以高频率(几秒钟内数百次)检查>。或者每次写入时都会通知thread1。我的问题如下:在boost::condition实现中,thread1仍然需要频繁

c++ - 根据提案 n4015 实现 expected<E, T>

我开始实现expected根据建议,我遇到了问题。在描述monadic功能(5.9)时,在bind中声明如果结果已经包装在上下文中(expected),则不应再次包装。我如何实现它是bind有2个重载(使用enable_if),一个用于返回expected实例化的仿函数哪个实现没有将它包装在上下文中,而一个用于返回它所做的其他类型的那些。我遇到了一个问题,在调用者中没有值的情况下,非包装版本必须返回默认构造的expected这给出了预期的默认构造错误值。这导致返回的expected的进一步延续会丢失导致默认构造的错误的上下文。也许我应该处理被称为is_same,functor_ret_

c++ - 尝试在 cygwin : error: expected unqualified-id before '&&' token 中构建 boost 文件系统时出错

我安装了cygwin2.6和gcc5.4。我安装了boost.build,它似乎可以正常工作。但是,当我尝试构建文件系统模块时,它失败并出现错误:work@PC/lib/boost_1_62_0/libs/filesystem/example/test$./build.shCompilingexampleprograms...tut4.cpp:40:18:error:expectedunqualified-idbefore'&&'tokentut4.cpp:40:18:error:expected';'before'&&'tokentut4.cpp:40:23:error:expect

c++ - "expected ' : ', ' , ', ' ; ', ' } ' or ' __attribute__ ' before ' { 结构成员函数中的' token"

我正在尝试编译我教授设计过度的C++代码。这是我的代码:/***Vectorclass.*CommonmathematicaloperationsonvectorsinR3.**WrittenbyRobertOsada,March1999.**/#ifndef__VECTOR_H__#define__VECTOR_H__/***Vector3**/structVector3f{//coordinatesfloatx,y,z;//normfloatnormSquared(){returnx*x+y*y+z*z;}doublenorm(){returnsqrt(normSquared())

c++ - 类 : "expected unqualified-id before ' volatile'"? 中的 volatile 变量

我在类ADC中定义了两个staticvolatile变量。该类写为:(裁剪以节省空间)#pragmaonce#include"../PeriodicProcess/PeriodicProcess.h"#include#includeclassADC{private:staticinlineunsignedcharSPI_transfer(unsignedchardata);voidread(uint32_ttnow);staticconstunsignedcharadc_cmd[9];staticvolatileuint32_t_sum[8];staticvolatileuint16_

c++ - 错误 : expected primary-expression before ‘)’ token

我已经尝试了很多次来解决这个问题,但我一无所获。此代码的主要目的是在嵌套类NslObject::KeyK或NewKeyPair1中保存key对(公共(public)和私有(private))。.cpp文件unsignedlongintkeyLength=10;//KeyPairADD(RSA::GenerateKeyPair(keyLength));NslObject::KeyK(RSA::GenerateKeyPair(keyLength));typedefNslObject::KeyKNewKeyPair1;NewKeyPair1(RSA::GenerateKeyPair(keyL

c++ - 检查 GTest 中 EXPECT_* 宏的结果或在 ASSERT_* 失败时运行代码

我用GTest编写了C++测试,基本上是这样工作的MyDatadata1=runTest(inputData);MyDatadata2=loadRegressionData();compareMyData(data1,data2);与voidcompareMyData(MyDataconst&data1,MyDataconst&data2){ASSERT_EQ(data1.count,data2.count);//pseudo:foreachelementindata1/data2:EXPECT_EQ(data1.items[i],data2.items[i]);}现在我想将data1

c++ - 了解使用 std::condition_variable 的示例

有一个使用condition_variable的例子来自cppreference.com:#include#include#include#include#include#includeintmain(){std::queueproduced_nums;std::mutexm;std::condition_variablecond_var;booldone=false;boolnotified=false;std::threadproducer([&](){for(inti=0;ilock(m);std::coutlock(m);notified=true;done=true;cond

c++ - 使用 C++11 std::condition_variable 的 Gtest 意味着 valgrind 错误

如果我以这种方式使用google测试框架编写测试:TEST_F(TestFName,TestName){std::condition_variablecv;}它会生成一个valgrind错误。我使用--leak-check=full--track-origins=yes选项运行它。Conditionaljumpormovedependsonuninitialisedvalue(s)==17215==at0x4E3DA82:pthread_cond_destroy@@GLIBC_2.3.2(pthread_cond_destroy.c:35)...Uninitialisedvaluewa