草庐IT

0x00000001048a35b2

全部标签

c++ - 显式覆盖和最终的 c++0x

根据Wikipedia,在这个例子中:structBase{virtualvoidsome_func(float);};structDerived:Base{virtualvoidsome_func(float)override;};我认为override不是C++关键字,那么它到底是什么意思呢?我们可以在没有该关键字的情况下实现同样的事情,那么为什么有人需要它呢?还有关键字final还不能在VS2010上工作:structBase1final{};structDerived1:Base1{};//ill-formedbecausetheclassBase1//hasbeenmarke

c++ - 关于C++0x引用崩溃的问题

我不知道为什么这些代码无法编译。我已经在Visualc++2010和gcc中使用-std=c++0x进行了测试。有人给点建议吗?谢谢!templateclassFoo{public:voidtest(constT&){coutf;}编译错误:'voidFoo::test(T)':成员函数已经定义或声明但是为什么这个可以编译呢?templatevoidfoo(constT&){coutvoidfoo(T&){cout(a);}我读过c++0x文章说:T&&==T&,所以constT&&==constT&? 最佳答案 i'vreadc+

c++ - 你开始使用 C++0x 了吗?

大多数编译器alreadysupportC++0x.你开始使用C++0x还是在等待x的定义?我必须对我的代码进行一些重构;我应该开始使用新功能吗? 最佳答案 C++0x还不是一个完整的标准。在发布国际公认标准之前,很可能会有许多修订。所以这完全取决于,您编写代码的目的是什么?如果它是为了工作任务,我会坚持使用常规C++,等待标准被设定,并给编程社区调整所需的时间。不要重构你真正需要实现的代码,它可能会给你带来很多麻烦。不过,我认为C++0x非常适合使用,而且当0x被全局接受时,熟悉其语法也无妨。

c++ - INetSharingConfiguration->EnableSharing( ICSSHARINGTYPE_PUBLIC ) 返回 0x80040201

我正在尝试以编程方式在与Windows7计算机上的已知GUID匹配的设备上启用共享类型public的共享。API位于:http://msdn.microsoft.com/en-us/library/windows/desktop/aa365944(v=vs.85).aspx错误列表显示如下:E_ABORT、E_FAIL、E_INVALIDARG、E_NOINTERFACE、E_NOTIMPL、E_OUTOFMEMORY、E_POINTER和E_UNEXPECTED。我返回的错误代码是0x80040201,解析为:“事件无法调用任何订阅者。”这似乎与上面列出的任何错误代码都不匹配。如果我

c++ - b2 vs bjam 用于构建 Boost 库

我使用b2.exe和bjam.exe为VS2013构建了64位架构的Boost。根据Boostdocumentation,b2必须在bjam上使用。我注意到的差异是:b2中的.lib文件的大小与相应的bjam文件的大小不同。使用bjam提供动态.lib库(不带-s标记,如here所述),但它不提供要链接到的.dll文件(那么现在该怎么办?),而使用b2会同时提供静态库和动态库以及.dll文件。但使用b2的问题是,它提供了两个动态.lib文件-一个以boost_xxxx.lib开头,另一个以libboost_xxxx.lib开头,两者大小不同。这是为什么?我还提到了使用构建选项--bui

c++ - 为什么在 C++0x 或 Boost.Thread 中没有针对多个互斥锁的作用域锁?

C++0x线程库或Boost.thread定义非成员变量模板函数,锁定所有锁避免死锁。templatevoidlock(L1&,L2&,L3&...);虽然此功能有助于避免死锁,但标准不包括用于编写异常安全代码的关联作用域锁。{std::lock(l1,l2);//dosomething//unlocklil2exceptionsafe}这意味着我们需要使用其他机制作为try-catchblock来制作异常安全的代码,或者我们自己在多个互斥锁上定义我们自己的作用域锁,甚至这样做{std::lock(l1,l2);std::unique_locklk1(l1,std::adopted);

c++ - 格式错误的 C++0x 代码或编译器错误?

在下面的C++0x代码中,我试图通过使用克隆成员函数(如果存在)并回退到一个拷贝构造函数:structuse_copy_ctor{};structprefer_clone_func:use_copy_ctor{};templateautoclone(Tconst*ptr,prefer_clone_func)->decltype(ptr->clone()){returnptr->clone();}templateautoclone(Tconst*ptr,use_copy_ctor)->decltype(newT(*ptr)){returnnewT(*ptr);}structabc{vir

C++0x 用基于范围的 for 循环替换 for(int i;;) 范围循环的方法

所以我一直在使用GCC4.6进入新的C++,它现在具有基于范围的for循环。我发现这非常适合迭代数组和vector。主要出于审美原因,我想知道是否有办法用它来代替标准for(inti=min;i用类似的东西for(int&i:std::range(min,max)){}新的C++标准中是否有内置的东西允许我这样做?还是我必须编写自己的范围/迭代器类? 最佳答案 我在任何地方都看不到它。但这将是相当微不足道的:classrange_iterator:publicstd::input_iterator{intx;public:range

C++0X memory_order 无围栏,应用,支持的芯片

作为我之前question的跟进,atomic类使用memory_order指定大多数操作范围。与栅栏相反,此内存顺序仅影响其操作的原子。据推测,通过使用几个这样的原子,您可以构建一个并发算法,其中其他内存的顺序并不重要。所以我有两个问题:有人能给我指出一个算法/情况的示例,该算法/情况可以从单个原子变量的排序中受益并且不需要需要栅栏吗?哪些现代处理器支持这种行为?也就是说,编译器不会只是将特定顺序转换为正常的围栏。 最佳答案 关于std::atomic操作的内存排序参数变量不会影响该操作本身的顺序,它会影响该操作与其他操作创建的顺

c++ - 谁能解释一下当前C++0x标准草案的这一段?

谁能解释ISON3242§3.2第2点中的这个陈述Anon-placementallocationordeallocationfunctionforaclassisodr-usedbythedefinitionofaconstructorofthatclass.Anon-placementdeallocationfunctionforaclassisodr-usedbythedefinitionofthedestructorofthatclass,orbybeingselectedbythelookupatthepointofdefinitionofavirtualdestructor