Я создаю исполняемый файл с этим:
gcc elliptical.o -Llibs -lhfcal -o elliptical
В моей подпапке libs есть:
libhfcal.a libhfcal.so
файлы. Моя цель - использовать динамическую библиотеку, но я все еще не понял, как она выбирает файл .so
, когда я явно не ссылался на него. Я знаю, что пытаюсь использовать .so
, потому что при запуске исполняемого файла я получил
./elliptical: error while loading shared libraries: libhfcal.so: cannot open shared object file: No such file or directory
Использование статической библиотеки для создания исполняемой команды, такой же, как и динамической. Я знаю, что мне нужно использовать LD_LIBRARY_PATH
, но мой вопрос: почему компилятор выбрал библиотеку динамики?
Но я использовал ту же команду для своего файла .a и работал. после этого я создал этот файл .so для запуска динамической компоновки.
Из руководство gcc (выделено мной):
-l library
Search the library named library when linking. (The second alternative with the library as a separate argument is only for POSIX compliance and is not recommended.)
The -l option is passed directly to the linker by GCC. Refer to your linker documentation for exact details. The general description below applies to the GNU linker.
The linker searches a standard list of directories for the library. The directories searched include several standard system directories plus any that you specify with -L.
Static libraries are archives of object files, and have file names like liblibrary.a. Some targets also support shared libraries, which typically have names like liblibrary.so. If both static and shared libraries are found, the linker gives preference to linking with the shared library unless the -static option is used.
вау, очень ценю. Теперь все ясно.
-lhfcal
делает именно это, ссылка наlibhfcal.so