草庐IT

include_directories

全部标签

C++ - 使用#include <ClassName> 而不是#include <classname.h> 有好处吗?

我知道标准库使用includewith.h用于旧的C库,而includewithout.h用于最新的库。但是,对于自己的类(class)来说,更好的做法是什么?在我工作的地方,我们总是有一个include文件夹,每个类有两个文件:classname.h和ClassName。ClassName包含classname.h,classname.h包含真正的类头文件。要包含一个类,您然后使用#includeQt就是这样做的,我很确定Qt是他们开始在我的公司这样做的原因。但这有什么好处吗?缺点很明显,我认为:要为新类创建另一个文件(我们使用bash脚本来创建,但仍然如此)每个类(class)多管

c++ "#include"输出说明

试图理解#include是如何工作的。我读到,在预处理过程中,它只是用引用文件的内容替换自己。为了验证,我创建了两个文件。一个名为otherfile的文件只包含字符串1234,一个文件test.cpp包含#includeotherfileabcd我运行g++-Etest.cpp,得到的输出是#1"test.cpp"#1""1#1""3#373""3#1""1#1""2#1"test.cpp"2#1"./wtf"11234#2"test.cpp"2abcd其余的行来自哪里,它们是什么意思? 最佳答案 Wheredotherestoft

c++ - 了解 Google 的 C++ 风格指南的 #include 顺序指南的 "build break"基本原理

这是来自Google'sC++styleguide的关于#include的部分:Indir/foo.ccordir/foo_test.cc,whosemainpurposeistoimplementortestthestuffindir2/foo2.h,orderyourincludesasfollows:dir2/foo2.h.AblanklineCsystemfiles.C++systemfiles.AblanklineOtherlibraries'.hfiles.Yourproject's.hfiles.Notethatanyadjacentblanklinesshouldbec

c++ - 尝试在目标设备上运行交叉编译的可执行文件失败并显示 : No such file or directory

我陷入了不太阳光的交叉编译世界。我正在尝试为我的BeagleBoneBlack(运行TICortex-A8处理器)编译一个简单的helloworld应用程序。首先,我用gcc在x86上编译并成功运行了helloworld应用程序然后我将编译设置更改为以下内容:arm-linux-gnueabi-gcc-c-O0-g3-Wallmain.c-obin/obj/main.oarm-linux-gnueabi-gccbin/obj/main.o-obin/hello_world我通过SCP将文件传输到BeagleBone,并使用chmod+xhello_world设置了可执行权限运行它(./

c++ - 当您不想 #include 时,可以替代前向声明

我通常不假思索地使用前向声明,这样我就不必包含标题。这个例子中的一些东西://-----------------------//foo.h//-----------------------classfoo{foo();~foo();};//-----------------------//bar.h//-----------------------classfoo;//forwarddeclarationclassbar{bar();~bar();foo*foo_pointer;};一些开发者喜欢使用这种方法来避免包含环的问题。我宁愿使用它来最大限度地减少广泛包含层次结构的开销,这是物

c++ - Ubuntu Eclipse libxml2 错误 : fatal error: libxml/xmlversion. h: No such file or directory

我想在我的eclipse项目中使用libxml2。我可以通过“”在命令行上使用这个库g++main.cpp-I/usr/include/libxml2-lxml2-ooutput"但是我不能在eclipse上使用。我添加了C++Build->Setting->GCCCCompiler->Includes-I/usr/include/libxml2andIaddC++Build->Setting->GCCC++Linker->library-lxml2但是当我构建我的项目时,我通过得到一个错误libxml/parser.h:15:31:fatalerror:libxml/xmlversi

c++ - 如何使用#includes 强制 Visual Studio 预处理器区分大小写?

如果您有一个名为ThisIsAHeaderFile.h的头文件,以下仍将在VisualStudio中找到该文件:#include有没有办法强制区分大小写,以便#include会导致错误? 最佳答案 你不能,因为Windows文件系统本身是不区分大小写的。如果您遇到同时拥有RICHIE.h和richie.h的情况,那么控制区分大小写可能有意义,但您不能。 关于c++-如何使用#includes强制VisualStudio预处理器区分大小写?,我们在StackOverflow上找到一个类似的

c++ - g++ 递归地包含所有/usr/include

我正在尝试编译一个简单的程序,用#includegtkmm.h的路径是/usr/include/gtkmm-2.4/gtkmm.h。g++看不到这个文件,除非我特别告诉它-I/usr/include/gtkmm-2.4。我的问题是,我如何让g++自动递归地查看/usr/include中的所有目录以查找其中包含的所有头文件,为什么这不是默认操作? 最佳答案 在这种情况下,正确的做法是在Makefile或构建脚本中使用pkg-config:#Makefileifeq($(shellpkg-config--modversiongtkmm-

c++ - 如何将 boost::filesystem::directory_iterator 转换为 const char *

我想遍历目录中的所有文件并打印它们的内容。Boost很好地处理了迭代部分,但我不知道如何将其转换为constchar*。boost::filesystem::directory_iteratorpath_it(path);boost::filesystem::directory_iteratorend_it;while(path_it!=end_it){std::cout我试图阅读这个documentation但找不到类似string或c_str()的内容。我是C++和boost的新手,希望能找到一些类似javadoc的文档,基本上可以告诉我成员是什么,是什么函数可用而不是转储源代码。

linux - Active Directory 和 linux nslcd 绑定(bind)而不扩展 AD 模式

我需要将Linux客户端绑定(bind)到WindowsServer2012ActiveDirectory。我有一个测试环境,我在其中成功地使用samba-winbind-kerberos和nslcd,使用用户进行身份验证。然而,当使用samba-winbind-kerberos时,我能够在不扩展AD架构以包含UNIX属性(UID/GID、主目录、shell)的情况下实现这一点,因为smb.conf有一个idmap选项,指定起始范围idmapconfig*:range=11000-20000这将负责AD用户的UID/GID的unix映射。如果我不在AD中启用UNIX属性,我会在nslc