调用c函数时出现分段错误

问题描述:

我创建了一个包含c_mainwrapper的静态库(将其命名为myStaticLib)。如果我创建一个测试应用程序,我可以毫无问题地调用函数MainControllerInitiate();调用c函数时出现分段错误

当我使用myStaticLib和c_wrapper创建共享库时,我可以调用connectCreate();而没有任何问题。但是当我尝试拨打MainControllerInitiate(); 时,我收到了分段错误。

文件:
c_mainwrapper.h

(...) 
typedef void* MainController_p; 
extern MainController_p (*createMainController)() 

#ifdef __cplusplus 
#define EXTERNC extern "C" 
#else 
#define EXTERNC 
#endif 

EXTERNC void MainControllerInitiate(); 
(...) 

#undef EXTERNC 
(...) 

c_mainwrapper.cpp

(...) 
MainController_p (*createMainController)() = NULL; 
(...) 
void MainControllerInitiate() 
{ 
    if (createMainController != NULL) 
    { 
     createMainController(); 
    } 
} 
(...) 

c_wrapper.h

(...) 
#include <c_mainwrapper.h> 

#ifdef __cplusplus 
#define EXTERNC extern "C" 
#else 
#define EXTERNC 
#endif 

EXTERNC void connectCreate(); 
(...) 

#undef EXTERNC 
(...) 

c_wrapper.cpp

(...) 
MainController_p createController() 
{ 
    return new MainController(); 
} 

void connectCreate() 
{ 
    createMainController = &createController; 
} 
(...) 

编辑:
的失败的测试应用程序只是:

#include <c_wrapper> 

int main(int argc, char *argv[]) 
{ 
    connectCreate(); 
    MainControllerInitiate(); // here the Segmentation fault occures 

    return 0; 
} 

EDIT2: 新增失踪createMainController = NULL

+0

派息你一步虽然它与调试器? – 2014-10-27 14:59:09

+0

我错过了'createMainController = NULL;' – Surt 2014-10-27 15:05:06

+0

@MichaelWalz:是的,我可以通过connectCreate(),但是当它涉及到MainControllerInitiate()时,它会失败。当我只使用静态库,我可以调用,并通过MainControllerInitiate()没有任何问题。 – 2014-10-27 15:13:07

发现myselfe问题:

无人问项目文件(标签qt)。我将静态库编译为debug AND release。并在共享库项目文件我写道:

CONFIG(release : debug|release) 
{ 
    unix:!macx: LIBS += -L../../Build_Directory/x86/Release/myStaticLib \ 
    -lmyStaticLib 
} 
CONFIG(debug: debug|release) 
{ 
    unix:!macx: LIBS += -L../../Build_Directory/x86/Debug/myStaticLib \ 
    -lmyStaticLib 
} 

问题是,我使用了错误的语法。我必须

CONFIG(release, debug|release){ 

,而不是

CONFIG(release : debug|release) 
{ 

所以链接的共享库对静态库每次的发行版本。我自己强迫共享库中的错误。但我认为我会使用静态库的调试版本,并可能直接通过代码直到错误。

结论:对库调试版本的链接,如果你想步库代码,并检查补充文件