草庐IT

variable-initialization

全部标签

c++ - G++ 4.5 错误 : No diagnostic for narrowing in initializer list

我尝试了以下代码:intmain(){intx{23.22};}其中包括需要缩小的初始化,但代码编译正常,没有任何错误或警告。另一方面,以下代码给出了错误:intmain(){intx[]{23.22};}我是发现了错误还是什么?PS:我目前使用的是GCC4.5.0 最佳答案 看起来像一个错误。以下直接来自n3092草案:8.5.4List-initialization—Otherwise,iftheinitializerlisthasasingleelement,theobjectisinitializedfromthatelem

c++ - 如果用户使用 Rice 在 Ruby 中重新定义 initialize(),则避免 C++ 代码中的段错误

在为Ruby编写C++扩展时,我一直在努力解决的一个问题是,即使用户做了愚蠢的事情,也要让它真正安全。那时他应该得到异常,但绝不是SegFault。一个具体的问题如下:我的C++类有一个非平凡的构造函数。然后我使用RiceAPI来包装我的C++类。如果用户在他的Ruby代码中重新定义了initialize(),那么Rice创建的initialize()函数就会被覆盖,对象既不会被分配也不会被初始化。一个玩具示例如下:classPerson{public:Person(conststring&name):m_name(name){}conststring&name()const{retu

c++ - constexpr if with initializer 由标准保证吗? 'constexpr(constexpr auto x = f(); x) { }'

我找不到任何关于新C++17if初始化语法的信息和“constexprif”在:http://open-std.org/JTC1/SC22/WG21/docs/papers/2016/p0128r1.html不过,Clang-HEAD支持该语法...constexprautof(){returntrue;}intmain(){ifconstexpr(constexprautox=f();x){}}在线代码在这里->http://melpon.org/wandbox/permlink/dj3a9ChvjhlNc8nr是constexprif带有标准保证的初始值设定项,如constexpr

c++ - 错误 : has initializer but incomplete type

我遇到了问题:在使用结构时有初始化器但类型不完整:在hpp文件中:classA{private:structvideoDT;};在一个cpp文件中:structA::videoDT{videoDT(intb):a(b){}inta;};voidtest(){structvideoDTtest(1);}那么问题来了:错误:有初始化器但类型不完整提前致谢 最佳答案 我认为问题在于test()无法访问A的私有(private)类型。这为我编译:classA{private:friendvoidtest();structvideoDT;};

C++11 我可以确保 condition_variable.wait() 不会错过通知吗?

我让线程1执行以下代码:unique_lockul(m);while(condition==true)cv.wait(ul);线程2执行这段代码:condition=false;cv.notify_one();不幸的是,我遇到了时间问题:T1:conditioncheckstrueT2:conditionsettofalseT2:cv.notify_one()T1:cv.wait()线程1完全错过了通知并在wait()上保持阻塞状态。我尝试使用带有谓词但结果基本相同的wait()版本。也就是说,谓词的主体执行检查,但在它返回之前,条件的值被更改并发送通知。然后谓词返回。我该如何解决这个

c++ - 错误 : variable or field ‘myfunction’ declared void

这个问题在这里已经有了答案:variableorfielddeclaredvoid(6个答案)关闭7年前。在下文中,我没有定义类型doesntexist。voidmyfunction(doesntexistargument){}GCC4.7.2说“error:variableorfield‘myfunction’declaredvoid”我的问题是:编译器在这里指代函数名称为void而不是参数类型是怎么想的?[编辑]在投票之前,请注意这个问题的答案与错误的顺序和-Wfatal-errors停止打印更直接相关的消息有关。这不仅仅是我在尝试一个稍微模糊的编译器消息。

c++ - 错误 C4703 : potentially uninitialized local pointer variable 'pNamesPtr' used

我正在做一个加密项目,在尝试编译程序时遇到了以下错误。main.cpp(520):errorC4703:potentiallyuninitializedlocalpointervariable'pNamesPtr'used==========Build:0succeeded,1failed,0up-to-date,0skipped==========DLLNAMES[i].UsedAlready=0;}*dwOutSize=(DWORD)pNamesPtr-(DWORD)pBuffer;//*有人可以帮我解决这个错误吗?您是否需要更多代码才能得到好的答案?

C++ 调试窗口显示“<incomplete type> for string variable

据我所知,我正在以一种相当正常的方式初始化一个字符串,当我调试时,我的IDE(CLion)中的变量窗口将其值显示为.我有一些简单的代码导致字符串变量Bob出现问题.#includeintmain(){std::stringBob="thisdoesn'tshowupinthevariableswindow";std::cout我不知道它有什么影响,但我会包含CMakeLists文件,它似乎是我可以使用的最简单的文件。cmake_minimum_required(VERSION3.8)project(testing123)set(CMAKE_CXX_FLAGS"${CMAKE_CXX_F

c++ - `std::condition_variable::wait_for` 经常调用谓词

考虑以下代码片段:#include#include#include#includeintmain(){std::mutexy;std::condition_variablex;std::unique_locklock{y};inti=0;autoincrement=[&]{++i;returnfalse;};usingnamespacestd::chrono_literals;//lock5sifincrementreturnsfalse//let'sseehowoftenwasincrementcalled?x.wait_for(lock,5s,increment);std::cou

c++ - 为什么 std::condition_variable 使调度不公平?

我正在尝试创建一个简单的池对象,我想将对一组共享资源的访问或多或少公平地分配给任何请求它的线程。在Windows中,我通常会有一个Mutexes数组并使用bWaitAll=FALSE执行WaitForMultipleObjects(请参阅下面的windows_pool_of_n_t)。但我希望有一天能够将其移植到其他操作系统,所以我想坚持使用标准。在size()!=0上使用condition_variable的资源双端队列似乎是显而易见的解决方案(请参阅下面的pool_of_n_t)。但是由于我不明白的原因,该代码序列化了线程访问。我并不期待严格的公平性,但这几乎是最坏的情况——上次获