从 C 调用静态 C++ 方法在编译时给出未定义的引用

Calling static C++ method from C gives undefined reference when compiled

这是一组简单的文件,可以重现我遇到的问题:

c.h:

void dummy();

c.cpp:

#include <stdio.h>
extern "C" {
#include "c.h"
}

class Bubu {
public:
  static Bubu *getInstance() {
    if (_instance == NULL) {
      _instance = new Bubu;
    }
    return _instance;
  }

private:
  static Bubu *_instance;
};

Bubu *_instance = NULL;

void dummy() {
  printf("bubu called\n");
  Bubu *ptr = Bubu::getInstance();
}

main.cpp:

extern "C" {
#include "c.h"
}

int main() {
  dummy();
  return 0;
}

当我编译时我得到这个:

g++ -W -Wall -c c.cpp -o c.o
c.cpp: In function ‘int bubu()’:
c.cpp:24: warning: unused variable ‘ptr’
g++ -W -Wall main.cpp c.o -o main
c.o: In function `Bubu::getInstance()':
c.cpp:(.text._ZN4Bubu11getInstanceEv[Bubu::getInstance()]+0x7): undefined reference to `Bubu::_instance'
c.cpp:(.text._ZN4Bubu11getInstanceEv[Bubu::getInstance()]+0x1d): undefined reference to `Bubu::_instance'
c.cpp:(.text._ZN4Bubu11getInstanceEv[Bubu::getInstance()]+0x24): undefined reference to `Bubu::_instance'
collect2: ld returned 1 exit status
make: *** [main] Error 1
Compilation exited abnormally with code 2 at Tue Dec 15 09:15:21

我已经看到了其他类似问题的答案,但问题是在调用静态方法时缺少 Bubu::,或者在 class 声明之外缺少静态成员的初始化,或者缺少extern "C" 构造。我相当确定我不会犯那些错误……我肯定会犯其他错误。 你能解释一下这是怎么回事吗?

当您在 class 中定义静态变量时,您还必须在 class 之外定义它。您尝试这样做,但是

Bubu *_instance = NULL;

只会创建一个指向 Bubu 的全局指针,不会实例化 class 中的静态指针。你需要使用

Bubu *Bubu::_instance = NULL;

告诉编译器这将是 class.

中的静态变量