草庐IT

num_times_done_it

全部标签

c++ - C++11 中的数据竞争、UB 和计数器

以下模式在许多软件中很常见,这些软件想要告诉用户它做了多少次各种事情:intnum_times_done_it;//globalvoiddoit(){++num_times_done_it;//dosomething}voidreport_stats(){printf("calleddoit%itimes\n",num_times_done_it);//andprobablysomeotherstufftoo}不幸的是,如果多个线程可以在没有某种同步的情况下调用doit,则对num_times_done_it的并发读取-修改-写入可能是数据竞争,因此整个程序的行为将是不确定的。此外,如

c++ - 为什么 std::chrono::system_clock::to_time_t() 不是 constexpr?

C++标准(github.com/cplusplus/draft)有time_t转换函数(std::chrono::system_clock::to_time_t和std::chrono::system_clock::from_time_t)用于列为static和noexcept但不是constexpr。鉴于time_point和duration上的所有操作基本上都是constexpr(包括duration_cast和time_point_cast),我想不出任何理由来排除它们。在我的本地机器上快速检查libstdc++源代码确认这些函数是作为简单的持续时间/时间点转换实现的。这两个函

c++ - G++ 4.6 -std=gnu++0x : Static Local Variable Constructor Call Timing and Thread Safety

voida(){...}voidb(){...}structX{X(){b();}};voidf(){a();staticXx;...}假设在进入main之后,f被多个线程(可能竞争)多次调用。(当然,唯一对a和b的调用是上面看到的那些)以上代码在-std=gnu++0x模式下用gccg++4.6编译时:Q1。是否保证至少调用一次a()并在调用b()之前返回?也就是说,在第一次调用f()时,x的构造函数是否会同时调用一个自动持续时间局部变量(非静态)(而不是在全局静态初始化时间)?Q2。是否保证b()只会被调用一次?即使两个线程第一次同时在不同的核上执行f?如果是,GCC生成的代码通过

c++ - 如何将大量秒数可移植地添加到 time_t 对象?

嗯,我认为标题总结了它。假设我有一个double类型的对象,它是通过在两个time_t对象上运行std::difftime获得的,现在我想添加结果返回到time_t对象的秒数。我不介意损失几分之一秒。请注意,秒数可能很大(即大于structtm中允许的60秒,但始终低于用于在相应机器/实现上表示秒的任何整数原语,并且永远不会超过1年的数量级,尽管我最好不希望这是一个限制)。我将如何着手可移植(即按照C标准)?我希望不必将它们分为月、日、小时、分钟等,然后手动将它们添加到structtm对象中。当然有更好的方法!? 最佳答案 您可以使

c++ - STL 容器 move 语义并按值返回 : how many times of copying get avoided away?

我知道在C++11中,move语义已经在STL容器中实现以避免临时对象。人们说现在编写按值返回的函数是完美的。但我对究竟有多少次复制实际上被避免感到困惑。请看下面的例子:vectormyVector(){vectorres;res.push_back(4);res.push_back(5);returnres;}vectorv=myVector();我的理解是在c++03中,myVector返回res的拷贝(4,5复制了一次),在评估vectorv=myVector();时vector的复制构造函数vector(constvector&)被调用(4,5复制了两次)。但是在具有move语

c++ - 尝试使用 std::get_time 解析 YYMMDD 并失败

我正在尝试这样做但失败了:std::istringstreamss("1212");ss>>std::get_time(&t,"%y%m");if(ss.fail())//everytime!这工作正常:std::istringstreamss("12-12");ss>>std::get_time(&t,"%y-%m");知道我做错了什么吗?我还能用什么,因为Windows似乎没有srtptimewindow/vs13时间差 最佳答案 VisualStudio似乎没有正确实现规范,GCCuntilversion5.0也没有。.如果您

c++ - SFINAE : Detecting if a function is called by a compile time known value

我喜欢在我的一个ctors以编译时已知值被调用时做一些检查。有办法检测吗?所以当有人调用它时:Aa(10);因为10是编译时已知常量,所以我喜欢调用一个特殊的构造函数,如下所示:template>A(intValue){}知道如何解决这个问题吗?谢谢! 最佳答案 积分常量可以解决您的问题:structA{template*=nullptr>A(std::integral_constant){}};然后,你可以像这样使用它:Aa{std:integral_constant{}};为了便于使用,您还可以使用类似于boost::hana的

c++ - Qt 信号/槽 : Is it an error to emit a signal from a temporary object?

在Qt中,如果从一个临时对象中调用一个信号,使得该对象可能在调用槽时被删除,这是一个错误吗?如果相关,代码会从临时对象的构造函数发出信号。(注意:没有指针或引用作为参数传递,所以这不是关于悬挂指针或引用的问题。我只是想知道,以最简单的形式,从Qt中的一个临时对象。)这是我的代码的简化版本://MyapplicationclassHandyApplication:publicQApplication{Q_OBJECTpublic:explicitHandyApplication(intargc,char*argv[]);signals:publicslots:voidhandySlot(

c++ - 现代 C 和 C++ : it is possible to use one defined structure for other declared structure?

假设我想制作某种支持加载图形Image的引擎,所以我有structImage;Image*load_image_from_file(...);我不想让外部世界知道Image到底是什么,他们只会处理指向它的指针。但是在engine内部我想使用特定的类型,例如SDL_Surface在SDL中完全定义。我能否以某种方式重新定义此文件的图像,以便编译器在每次看到Image*(宏除外)时都假定为SDL_Surface*?即我想要像typedefstructSDL_SurfaceImage;这样的东西所有的尝试都像usingImage=SDL_Surface;typedefSDL_SurfaceI