草庐IT

HK_EXTERN

全部标签

c++ - extern C 的 undefined reference

我正在尝试使用包含Aquila的Netbeans(g++)编译程序,anopensourcelibary.我关注了theinstallationinstructions.但是当试图编译一个小的测试程序时,我得到了这个错误Infunction`Aquila::OouraFft::fft(doubleconst*)':OouraFft.cpp:(.text+0x24f):undefinedreferenceto`cdft'OouraFft.h:#include"Fft.h"extern"C"{voidcdft(int,int,double*,int*,double*);//prototyp

c++ - 外部链接和 »extern "C"« block

我有一个intID,我想在C++中定义它并使其可用于C链接(为简单起见设计的案例):/*i.h*/#ifdef__cplusplusextern"C"{#endifexternintID;#ifdef__cplusplus}#endif这是一个使用int的C和C++程序:/*m.cpp*/#include"i.h"#includeintmain(){std::coutintmain(){printf("%d\n",ID);}现在我想知道的是extern"C"和/或extern的语法。以下是可以和不能定义intID的方式:/*i.cpp*///constintID=88;//noClin

c++ - 在 C++ 中对用户定义的类型使用 extern 关键字

我想对用户定义的类型使用extern关键字。这意味着我在一个文件中声明了对象并在另一个文件中定义了它。我读过extern关键字用于声明变量而不定义它。当程序被拆分成多个源文件并且每个源文件都需要使用全局变量时,extern关键字很有用。如果我在某个地方错了,请纠正我。这是我编写的程序,但不幸的是我做错了什么或遗漏了什么,所以我遇到了编译器错误。Prog1.cpp#includeusingstd::cout;classtest{public:voidfun();};voidtest::fun(){coutProg2.cpp#includeusingstd::cout;externtest

c++ - 在非函数调用相关声明上使用 "extern C"

我知道之前有人问过有关extern"C"的问题,但我收到的信号很复杂,希望有人能指出以下场景中的最佳实践。我已经为Linux编写了一个驱动程序,并定义了几个struct以及一些_IO、_IOR和_IOWioctl(...)调用的定义。我的结构都不包含任何函数,下面是我使用的struct、enum和ioctl示例:#ifdef__cplusplusextern"C"{#endifenumAlignment{Left=0,Right=1,Middle=3};structData{intSize;void*Address;};#definefoo_IOR(DRV_ID,1,structDat

c++ - Windows 上 DLL Exporting/Importing 和 Extern 的问题

我有一些关于Windowsdll的快速问题。基本上我使用ifdefs来处理dllexport和dllimport,我的问题实际上是关于dllexports和dllimports以及extern关键字的放置。我将dllimports/dllexports放在头文件中,但我是否必须将dllexport和dllimports放在实际定义中?对于typedef呢?我是否将dllimport/dllexport放在前面?如dllexporttypedefmapst_map另外关于extern关键字,我看到它被这样使用:extern"C"{dllexportvoidfunc1();}我也看到它被这

java - 关于extern "C"的C++到Java的转换问题

我必须将一些C/C++代码转换为Java。我的C++非常生锈。在.h文件中,我有以下内容:#ifdef__cplusplusextern"C"{#endif/*tonsofdeclarations*/#ifdef__cplusplus}/*externC*/#endifextern"C"有什么用?这是什么意思?它是否告诉编译器相应的代码应该被解释为纯C,而不是C++?编辑感谢您到目前为止的回答。我必须转换的代码的历史是,似乎一部分是先用C编写的,然后其余部分是用C++编写的。所以我的头文件似乎对应于“旧”C代码。我会将此代码转换为具有静态方法和属性的publicfinalclass。没

c++ - 在每个源文件中替代 "extern template"

我正在开发一个库,其中我们的许多核心对象都是模板,其中一个特定实例以指向该模板实例的智能指针的形式出现在项目的大多数文件中。我在单个源文件中明确实例化了这些模板。我们最近切换到C++11,我正在尝试使用新的externtemplateclassMyTemplate;加快编译速度。我的第一个问题是我是否在周围使用智能指针MyTemplate正在隐式实例化模板并要求文件顶部的“外部模板..”以避免重复实例化。我的第二个问题是是否有一些替代方法来添加所有这些externtemplateclassMyTemplate;到每个源文件。为我定义的每个模板搜索智能指针的每个实例并确保我在该文件中有正

c++ - 从常规 C++ 代码调用 CUDA 代码——整理出 extern "C"

我正在尝试从单独编译的C++文件调用CUDA(主机)函数:sample.cppC++文件:extern"C"voidcuda_function(inta,intb);intmain(){//statementscuda_function(23,34);//statements}cuda.cu文件:#include__global__voidkernel(inta,intb){//statements}voidcuda_function(inta,intb){//cuda_function}构建命令:g++-csample.cppnvcc-ccuda.cunvcc-osamplesamp

c++ - extern 和 extern "C"用于变量

我正在编写供C程序使用的C++共享库。但是,我对extern和extern"C"有疑问。考虑以下代码我的头文件是这样的:#ifdef__cplusplusextern"C"intglobal;extern"C"intaddnumbers(inta,intb);#elseexternintglobal;#endif这很好用;我只需要声明intglobal;在我的.cpp或我的.c文件中。但是,我不明白的是:extern"C"和extern有什么区别?我尝试注释掉extern"C"intglobal并且有效!为什么?我知道extern"C"用于建立C链接。这就是为什么我有extern"C"

C++:extern "C"和类成员之间的命名空间冲突

我偶然发现了一个相当奇特的c++命名空间问题:浓缩示例:extern"C"{voidsolve(lprec*lp);}classA{public:lprec*lp;voidsolve(intfoo);}voidA::solve(intfoo){solve(lp);}我想在我的C++成员函数A::solve中调用c函数solve。编译器对我的意图不满意:errorC2664:'lp_solve_ilp::solve':cannotconvertparameter1from'lprec*'to'int'我可以在solve函数前加前缀吗?C::solve不起作用