make/makefileの使用

15802793:

メイク/メイクファイル


make はコマンド、makefile の命令を説明するコマンド ツール、makefile はファイル、現在のディレクトリ内のファイル、この 2 つは一緒に使用され、プロジェクトの自動構築を完了します。

make/makefile是Linux项目自动化构建工具,将多个源文件放在makefile中,通过make命令,通过makefile文件中的依赖关系,使得文件实现自动化编译,极大的提高了软件开发的效率。

Makefile のワークフローを理解する

下面通过一段代码进行编译演示makefile的工作流程

1. メイクファイルのコンテンツ形式要件を理解する

ここに画像の説明を挿入

2.makeコマンド

ここに画像の説明を挿入

上述内容,我们通过make命令,通过makefile文件中的依赖关系实现了test可执行程序。

依存関係と依存メソッド

依赖关系为我们要实现的可执行文件是需要依赖于一些文件,通过依赖方法来实现的。只需要找到合适的依赖关系和依赖方法,我们就可以自动化编译

ここに画像の説明を挿入

//1.依赖方法实际上就是实现依赖关系的语句,来得到可执行文件
test:test.c   //当前目录下进行查找发现拥有test.c文件
    gcc -c test test.c  //我们通过改gcc语句来得到test
//2.如果拥有多对依赖关系的时候,对于依赖关系的文件在该makefile所在目录下进行查找,如果没有,就查看makefile中是否有能得到该文件的依赖关系,然后一步一步的向下,直到查找到的依赖关系的文件是已存在的,可以从这一依赖关系,开始运行gcc语句,来得到对应文件来作为另一依赖关系的依赖文件
    
  1 test:test.o      			//test.o 文件不存在,所以向下找
  2     gcc -o test test.o
  3 test.o:test.s				//得到.o需要.s文件,所以还是没法运行对应的gcc语句(依赖方法)
  4     gcc -c test.s -o test.o
  5 test.s:test.i				//。。。
  6     gcc -S test.i -o test.s                                                       
  7 test.i:test.c				//最后找到了.c文件的依赖关系(.c是makefile所在目录下已有的文件所以是可以执行对应的gcc语句的)
  8     gcc -E test.c -o test.i
//所以从 第8行开始执行.c得到.i,现在有了.i 在由test.s:test.i关系通过gcc -S test.i -o test.s  语句来得到.s以此类推,最后得到test可执行文件

メイクの使用

我们创建好makefile文件之后,我们可以通过make命令来运行该文件,但是我们发现的是make只能运行一次,情况如下:

ここに画像の説明を挿入

//1.为什么会这样呢?难道不可以运行make创建新的test覆盖原来的test可执行文件
	对于make命令来讲,这是为了提高编译效率
//2.那么是如何判断是否需要更新该test文件的呢?
    我们先认识一个事情:先有源文件,再通过一定的依赖方法,得到可执行程序,所以一般来讲源文件的最近的修改时间比可执行文件要老(旧)
    所以当我们更改源文件之后,历史上曾经还有可执行文件,那么源文件的最近修改的时间,一定是 比可执行文件要新的。
    我们比较的是可执行程序的最近修改时间和源文件的最近修改时间
        如果.exe 新于 .c源文件 那么说明源文件是老的,即不需要重新编译
        如果.exe 旧于 .c源文件 那么说明.c源文件在实现.exe之后被更改了,所以需要重新编译
      	一般 .exe!=.c

对于上述内容总结,make会根据源文件和可执行程序的新旧,来判定是否需要重新执行依赖关系进行编译!!!

ファイルのステータスを確認するコマンド: stat ファイル名

ここに画像の説明を挿入

ファイルの内容はファイル属性です。ファイル = ファイルの内容 + ファイル属性

下面是对于三种时间的演示:

ここに画像の説明を挿入

//对于上述的内容我们知道了
//1.Access是多次访问之后才会进行改变,是为了系统性能考虑
//2.Modify是文件内容改变之后才会改变,相应的一般大小变化之后Change也会改变,所以一般Modify==Change
//3.Change是文件属性变化才会改变(权限,大小等),一般只有Change会发生变化(Access可能变)

所以对于make判断源文件和目标文件的新旧问题,我们采用的是Change的时间(因为稳定,文件发生变化,就一定会改变时间)

ファイルに関する新旧の問題を解決するデモを作成
ここに画像の説明を挿入

指定した依存関係を毎回指定する必要がある場合: .PHONY: pseudo-target を使用します。

.PHONY:test 表示不管如何(test.c不更改也可以)都会执行该依赖关系

[外部リンク画像の転送に失敗しました。ソース サイトには盗難防止リンク メカニズムがある可能性があります。画像を保存して直接アップロードすることをお勧めします (img-2A3ZsIRU-1689503950289) (C:\Users\Hongyan\AppData\Roaming\Typora\typora-user-images\image-20230716175439430.png)]

表示を実行します。

ここに画像の説明を挿入

メイククリーンの使用

make clean 使得make的操作更加简便,想要删除指定可执行程序的时候,不用去rm,直接make clean即可

操作演示:
ここに画像の説明を挿入

ここに画像の説明を挿入

要約する

  1. make のデフォルトの実装は、makefile の最初の部分 (モジュール) です。

  2. make + target は、make clean、make test など、makefile 内の指定されたターゲット (部分) を達成できます。

  3. make のデフォルトのファイルは makefile/Makefile です。他のファイルを使用して操作する場合は、make -f filename を使用します。

  4. 依存関係と依存メソッドの理解と、make が連続実行できないのは、対象ファイルが既に最新であるためで、指定したファイルの情報は stat filename で参照できます。ソースファイルの情報を変更してmakeで再コンパイル

  5. stat filename (ファイル名)、stat+filename の形式で、ファイルの基本情報以外の 3 種類の時間を表示できます

彼らです:

  • アクセス: ファイルが最後にアクセスされた時刻を示します。
  • 変更: ファイルの内容が最後に変更された時刻を示します。
  • 変更: ファイル属性が最近変更された時刻を示します。

Linux システムのパフォーマンスを向上させるため、Access は時刻を自動的に変更するためにファイルに複数回アクセスする必要があります。

一般に、Modify が変更されるとファイル サイズが変更されるため、Change が変更されるとファイル属性が変更され、通常は Change のみが変更されるため、ターゲット ファイルを再コンパイルするかどうか、ソース ファイルと実行可能プログラムの変更時刻を比較します。

Je suppose que tu aimes

Origine blog.csdn.net/qq_63319459/article/details/131753485
conseillé
Classement