草庐IT

p_adts_header

全部标签

c++ - 当 C++ 标准提供将名称带入全局命名空间的 C header 时,这是否包括重载?

即将发布的C++0x标准的最终委员会草案说:EveryCheader,eachofwhichhasanameoftheformname.h,behavesasifeachnameplacedinthestandardlibrarynamespacebythecorrespondingcnameheaderisplacedwithintheglobalnamespacescope.Itisunspecifiedwhetherthesenamesarefirstdeclaredordefinedwithinnamespacescope(3.3.6)ofthenamespacestdanda

c++ - 什么是 C++ 中用于分离 header /源的模板特化的可靠方法

在中等规模甚至大型复杂项目中,分离模板声明和定义很有用以减少编译时间。然而,在复杂的代码中,小的程序员错误可能会导致不被注意的行为改变,例如调用通用版本而不是专用版本。例子:由于错过声明,模板特化变得不可见。/////////////////////fileA.hpp/////////////////////#includetemplateclassA{public:voidfoo(){std::cerrvoidA::foo();/////////////////////fileA-foo-int.cpp/////////////////////#include"A.hpp"templ

c++ - 如何为大量 header 生成 .pch?

我的代码一直使用libcxx、sdl和其他一些库。我如何生成.pch考虑到每个header都可以包含一些其他header(即使有像#ifdef#include#endif这样的复杂条件。这就是为什么很难理解所需的头文件列表的原因。我应该只使用在中找到的所有头文件吗?那个文件夹来创建.pch?在那种情况下使用这样的.pch性能怎么样?更新:如果它很重要,我将把它与Clang(而不是GCC)一起使用,并通过ClangCAPI更具体。更新2:我已经为单个头文件创建了pch:MBA-Anton:pchasmirnov$clang++-xc++-headerheader.h-emit-pch-o

c++ - 仅在 header 中的extern变量意外起作用,为什么?

我当前正在更新Arduino的C++库(使用avr-gcc编译的8位AVR处理器)。通常,默认Arduino库的作者喜欢在header中包含该类的extern变量,该变量也在.cpp类文件中定义。我认为基本上是为了让新手能够将所有东西都准备好作为内置对象。我遇到的情况是:我更新的库不再需要.cpp文件,并且已将其从库中删除。直到我进行最后一遍检查发现的错误之后,尽管没有为.cpp文件中的extern变量提供定义的事实,但没有产生链接器错误。这很简单,我可以得到它(头文件):structFoo{voidmethod(){}};externFoofoo;包含此代码并将其用于一个或多个源文件

c++ - 我可以安全地使用#ifdef 来了解是否包含 c++ std header 吗?

首先,我读过这个问题:Isthereawaytodetectportablythatastandardheaderisincludedusingmacros?我想知道的是:使用#ifdef检测是否包含c++stdheader的安全性如何,如下面的代码所示:namespaceoverwrite{usingbyte=unsignedchar;templatevoidwithZeros(generic*toBeOverwriten,size_tlength=1){//dostuff}#ifdef_GLIBCXX_RANDOM//foundthismacroinsidetemplatevoid

c++ - CLion 添加依赖 header 和源

我有一个项目,在某些模块中使用C,而在其他模块中使用C++-所有内容都是使用Makefile构建的。我创建了一个仅调用Makefile的CMakeLists.txt文件,因此可以将项目导入Clion。当我运行我的程序时,我在我之前构建的库之一中遇到段错误(因此,我有源代码、头文件和静态库)——所以我试图在我的项目上下文中调试该库。现在,我的问题是如何在Clion中将header、库和库源添加到我的项目中,以便我可以设置断点并调试它? 最佳答案 您需要使用单独的CMake将您的库添加到源中,例如:set(HEADER_FILES...

c++ - 如何使用 -std=c++17(可选、任意、string_view、变体)在 g++ 6.2.0 中包含 C++ 17 header

std::optional在C++17中,它是std::experimental::optional之前。我尝试编译一个包含的文件,使用命令:g++-std=c++17.cpp(在Bash终端中)。我收到以下错误:.cpp:5:20fatalerror:optional:Nosuchfileordirectory#include^compilationterminated但我可以#include就好了。我是否缺少一些头文件?如何包含optional标题?我也不能包含,或,得到同样的错误。 最佳答案 你不能。GCC6.2'ssuppo

c++ - 是什么导致 clang 找不到 unordered_map header ?

我正在尝试使用Clang++编译我在网上找到的程序。Makefile生成此命令:clang++-c-archx86_64-msse3-std=c++11-stdlib=libstdc++-Wno-missing-field-initializers-Wno-missing-prototypes-Wreturn-type-Wno-non-virtual-dtor-Wno-exit-time-destructors-Wformat-Wmissing-braces-Wparentheses-Wno-switch-Wunused-function-Wunused-label-Wno-unuse

c++ - 在 header 中使用未命名的 namespace 会如何导致 ODR 违规?

在GoogleC++风格指南中,Namespaces部分指出“在头文件中使用未命名的命名空间很容易导致违反C++统一定义规则(ODR)。”我明白为什么不在实现文件中使用未命名的命名空间会导致ODR违规,但不知道在header中使用如何做到这一点。这怎么会导致违规? 最佳答案 原因是如果你真的在匿名中使用任何东西命名空间,你冒着未定义行为的风险。例如:namespace{doubleconstpi=3.14159;}inlinedoubletwoPiR(doubler){return2.0*pi*r;}内联函数(以及类、模板和任何其他

c++ - 使用 boost::filesystem 添加 header 后,不再找到来自 google test 的单元测试

我有一个使用谷歌测试框架的单元测试项目,我的测试工作正常。但是现在我添加了boost::filesystem标题类似#include之后我的项目链接和编译正常,但是根本没有找到测试,当我运行测试时它给了我-Processfinishedwithexitcode-1073741515(0xC0000135)Emptytestsuite.如果我有这段代码:#includeTEST(Test,Test1){ASSERT_FALSE(true);}它工作得很好并找到失败的测试用例,但是如果我像这样添加boostheader:#include#includeTEST(Test,Test1){AS