리눅스 시스템의 컴파일 명령어는 "Make"입니다. Linux 시스템에서 make는 매우 중요한 컴파일 명령입니다. 관리자는 이를 사용하여 명령줄을 통해 많은 오픈 소스 도구를 컴파일하고 설치합니다. 프로그래머는 이를 사용하여 크고 복잡한 프로젝트의 컴파일 문제를 관리합니다. make는 대규모 프로그램의 자동 컴파일 작업을 관리하고, 프로그램의 특정 부분을 다시 컴파일해야 하는지 자동으로 결정하고, 컴파일 지침을 발행하는 데 사용됩니다.
이 튜토리얼의 운영 환경: linux7.3 시스템, Dell G3 컴퓨터.
Linux의 make 명령은 시스템 관리자와 프로그래머가 가장 자주 사용하는 명령 중 하나입니다. 관리자는 이를 사용하여 명령줄을 통해 많은 오픈 소스 도구를 컴파일하고 설치하며, 프로그래머는 이를 사용하여 크고 복잡한 프로젝트의 컴파일 문제를 관리합니다. 이 기사에서는 몇 가지 예를 사용하여 make 명령 뒤에 있는 작업 메커니즘을 논의합니다.
make는 Linux 시스템용 유틸리티 프로그램입니다. 이는 대규모 프로그램의 자동 컴파일 작업을 관리하고, 프로그램의 특정 부분을 다시 컴파일해야 하는지 자동으로 결정하고, 컴파일 지침을 발행하는 데 사용됩니다. 하지만 우리는 C 언어 프로그램을 컴파일할 때 가장 일반적으로 사용합니다. 그러나 make는 특정 언어로 제한되지 않으며 쉘 명령을 통해 컴파일러를 실행할 수 있는 모든 언어에서 사용할 수 있습니다. 또한 make를 사용하면 파일이 변경된 후 파일을 자동으로 업데이트해야 하는 빌드 작업을 설명할 수도 있습니다.
메이크의 메커니즘을 모르는 분들을 위해 설명하자면, make 명령은 명령줄 인수처럼 대상을 받아들입니다. 이러한 목표는 일반적으로 "Makefile"이라는 특수 파일에 저장되며 파일에는 목표에 해당하는 작업도 포함됩니다. 자세한 내용은 Makefile 작동 방식에 대한 이 기사 시리즈를 읽어보세요.
make 명령이 처음 실행되면 Makefile을 스캔하여 대상과 해당 종속성을 찾습니다. 이러한 종속성 자체가 대상인 경우 Makefile에서 이러한 종속성을 계속 검색하여 종속성을 설정한 다음 컴파일합니다. 기본 종속성이 컴파일되면 기본 대상이 컴파일됩니다(make 명령을 통해 전달됨).
이제 특정 소스 파일을 수정하고 make 명령을 다시 실행한다고 가정하면 소스 파일과 관련된 대상 파일만 컴파일되므로 최종 실행 파일을 컴파일하면 많은 시간이 절약됩니다.
다음은 이 글에서 사용한 테스트 환경입니다.
OS —— Ubunut 13.04 Shell —— Bash 4.2.45 Application —— GNU Make 3.81
다음은 프로젝트 내용입니다.
$ ls
anotherTest.c Makefile test.c test.h
Makefile 내용은 다음과 같습니다.
all: test test: test.o anotherTest.o
gcc -Wall test.o anotherTest.o -o testtest.o: test.c
gcc -c -Wall test.c
anotherTest.o: anotherTest.c
gcc -c -Wall anotherTest.c
clean:
rm -rf *.o test
이제 Linux를 살펴보겠습니다. 다음은 make 명령 응용 프로그램의 몇 가지 예입니다.
전체 프로젝트를 컴파일하려면 간단히 make
를 사용하거나 대상을 추가하면 됩니다. make 명령 뒤의 모든 것
. make
或者在 make 命令后带上目标 all
。
$ make
gcc -c -Wall test.c
gcc -c -Wall anotherTest.c
gcc -Wall test.o anotherTest.o -o test
你能看到 make 命令第一次创建的依赖以及实际的目标。
如果你再次查看目录内容,里面多了一些 .o 文件和执行文件:
$ ls
anotherTest.c anotherTest.o Makefile test test.c test.h test.o
现在,假设你对 test.c 文件做了一些修改,重新使用 make 编译工程:
$ make
gcc -c -Wall test.c
gcc -Wall test.o anotherTest.o -o test
你可以看到只有 test.o 重新编译了,然而另一个 Test.o 没有重新编译。
现在清理所有的目标文件和可执行文件 test,你可以使用目标 clean
:
$ make clean
rm -rf *.o test$ ls
anotherTest.c Makefile test.c test.h
你可以看到所有的 .o 文件和执行文件 test 都被删除了。
到目前为止,你可能注意到 make 命令不会编译那些自从上次编译之后就没有更改的文件,但是,如果你想覆盖 make 这种默认的行为,你可以使用 -B 选项。
下面是个例子:
$ make
make: Nothing to be done for `all’.$ make -B
gcc -c -Wall test.c
gcc -c -Wall anotherTest.c
gcc -Wall test.o anotherTest.o -o test
你可以看到尽管 make 命令不会编译任何文件,然而 make -B
会强制编译所有的目标文件以及最终的执行文件。
如果你想知道 make 执行时实际做了什么,使用 -d 选项。
这是一个例子:
$ make -d | more
GNU Make 3.81
Copyright (C) 2006 Free Software Foundation, Inc.
This is free software; see the source for copying conditions.
There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A
PARTICULAR PURPOSE.
This program built for x86_64-pc-linux-gnu
Reading makefiles…
Reading makefile `Makefile’…
Updating makefiles….
Considering target file `Makefile’.
Looking for an implicit rule for `Makefile’.
Trying pattern rule with stem `Makefile’.
Trying implicit prerequisite `Makefile.o’.
Trying pattern rule with stem `Makefile’.
Trying implicit prerequisite `Makefile.c’.
Trying pattern rule with stem `Makefile’.
Trying implicit prerequisite `Makefile.cc’.
Trying pattern rule with stem `Makefile’.
Trying implicit prerequisite `Makefile.C’.
Trying pattern rule with stem `Makefile’.
Trying implicit prerequisite `Makefile.cpp’.
Trying pattern rule with stem `Makefile’.
--More--
这是很长的输出,你也看到我使用了 more
$ ls file file2 frnd frnd1.cpp log1.txt log3.txt log5.txt file1 file name with spaces frnd1 frnd.cpp log2.txt log4.txt
$ make -C ../make-dir/ make: Entering directory `/home/himanshu/practice/make-dir’ make: Nothing to be done for `all’. make: Leaving directory `/home/himanshu/practice/make-dir이제 test.c 파일을 일부 수정했다고 가정하고 make를 다시 사용하여 프로젝트:
make -f my_makefiletest.o만 재컴파일되었지만 다른 Test.o는 재컴파일되지 않은 것을 볼 수 있습니다. 🎜🎜이제 모든 개체 파일과 실행 파일 테스트를 정리하려면
clean
대상을 사용할 수 있습니다.🎜🎜rrreee🎜🎜모든 .o 파일과 실행 파일 테스트가 삭제된 것을 확인할 수 있습니다. 🎜🎜🎜2. -B 옵션을 사용하여 모든 대상을 항상 다시 빌드하도록 합니다.🎜🎜🎜지금까지 make 명령이 마지막 컴파일 이후 변경되지 않은 파일을 컴파일하지 않는다는 것을 알 수 있습니다. 덮어쓰기 make의 기본 동작을 위해 -B 옵션을 사용할 수 있습니다. 🎜🎜예는 다음과 같습니다. 🎜🎜rrreee🎜🎜 make 명령은 어떤 파일도 컴파일하지 않지만 make -B
는 모든 대상 파일과 최종 실행 파일을 강제로 컴파일한다는 것을 알 수 있습니다. 🎜🎜🎜3. 디버깅 정보를 인쇄하려면 -d 옵션을 사용하세요. 🎜🎜🎜 make가 실행될 때 실제로 무엇을 하는지 알고 싶다면 -d 옵션을 사용하세요. 🎜🎜예는 다음과 같습니다. 🎜🎜rrreee🎜🎜이 출력은 매우 길며, 출력을 페이지별로 표시하기 위해 more
명령을 사용한 것도 보셨을 것입니다. 🎜🎜🎜4 -C 옵션을 사용하여 디렉토리를 변경하세요. 🎜🎜🎜 make 명령에 다른 디렉토리 경로를 제공할 수 있으며 Makefile을 찾기 전에 디렉토리가 전환됩니다. 🎜🎜현재 디렉토리에 있다고 가정하면 이것은 디렉토리입니다:🎜rrreee🎜그러나 실행하려는 make 명령의 Makefile 파일은 ../make-dir/ 디렉토리에 저장되어 있습니다. 다음을 수행할 수 있습니다:🎜🎜 rrreee🎜你能看到 make 命令首先切到特定的目录下,在那执行,然后再切换回来。
如果你想将重命名 Makefile 文件,比如取名为 my_makefile 或者其它的名字,我们想让 make 将它也当成 Makefile,可以使用 -f 选项。
make -f my_makefile
通过这种方法,make 命令会选择扫描 my_makefile 来代替 Makefile。
相关推荐:《Linux视频教程》
위 내용은 리눅스 시스템의 컴파일 명령은 무엇입니까의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!