草庐IT

include_guard_symbol

全部标签

c++ - 为什么有些人在 C++ 程序的开头放一个空白的#include?

关闭。这个问题是notreproducibleorwascausedbytypos.它目前不接受答案。这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topic在这里,这个问题的解决方式不太可能帮助future的读者。关闭7年前。Improvethisquestion我见过一些程序在开头有一个空白的#include。我想知道这背后的目的是什么?像这样:#include#include//includemorestuff示例链接:http://mkaczanowski.com/beaglebone-black-cpp-gpio-library-for-beginn

c++ - 架构 i386 的 undefined symbol :

我最近转向了Mac,并且正在努力使用命令行编译器。我正在使用g++进行编译,这可以很好地构建单个源文件。如果我尝试添加自定义头文件,当我尝试使用g++进行编译时,我会得到架构i386的undefinedsymbol。然而,这些程序在xCode中编译得很好。我是否遗漏了一些明显的东西?尝试使用g++-m32main.cpp...不知道还能尝试什么。好的,旧代码已编译...已将其缩小到我的构造函数。classMatrix{public:inta;intdeter;Matrix();intdet();};#include"matrix.h"Matrix::Matrix(){a=0;deter

c++ - 为什么 include 指令在头文件之上?

我曾经在编程课上被告知,C++通过让程序员在功能block的任何位置声明其变量来实现更好的可读性。这样,变量与处理它的代码部分组合在一起。为什么我们不对包含做同样的事情?换句话说,为什么不鼓励将包含文件放在实际使用它的定义旁边?parser::parser(){//someinitializationgoestherewhichdoesnotmakeuseofregex}#includeparser::start(){//hereweneedtouseboostregextoparsethedocument} 最佳答案 其中一个原因

C++ 函数模板,体系结构的 undefined symbol

这个问题在这里已经有了答案:Whycantemplatesonlybeimplementedintheheaderfile?(17个答案)关闭8年前。有人可以向我解释为什么以下代码无法编译吗?希望是我错过的显而易见的事情......函数.hpp:templatestringvector_tostr(std::vectorv);函数.cpp:templatestringvector_tostr(std::vectorv){std::stringstreamss;std::stringthestring="";if(v.size()>0){ssmain.cpp#include"functi

c++ - 您可以使用#define 来更改#include 吗?

是否可以使用#include更改包含的库?或#include"foo"在预占有期间变成不同的东西,所以它会充当不同的库,例如#include?我有一个无法使用当前#include的库只在一种情况下声明,但在其他地方工作正常,所以我不想直接改变它。是否可以使用#define解决这个问题? 最佳答案 有两种方法可以做到这一点。更简单、更明显的方法:#defineINCLUDE_FOO//...#ifdefINCLUDE_FOO#include#else#include#endif还有更短但更挑剔的方式:#defineFOO_HEADER

c++ - Qt 5.4 静态构建在 Visual Studio 2013 中产生 "unresolved external symbol"链接错误

我想使用Qt5.4的静态构建。由于没有可用的预编译静态构建,您必须自己从Qt源代码构建一个。我的环境如下:Windows7x64VisualStudio2013终极更新4Qt5VisualStudio插件1.2.4已安装ActivePerl/ActivePython(需要构建Qt源代码)我的程序如下(参见QtDocumentation>Qt5.4>QtforWindows-BuildingfromSource):下载qt-everywhere-opensource-src-5.4.0.zip解压缩到一个临时文件夹按照here所述打开命令提示符(基本上,这类似于打开“VisualStud

c++ - 智能指针是否破坏了头文件中最小化#includes 的原则?

我更愿意尽量减少使用#include在我的头文件中,尽可能使用前向声明,我相信这被认为是好的做法。如果我有一个像这样的方法声明,它会很好用:boolIsFlagSet(MyObject*pObj);但是如果我有typedefPtrMyObjectPtr在MyObject.hAPI更改为:boolIsFlagSet(MyObjectPtrpObj);我现在有到#include"MyObject.h"吗??有什么办法解决这个问题,还是这只是使用智能指针的代价? 最佳答案 不,您不必这样做。您可以为不完整的类定义类型别名,模板参数可以是不

c++ - libtool:i686-pc-mingw32 共享中不允许使用 undefined symbol

我正在使用autotools作为我的图书馆的构建系统。最近图书馆被移植到Windows。虽然我遇到了一个奇怪的错误,但库编译和链接成功。配置和制作后只有静态库。除了来自libtool的警告外,一切看起来都正常:libtool:undefinedsymbolsnotallowedini686-pc-mingw32shared我已经通过这段代码导出了Windows机器的所有符号:#ifdef_WIN32#ifdefDLL_EXPORT#defineLIBRARY_API__declspec(dllexport)#else#defineLIBRARY_API__declspec(dllimp

c++ - Unresolved external symbol 错误仅发生在 64 位模式中,而不是在 32 位构建中

我有一个VC++代码(使用VS2008构建),它使用了一些静态库(*.lib文件在编译时静态链接)。为了便于理解,我们将我的EXE代码称为“AAA.EXE”并将lib文件称为“A.lib”、b.lib等...AAA.EXE代码和静态库代码都是使用VS2008构建的。我看到我的“AAA.EXE”在32位版本中运行良好,并且在以64位模式构建AAA.EXE时显示以下链接器错误。当然,我已经在64位模式下重建了静态库,并在我的AAA.EXE中提供了lib路径,如下所示:::“对应于AAA.EXE的项目配置属性->链接器->常规/输入”。这个链接器错误真的困扰了我很长时间。任何帮助是极大的赞赏

c++ - std::lock_guard 导致未定义的行为

编辑:看起来,问题是我实际上并没有创建一个lock_guard的本地实例,而只是一个匿名的临时实例,它立即再次被销毁,如下面的评论所指出的。Edit2:启用clang的线程清理器有助于在运行时查明这些类型的问题。它可以通过启用clang++-std=c++14-stdlib=libc++-fsanitize=thread*.cpp-pthread这在某种程度上可能是一个重复的问题,但我找不到任何东西,所以如果它真的是重复的,我很抱歉。无论如何,这应该是一个初学者问题。我正在玩一个简单的“Counter”类,比如在文件中内联计数器.hpp:#ifndefCLASS_COUNTER_HPP