Linux에서 makefile은 전체 프로젝트의 컴파일 및 연결 규칙을 설명하는 프로젝트 파일의 컴파일 규칙입니다. 여기에는 컴파일해야 하는 파일, 컴파일할 필요가 없는 파일, 컴파일해야 하는 파일이 포함됩니다. 먼저 컴파일해야 하는 파일과 나중에 컴파일해야 하는 파일 컴파일, 다시 빌드해야 하는 파일 등
이 튜토리얼의 운영 환경: linux5.9.8 시스템, Dell G3 컴퓨터.
Makefile은 간단히 말해서 프로젝트 파일의 컴파일 규칙으로 생각하면 전체 프로젝트의 컴파일 및 연결 규칙을 설명합니다.
엔터프라이즈 수준 프로젝트에는 일반적으로 많은 소스 파일이 있으며 때로는 기능, 유형 및 모듈에 따라 서로 다른 디렉터리로 구분되기도 합니다. 때로는 여러 프로그램의 소스 코드가 하나의 디렉터리에 저장됩니다.
Makefle은 위 코드 중 일부를 어떻게 컴파일해야 하는지에 대한 문제를 해결하기 위해 탄생했습니다. 이는 어떤 파일을 먼저 컴파일해야 하는지, 어떤 파일을 나중에 컴파일해야 하는지, 어떤 파일을 다시 컴파일해야 하는지를 결정하는 일련의 규칙을 정의합니다.
전체 프로젝트 컴파일과 관련된 모든 내용은 Makefile에 설명될 수 있습니다. 즉, Makefile은 매번 여러 소스 파일과 매개변수를 수동으로 입력할 필요 없이 프로젝트 프로젝트 컴파일을 자동화할 수 있습니다.
Makefile의 장점은 "자율 컴파일"을 달성할 수 있다는 것입니다. 전체 프로젝트에는 일반적으로 컴파일, 링크 및 훨씬 더 복잡한 기능을 완료하는 데 하나의 make 명령만 필요합니다. 모든 Linux 소스 프로그램에는 Makefile이 함께 제공된다고 할 수 있습니다.
코드 컴파일을 관리하고, 컴파일할 파일, 컴파일 순서, 재컴파일 필요 여부를 결정하세요.
컴파일 시간을 절약하세요. 파일이 변경되면 전체 프로젝트를 다시 컴파일하지 말고 이 파일을 다시 컴파일하세요. Makefile은 일반적으로 한 번만 작성하면 되며 나중에 너무 많이 변경할 필요가 없습니다.
3. 명명 규칙
으로 지정해도 괜찮지만, 소스 파일의 이름이 소문자인 경우가 많아 그 이름을 사용하는 프로그래머가 많습니다. Makefile, 왜냐하면 Makefile이 먼저 표시되기 때문입니다. Makefile_demo 등 다른 이름으로 Makefile을 명명하는 경우도 허용되지만, 사용할 때는 다음 방법을 사용해야 합니다. make -f Makefile_demo
4 기본 규칙
Makefile의 기본 규칙
대상 : 종속성(탭) 규칙
대상--> 생성해야 하는 대상 파일종속성--> 대상을 생성하는 데 필요한 일부 파일-- > 종속 파일에서 대상 생성 파일은
tab -->
각 규칙은 탭으로 시작해야 합니다
, 공백은 허용되지 않습니다예를 들어, Makefile을 사용하여 gcc test.c -o test를 자주 작성합니다. test: test.c
gcc test.c -o test
합니다.
5. 작동 원리
대상 생성:
b. 종속 파일.
예를 들어 위 그림에서 계산기 생성 규칙은 gcc main.o add.o sub.o mul.o p.o -o입니다. Makefil은 먼저 main.o, add.o, sub를 확인합니다. o, mul. o, p.o가 존재합니까? 그렇지 않은 경우 종속성 파일을 생성하는 규칙을 찾습니다. 예를 들어 종속성 main.o가 누락된 경우 Makefile은 아래에서 main.o를 생성하는 규칙이 있는지 확인합니다. gcc main.c -o main.o 규칙이 main.o를 생성할 수 있음을 발견하면 이 규칙을 사용하여 main.o를 생성한 다음 최종 목표 계산기를 생성합니다.전체 프로세스는 아래쪽에서 종속성을 찾은 다음 위쪽으로 명령을 실행하여 최종 목표를 생성하는 것입니다.
대상 업데이트:a. 대상의 모든 종속성을 확인합니다. 종속성이 업데이트되면 대상 파일을 다시 생성합니다.
b. 업데이트되었습니다.
예를 들어 main.c가 수정되면 main.o 대상이 다시 컴파일됩니다. main.o가 업데이트되면 최종 대상 계산기도 다시 컴파일됩니다. 다른 파일의 업데이트도 유사하게 수행됩니다. 6. 명령 실행make:Makefile 파일 이름이 Makefile이나 makefile이 아닌 경우 다음과 같이 -f 옵션을 추가해야 합니다.
make -f Makefile_demo
make clean:
컴파일 과정에서 생성된 중간 파일(.o 파일)과 최종 대상 파일을 지웁니다.
현재 디렉터리에 clean이라는 파일이 있으면 이 명령이 실행되지 않습니다.
-->해결 방법: 의사 대상 명령문: .PHONY:clean
특수 기호:
-: 이 명령을 실행하는 동안 오류가 발생하더라도 후속 명령이 계속 실행됨을 나타냅니다. . 예:
-rm a.o build/
@: 명령이 에코 없이만 실행됨을 나타냅니다. 일반 규칙이 실행되면 실행 규칙이 터미널에 인쇄됩니다. 이 기호를 추가하면 명령만 실행되고 실행된 규칙은 에코되지 않습니다. 예:
@echo $(SOURCE)
변수 정의 및 할당:
변수는 다음과 같이 값을 할당하여 직접 정의할 수 있습니다.
INCLUDE = ./include/
변수 값:
괄호로 묶고 달러 기호를 추가합니다. 예:
FOO = $(OBJ)
시스템 내장 변수:
일반적으로 모두 대문자입니다. 예: CC, PWD, CFLAG 등
기본값이 있는 경우도 있고 그렇지 않은 경우도 있습니다. 예를 들어 일반적인 것들은 다음과 같습니다.
CPPFLAGS: 다음과 같은 전처리기에 필요한 옵션: -I
CFLAGS: 컴파일 중에 사용되는 매개변수 –Wall –g -c
LDFLAGS: 링크 라이브러리에서 사용되는 옵션 –L -l
변수의 기본값은 수정될 수 있습니다. 예를 들어 CC의 기본값은 cc이지만 gcc로 수정될 수 있습니다: CC=gcc
일반적으로 사용되는 자동 변수:
Makefile은 다양한 자동변수를 제공하는데, 일반적으로 다음 3가지를 사용합니다. 이러한 자동 변수는 규칙의 명령에만 사용할 수 있으며 다른 곳에서는 사용할 수 없습니다.
$@ --> 규칙의 대상
$ 규칙의 첫 번째 종속성 조건
$^ --> 규칙의 모든 종속성 조건
app : main.c func1.c fun2.c
gcc $^ - o $@
그 중 $^은 main.c func1.c fun2.c를 나타내고, $
패턴 규칙:패턴 규칙은 대상 및 종속성 조건에서 %를 사용하여 해당 파일을 일치시키는 것입니다. 예를 들어 디렉터리에 main.c, func1.c 및 func2.c 세 개의 파일이 있습니다. 이 세 가지의 경우 파일 컴파일은 다음 규칙에 따라 완료될 수 있습니다.
%.o:%.c
$(CC) –c $
이 패턴 규칙은 다음을 의미합니다.
main. o by main.c 생성,
func1.o는 func1.c에 의해 생성,
func2.o는 func2.c에 의해 생성
이는 디렉터리에 있는 모든 파일을 한번에 일치시킬 수 있는 패턴 규칙의 역할입니다. 시간.
9. 기능
이 있어야 한다는 점에 유의해야 합니다. 다음 예에서는 디렉터리에 main.c, func1.c, func2.c 세 개의 파일이 있다고 가정합니다.
wildcard:는 지정된 디렉터리에서 지정된 형식의 파일을 찾는 데 사용됩니다. 다음 매개 변수는 디렉터리 + 파일 형식입니다. 예:
src = $(wildcard ./src/*.c)
의미: ./src 디렉토리에서 .c 접미사가 있는 모든 파일을 찾아 변수 src에 할당합니다.
명령 실행이 완료된 후 src의 값은 main.c func1.c fun2.c입니다.
patsubst:다음 예와 같은 일치 대체는 src 디렉터리에서 .c로 끝나는 모든 파일을 찾아 .o 파일로 바꾸고 obj에 할당하는 데 사용됩니다.
obj = $(patsubst %.c ,%.o ,$(src))
src 변수에서 .c 접미사가 있는 모든 파일을 .o로 바꿉니다.
명령이 실행된 후 obj의 값은 main.o func1.o func2.o
특별히 모든 .o 파일을 obj 디렉터리에 저장하려면 다음 방법을 사용할 수 있습니다.
ob = $(patsubst . /src/%.c, ./obj/%.o, $(src))
관련 추천: "
Linux 비디오 튜토리얼위 내용은 리눅스에서 makefile이란 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!