Подтвердить что ты не робот

Объединить два GCC скомпилированных .o объектных файлов в третий файл .o

Как объединить два скомпилированных файла .o в GCC в третий файл .o?

$ gcc -c  a.c -o a.o
$ gcc -c  b.c -o b.o
$ ??? a.o b.o -o c.o
$ gcc c.o other.o -o executable

Если у вас есть доступ к исходным файлам, флаг -combine GCC объединяет исходные файлы перед компиляцией:

$ gcc -c -combine a.c b.c -o c.o

Однако это работает только для исходных файлов, а GCC не принимает файлы .o в качестве входных данных для этой команды.

Обычно связывание файлов .o работает неправильно, так как вы не можете использовать вывод компоновщика в качестве ввода для него. Результатом является общая библиотека и не статически ставится в результирующий исполняемый файл.

$ gcc -shared a.o b.o -o c.o
$ gcc c.o other.o -o executable
$ ./executable
./executable: error while loading shared libraries: c.o: cannot open shared object file: No such file or directory
$ file c.o
c.o: ELF 32-bit LSB shared object, Intel 80386, version 1 (SYSV), dynamically linked, not stripped
$ file a.o
a.o: ELF 32-bit LSB relocatable, Intel 80386, version 1 (SYSV), not stripped
4b9b3361

Ответ 1

Передача -r или --relocatable для ld создаст объект, подходящий для ввода ld.

$ ld -r a.o b.o -o c.o
$ gcc c.o other.o -o executable
$ ./executable

Сгенерированный файл того же типа, что и исходные файлы .o.

$ file a.o
a.o: ELF 32-bit LSB relocatable, Intel 80386, version 1 (SYSV), not stripped
$ file c.o
c.o: ELF 32-bit LSB relocatable, Intel 80386, version 1 (SYSV), not stripped

Ответ 2

Если вы хотите создать архив из двух или более файлов .o(т.е. статической библиотеки), используйте команду ar:

ar rvs mylib.a file1.o file2.o