草庐IT

UIKIT_EXTERN

全部标签

c++ - 为什么在 C++ 命名空间周围使用 extern "C"

几天前,我遇到了这段C++代码,虽然我不能粘贴代码本身,但我可以用一些示例代码重现问题。一、文件namespace.h:#includeusingnamespacestd;namespaceuseless{classX{intm_myint;staticX*m_foobar;X*getPrivVal(void);public:intgetMember(void);X*getStaticVal(void);};}接下来,namespace.cpp:#include"namespace.h"extern"C"{namespaceuseless{X*X::m_foobar=NULL;X*X:

c++ - 为什么在 C++ 命名空间周围使用 extern "C"

几天前,我遇到了这段C++代码,虽然我不能粘贴代码本身,但我可以用一些示例代码重现问题。一、文件namespace.h:#includeusingnamespacestd;namespaceuseless{classX{intm_myint;staticX*m_foobar;X*getPrivVal(void);public:intgetMember(void);X*getStaticVal(void);};}接下来,namespace.cpp:#include"namespace.h"extern"C"{namespaceuseless{X*X::m_foobar=NULL;X*X:

c++ - extern "C"在 C 中是否有任何影响?

我刚刚得到一些使用extern"C"来声明外部函数的C代码,如下所示:extern"C"voidfunc();这是有效的C吗?我在这一行遇到错误,但我不确定是因为这个还是其他原因。 最佳答案 不,它不是有效的C。它只能在C++代码中用于引用在C代码中定义的函数。extern"C"应该包含在ifdef__cplusplus/#endifblock中://Foronefunction#ifdef__cplusplusextern"C"#endifvoidfunc();//Formorethanonefunction#ifdef__cpl

c++ - extern "C"在 C 中是否有任何影响?

我刚刚得到一些使用extern"C"来声明外部函数的C代码,如下所示:extern"C"voidfunc();这是有效的C吗?我在这一行遇到错误,但我不确定是因为这个还是其他原因。 最佳答案 不,它不是有效的C。它只能在C++代码中用于引用在C代码中定义的函数。extern"C"应该包含在ifdef__cplusplus/#endifblock中://Foronefunction#ifdef__cplusplusextern"C"#endifvoidfunc();//Formorethanonefunction#ifdef__cpl

c++ - 使用 extern c 和 dllexport 与模块定义 (msvc++) 进行标准调用名称修改

我试图为dll导出一个简单的测试函数,以便与指定调用约定为的应用程序(仅供引用:mIRC)一起使用:int__stdcalltest_func(HWNDmWnd,HWNDaWnd,char*data,char*parms,BOOLshow,BOOLnopause)现在,要从应用程序中调用它,我会使用test_func,但我注意到由于名称修改,它并不像我想象的那么简单。通过此处的类似主题,我了解到将extern"C"与__declspec(dllexport)结合使用是一种等效的(某种程度上)消除重整的方法到模块定义(.def)。但是,当使用extern/dllexport方法时,我的函

c++ - 使用 extern c 和 dllexport 与模块定义 (msvc++) 进行标准调用名称修改

我试图为dll导出一个简单的测试函数,以便与指定调用约定为的应用程序(仅供引用:mIRC)一起使用:int__stdcalltest_func(HWNDmWnd,HWNDaWnd,char*data,char*parms,BOOLshow,BOOLnopause)现在,要从应用程序中调用它,我会使用test_func,但我注意到由于名称修改,它并不像我想象的那么简单。通过此处的类似主题,我了解到将extern"C"与__declspec(dllexport)结合使用是一种等效的(某种程度上)消除重整的方法到模块定义(.def)。但是,当使用extern/dllexport方法时,我的函

c++ - C++0x 是否支持 __stdcall 或 extern "C"capture-nothing lambdas?

昨天我在考虑是否可以使用C++0xlambda函数的便利性来为WindowsAPI函数编写回调。例如,如果我想使用lambda作为EnumChildProc怎么办?与EnumChildWindows?比如:EnumChildWindows(hTrayWnd,CALLBACK[](HWNDhWnd,LPARAMlParam){//...returnstatic_cast(TRUE);//continueenumerating},reinterpret_cast(&myData));另一个用途是为C例程编写extern"C"回调。例如:my_class*pRes=static_cast(b

c++ - C++0x 是否支持 __stdcall 或 extern "C"capture-nothing lambdas?

昨天我在考虑是否可以使用C++0xlambda函数的便利性来为WindowsAPI函数编写回调。例如,如果我想使用lambda作为EnumChildProc怎么办?与EnumChildWindows?比如:EnumChildWindows(hTrayWnd,CALLBACK[](HWNDhWnd,LPARAMlParam){//...returnstatic_cast(TRUE);//continueenumerating},reinterpret_cast(&myData));另一个用途是为C例程编写extern"C"回调。例如:my_class*pRes=static_cast(b

c++ - 如何防止 extern "C"函数过载?

我正在编写一个c++库,它公开了一些仅由C#代码使用的函数。但是,由于我不小心打错了参数,我发现只要不使用cpp文件中的(notmistypedversion)函数,即使没有任何警告,这段代码也可以成功编译和链接。structDummy{inta;doubleb;};extern"C"voidSetArray(Dummy*x,intcnt);voidSetArray(Dummyx,intcnt){//aTODOplaceholder.}如何让编译器针对这种情况抛出错误或警告?编译器选项-Wall已设置,但仍然没有警告。使用tdmgcc5.1.0。 最佳答案

c++ - 如何防止 extern "C"函数过载?

我正在编写一个c++库,它公开了一些仅由C#代码使用的函数。但是,由于我不小心打错了参数,我发现只要不使用cpp文件中的(notmistypedversion)函数,即使没有任何警告,这段代码也可以成功编译和链接。structDummy{inta;doubleb;};extern"C"voidSetArray(Dummy*x,intcnt);voidSetArray(Dummyx,intcnt){//aTODOplaceholder.}如何让编译器针对这种情况抛出错误或警告?编译器选项-Wall已设置,但仍然没有警告。使用tdmgcc5.1.0。 最佳答案