Почему при создании общих объектов я получаю ошибку "неопределенная ссылка" в gcc? - PullRequest
19 голосов
/ 15 ноября 2011

Почему я получаю ошибку "неопределенная ссылка" при использовании gcc?

Я пытаюсь создать общий объект (.so), который экспортирует одну функцию "external ()". Затем я пытаюсь сделать ссылку на .so, но получаю «неопределенную ссылку« внешняя »». Что я тут не так делаю?

Файл: external.c

int external() {
    return 5;
}

Файл: program.c

int external();
int main(char** argv, int* argc) {
    return external();
}

Команда:

$ gcc -fPIC -c external.c
$ gcc -shared -o libexternal.so external.o
$ gcc -L. -lexternal -o program program.c
/tmp/cc3MmhAE.o: In function `main':
program.c:(.text+0x7): undefined reference to `external'
collect2: ld returned 1 exit status

Я могу даже запустить nm и увидеть, что .so определяет 'external':

Команда:

$ nm libexternal.so | grep external
0000040c T external

Что мне здесь не хватает?

1 Ответ

37 голосов
/ 15 ноября 2011

Последние версии gcc / ld по умолчанию связаны с --as-needed.

Это означает, что если вы напишите -lexternal перед C-файлом, библиотека автоматически будет исключена (порядок имеет значение при тестировании, если что-то "нужно", как это)

Вы можете исправить это с помощью:

  • gcc -L. -o program program.c -lexternal
  • gcc -L. -Wl,--no-as-needed -lexternal -o program program.c

Последний из них передает --no-as-needed компоновщику, что приведет к тому, что библиотека все еще будет связана, даже если вы не вызывали external() из нее.

Примечание: -Wl,--no-as-needed не применяется глобально ко всему, что связано, оно применяется только к вещам, которые следуют за ним в порядке командной строки. Так что -lexternal -Wl,--no-as-needed тоже не сработает. Это означает, что вы можете смешивать и сопоставлять поведение, хотя, например, gcc -L. -Wl,--no-as-needed -lexternal -Wl,--as-needed -o program program.c -lmightneed всегда будет ссылаться на внешнее, но только на возможное , если один или оба из program.c / libexternal.so вызвали его необходимо.

...