草庐IT

INCLUDE_ALL

全部标签

c++ - 有效 C++ : Item 52 and how to avoid hiding all normal operator new & delete versions

在Myer的EffectiveC++的第52项(自定义新的和删除的)的末尾,他讨论了如何在实现自定义版本时避免隐藏正常的新的和删除的版本,如下所示:Ifyoudeclareanyoperatornewsinaclass,you'llhideallthesestandardforms.Unlessyoumeantopreventclassclientsfromusingtheseforms,besuretomakethemavailableinadditiontoanycustomoperatornewformsyoucreate.Foreachoperatornewyoumakeava

c++ - #include .h 或 .cpp 文件?

所以我遇到了这个看起来很奇怪的问题:当我导入一个单独类的.h文件时,我非常基本的程序会生成一条错误消息(对“foo::foo(int)”的undefinedreference)。但是,当我将导入文件更改为.cpp时,一切正常。现在,我读了一点书,看了一些视频教程,他们都说了同样的话:导入.h文件。那么为什么它不起作用?我使用Code::Blocks,在Windows7中编译和运行(无命令行)。我确实怀疑某些设置不太正确,但是,我确实想知道它是否正确我的代码失败了。主要.cpp:#include#include"Foo.h"//Thisdon'twork.IfiincludeFoo.cp

C++ 生成器 : #include <iostream> error

我正在测试新版本的CBuilder(XE2版)。大多数commnoninclude被重定向到boost库或dinkumware库(一些STL实现?)。#ifndefError_H#defineError_H#include#include//Errormessage,seebellow,please但编译因以下(和奇怪的)消息而停止:[BCC32Error]xlocale(1392):E2451Undefinedsymbol'MB_LEN_MAX'[BCC32Error]xlocale(1763):[BCC32Error]xlocnum(1495):E2451Undefinedsymb

c++ - Doxygen 文档应该放在 include guards 之前吗?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。ImprovethisquestionDoxygen文档应该放在includeguards之前还是之后?在namespace之前或内部?假设header包含单个类(context)的声明,这就是我在此处记录的内容。#ifndefCONTEXT_HPP#defineCONTEXT_HPP#include/***Theapplicationcontextinterface.*/namespacetest{classcontext{

c++ - 线程构建 block : Deadlocks because all threads used up

在英特尔线程构建block框架中,如何确保所有线程不忙于等待其他线程完成。例如考虑以下代码,#include#include#include#include#includestd::futurerun_something(std::functionfunc,boolb){autotask=std::make_shared>(std::bind(func,b));std::futureres=task->get_future();tbb::task_groupg;g.run([task](){(*task)();});returnres;};intmain(){tbb::parallel

c++ - "Include What you use"

我读到了一个名为"include-what-you-use"的工具这可以帮助清理多余的包括从源代码。我知道有一个编译器LLVM(clang)版本和一个GCC版本。我的问题是:为什么这个工具依赖于编译器而不是“跨平台”的编译器。为什么从一开始工具的创建者就没有让它独立于编译器?是否与它的特殊实现或类似的东西有关?如果我想采用与LLVM兼容的工具版本,并且我想让它与GCC兼容(因为我正在使用GCC),我需要为此做什么? 最佳答案 在大多数情况下,Include-What-You-Use应该能够处理任何有效的C++代码库,无论该代码库是使

c++ - 是否有任何关键字可以在模板化派生类中重新定义模板化基类的 "all"方法?

我知道这看起来是个愚蠢的问题,但是在C++中使用带有模板的面向对象的东西真的很麻烦。例如,Foo是基类:templateclassFoo{public:virtualvoidMethod1(){}virtualvoidMethod1(inta){}virtualvoidMethod2(){}virtualvoidMethod2(inta){}//...lotsofothermethods};是否有类似的东西:templateclassBar:publicFoo{public:usingFoo::*;//redefineallinheritedmethodsfromFoovirtualv

c++ - 米斯拉-C++ :2008[8-4-3] : return in all exit path in function

在测试我的代码(静态分析)以查看我是否尊重misrac++2008时,我收到以下错误Functiondoesnotreturnavalueonallpaths.函数看起来像int*Dosomething(stringv){int*retvalue=NULL;if(0==exists(v)){throw("error:valuedoesn'texist");}else{retvalue=dosomecomputations(v);}returnretvalue;}我真的需要抛出一个异常,因为调用者应该根据错误做一些事情。可能的错误列表可能很大,而且不仅仅是该代码示例中的值不存在。我该如何

C++ : generate all subsets from set with one condition

我正在尝试编写代码,通过一个条件从集合中生成所有子集,例如如果我有threshold=2,并且设置了三个:1,2,3,4,51,3,51,3,4然后程序会输出:第一次迭代时的生成集:1=numberoffrequency=32=numberoffrequency=13=numberoffrequency=34=numberoffrequency=25=numberoffrequency=2由于数字2第二次迭代时的生成集:1,3=numberoffrequency=31,4=numberoffrequency=21,5=numberoffrequency=23,4=numberoffre

c++ - 将 OSX Clang 配置为对 include 语句区分大小写

我知道C++include语句中区分大小写是一个文件系统问题(相关问题here和here)。是否可以将Clang配置为要求区分大小写的匹配以防止跨平台构建问题? 最佳答案 Clang现在有这些警告标志:-Wnonportable-include-path-Wnonportable-system-include-path第一个用于引用包含,第二个用于尖括号包含。它们甚至可以映射到错误:-Werror=nonportable-include-path-Werror=nonportable-system-include-path据推测,默