Makefile学习----初步理解

Posted lxk0825

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Makefile学习----初步理解相关的知识,希望对你有一定的参考价值。

一.我对makefile的理解:

经过一段时间对makefile的学习,我理解的makefile就是将程序员手动编译源文件的过程用一个脚本执行,这对于小型项目来说,程序员手动执行和用makefile来执行感官上可能没有大的差异,但是对于中大型项目来说,makefile的存在大大提供了程序员编译代码效率,一个好的makefile文件是一个项目健康存在的基础。

 

二.初涉makefile:

   用个简单的例子初步认识下makefile:

源文件:test.cpp:

#include<iostream>

using namespace std;

 

class A

{

        private:

        int a;

        public:

        A(int i)

        {

                a=i;

        }

 

        void disp()

        {

                cout<<a<<",";

        }

};

 

class B

{

        private:

        int b;

        public:

        B(int j)

        {

                b=j;

        }

 

        void disp()

        {

                cout<<b<<",";

        }

};

 

class C:public B,public A

{

        private:

        int c;

        public:

        C(int k):

        A(k-2),B(k+2)

        {  

                c=k;

        }

 

        void disp()

        {

                A::disp();

                B::disp();

                cout<<c<<endl;

        }

};

 

int main()

{

        C obj(10);

        obj.disp();

        return 0;

}

 

Makefile文件Makefile:

test:test.o

        g++  test.o  -o  test   

test.o:test.cpp

        g++  -c  test.cpp  -o  test.o

 

clean:

        rm  -fr  test  test.o

****************************************************************************

test:test.o                         ---- test是目标文件,也就是最后要生成的可执行文件;

                                               test.o编译源文件产生的中间代码文件;

                                               这行命令的意思是:目标文件test的产生依赖于中间代码文件test.o;

g++  test.o  -o  test           ---- 这行是编译器通过中间代码文件产生目标文件的命令,命令必须以tab键打头,否则执行的时候会报错;这边使用的是g++编

                                               译器,所以你的环境必须安装g++编译器;

test.o:test.cpp                    ----这行的目标文件是test.o,依赖文件是test.cpp;和第一行的格式相同;

g++ -c test.cpp –o test.o     ----这行是通过源文件test.cpp如何生成中间代码文件test.o,是编译命令;

 

clean:

        rm  -fr  test  test.o

 

clean是清除想要删除的文件,执行的时候需要使用命令make clean,一般是删除中间代码文件和最后生成的目标文件,即可执行文件;

 

      在环境中执行make命令,系统就会在目录下自动寻找Makefile、makefile文件,然后执行makefile文件中的内容;同样,你可以指定你自己的makefile文件名,比如:makefile_201020831,执行的时候必须用make –f makefile_201020831;

      Makefile的执行过程是一个递归的过程,目标文件:依赖文件,是使用命令通过依赖文件生成目标文件的过程;

      验证生成的目标文件,即可执行文件,直接./test即可。

以上是关于Makefile学习----初步理解的主要内容,如果未能解决你的问题,请参考以下文章

makefile入门-初步了解

makefile.in与makefile.am

嵌入式linux核心课程 2.uboot和系统移植-第2部分-2.2.补基础之shell和Makefile

跟我一起写 Makefile

Makefile工具使用

makefile从0到1