草庐IT

external_deps

全部标签

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

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

c++ - 扭曲的逻辑 : a global variable in one file refers to an extern variable but is also referred by that extern variable

文件A.cpp:#includeexternintiA;externintiB=iA;intmain(){std::cout文件B.cppexternintiB;externintiA=2*iB;编译链接运行,out进来debug和release模式是0,0我的问题是它是如何工作的,为什么在链接阶段没有问题?我正在使用VC++2003。 最佳答案 初始化程序覆盖了extern关键字,因此这没有什么“神奇”:您只是在不同的翻译单元中声明和定义两个完全不相关的变量。来自StandardforProgrammingLanguageC++-

c++ - 更好地理解 extern "C"函数

我只是想进一步了解externC函数。据我所知,externC函数始终是您尝试从已编译的应用程序调用的函数。可执行文件、静态或动态库。extern"C"{HRESULTCreateDevice();typedefHRESULT(*CREATEDEVICE)();HRESULTReleaseDevice();typedefHRESULT(*RELEASEDEVICE)();}所以我的问题是...我的理解对吗??它总是必须是C函数指针吗??'为什么必须为每个函数使用typedef??我假设当您使用GetProcAddress()时。您正在为特定应用程序HEAP而不是您从中调用它的应用程序分

c++ - 使用 `extern template` 防止模板类的隐式实例化

考虑以下代码片段:templatestructX{};externtemplatestructX;intmain(){X{};}它编译并链接:liveexampleongodbolt.org.由于externtemplate声明,我希望它不会链接。我的理解是externtemplate的意思是:“请不要在这个TU中实例化这个特定的模板特化,它将由其他一些TU提供,你可以链接到它”.示例/描述。我在isocpp上看到过,cppreference似乎验证了我的心智模型。例如Fromhttps://en.cppreference.com/w/cpp/language/class_templa

c++ - extern 在命名空间中如何工作?

我正在运行一个类似于我发现的简单程序here.它旨在减少在多个文件中包含常量时的代码膨胀。它通过在命名空间中使用const全局变量及其各自的extern前向声明来实现这一点。globals.h#ifndefGLOBALS_H_#defineGLOBALS_H_namespaceConstants{//forwarddeclarationsonlyexternconstdoublepi;externconstdoubleavogadro;externconstdoublemy_gravity;}#endif全局变量.cppnamespaceConstants{//actualglobal

c++ - extern 在 C++ 中如何工作?

这是来自:namespacestd{externistreamcin;///似乎通过使用extern其他命名空间中定义的数据类型是否可用? 最佳答案 extern表示“这些变量在其他一些编译单元(.cpp或.lib文件)中定义”在这种情况下,您#include进入你的.cpp文件,因为cin和cout被声明为extern,编译器会让你毫无怨言地使用它们。然后,当链接器运行时,它会查找所有extern变量并将其全部排序。 关于c++-extern在C++中如何工作?,我们在StackOve

c++ - 错误 : LNK 2019 : unresolved external symbol _imp_CrtDbgReportw in Visual Studio

我编写了一个程序,在出现相应的分隔符时拆分字符串。但是发生了一个不同的错误,例如:Error1errorLNK2019:unresolvedexternalsymbol__imp___CrtDbgReportWreferencedinfunction"public:charconst&__thiscallstd::_String_const_iterator>>::operator*(void)const"(??D?$_String_const_iterator@V?$_String_val@U?$_Simple_types@D@std@@@std@@@std@@QBEABDXZ)So

c++ - 如果我将 extern "C++"与 C 工具链一起使用会怎样?

我的问题主要是关于C++工具链“理解”C和C++的事实,所以如果我将一些带有extern"C"的代码提供给C++工具链,我假设它可以理解怎么办?但是,如果我将带有extern"C++"的代码提供给C工具链呢?预期的行为是什么? 最佳答案 如果编译器还理解C++,它可能会接受它。如果它是一个纯C编译器,它将反对(就像它在extern"C"上一样,因为该语法无效C-这就是为什么它通常包含在#ifdef__cplusplus或类似的) 关于c++-如果我将extern"C++"与C工具链一起使

C++ Unresolved external

这个问题在这里已经有了答案:Whatisanundefinedreference/unresolvedexternalsymbolerrorandhowdoIfixit?(38个答案)关闭3年前。谁知道这是什么意思?1>GeneratingCode...1>BlankWindowDXbaseImpl.obj:errorLNK2019:unresolvedexternalsymbol"public:__thiscallDXBase::DXBase(void)"(??0DXBase@@QAE@XZ)referencedinfunction"public:__thiscallBlankWin

c++ - extern"C"与 extern 的区别

我对整个header使用extern"C"说明符,还是为每个函数指定extern有区别吗?据我所知,没有,因为只有函数和变量可以外部链接,所以当我在每个函数原型(prototype)和外部变量之前使用extern说明符时,我不需要使用全局extern"C"声明!?示例A:#ifdef__cplusplusextern"C"{#endifvoidwhatever(void);#endif示例B:externvoidwhatever(void); 最佳答案 C++文件中extern"C"的存在允许从C客户端调用程序代码调用特定的C++函