두 개의 GCC 컴파일 된 .o 개체 파일을 세 번째 .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
답변
전달 -relocatable
또는 -r
to ld
는의 입력으로 적합한 객체를 생성합니다 ld
.
$ ld -relocatable 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
답변
두 개 이상의 .o 파일 (예 : 정적 라이브러리)의 아카이브를 만들려면 다음 ar
명령을 사용하십시오 .
ar rvs mylib.a file1.o file2.o