linux从源码编译软件,linux源码安装软件系列1

linux软件安装

在windows安装软件是极其简单的事,无非就是下载,然后一路点击“下一步”即可。而在linux装软件就没那么简单了,尤其是对于新手而言,往往会手足无措,觉得linux很不好用。可一旦习惯了,就会惊叹于linux的强大,安装软件可以简单地用一句命令行解决从下载到安装的整个流程,比windows下的一键安装还要轻爽。也可以自己到官网下载源码,自己编译,甚至修改源码,真正自定义安装软件。

本系列文章主要讲解通过源码安装软件的原理以及方法。

我们知道,不管是windows,还是linux,最终能执行的都是二进制文件,而我们的代码是用编程语言写的文本文件,要转换成操作系统能识别的二进制码就需要编译器。

以下用实例演示编译源码的操作流程

编译单一文件

新建c语言文件:hello.c

#include

int main(void)

{

printf("Hello World\n");

}

[senlong@linux ~]$ gcc hello.c

[senlong@linux ~]$ ll hello.c a.out

-rwxrwxr-x 1 senlong senlong 8512 7月 27 08:44 a.out

-rw-rw-r-- 1 senlong senlong 67 7月 27 08:44 hello.c

[senlong@linux ~]$ ./a.out

Hello World

以上实例演示了hello.c源码文件经由gcc命令编译生成a.out可执行文件

相关术语解释:

源码文件:即程序员写的源代码文件(hello.c)

编译器:将便于人编写,阅读,维护的高级计算机语言所写作的源码程序,翻译为计算机能解读、运行的低阶机器语言的程序(gcc)

可执行文件:操作系统能直接识别,可直接执行的二进制文件(a.out)

可执行文件与普通文本文件可通过file指令识别:

[senlong@linux ~]$ file hello.c

hello.c: C source, ASCII text # 普通文本文件

[senlong@linux ~]$ file a.out

a.out: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.32, BuildID[sha1]=29c4c64ff2985490bb17a37ef188574a0009b3da, not stripped # 可执行的二进制文件

编译多个文件

默认情况下,使用gcc编译输出的二进制文件是a.out, 我们可以将gcc的编译行为拆分成两个步骤:

gcc -c filename.c 生成目标文件(object file)

gcc -o filename.o 生成可执行文件

[senlong@linux ~]$ gcc -c hello.c

[senlong@linux ~]$ ll hello*

-rw-rw-r-- 1 senlong senlong 67 7月 27 08:44 hello.c

-rw-rw-r-- 1 senlong senlong 1496 7月 27 08:53 hello.o # object file

[senlong@linux ~]$ gcc -o hello hello.o

[senlong@linux ~]$ ll hello*

-rwxrwxr-x 1 senlong senlong 8512 7月 27 08:54 hello # 二进制文件

-rw-rw-r-- 1 senlong senlong 67 7月 27 08:44 hello.c

-rw-rw-r-- 1 senlong senlong 1496 7月 27 08:53 hello.o

[senlong@linux ~]$ ./hello

Hello World

那么问题来了,既然可以一步到位用一个命令生成可执行文件,为什么还要拆分成两步呢?

继续以下实例:

thanks.c

#include

int main(void)

{

printf("Hello World\n");

thanks_2();

}

thanks_2.c

#include

void thanks_2(void)

{

printf("Thank you!\n");

}

[senlong@linux ~]$ gcc -c thanks.c thanks_2.c

[senlong@linux ~]$ ll thanks*

-rw-rw-r-- 1 senlong senlong 71 7月 27 08:57 thanks_2.c

-rw-rw-r-- 1 senlong senlong 1504 7月 27 09:04 thanks_2.o

-rw-rw-r-- 1 senlong senlong 83 7月 27 08:56 thanks.c

-rw-rw-r-- 1 senlong senlong 1560 7月 27 09:04 thanks.o

[senlong@linux ~]$ gcc -o thanks thanks.o thanks_2.o

[senlong@linux ~]$ ll thanks*

-rwxrwxr-x 1 senlong senlong 8584 7月 27 09:05 thanks

-rw-rw-r-- 1 senlong senlong 71 7月 27 08:57 thanks_2.c

-rw-rw-r-- 1 senlong senlong 1504 7月 27 09:04 thanks_2.o

-rw-rw-r-- 1 senlong senlong 83 7月 27 08:56 thanks.c

-rw-rw-r-- 1 senlong senlong 1560 7月 27 09:04 thanks.o

[senlong@linux ~]$ ./thanks

Hello World

Thank you!

此时我们再来更改thanks_2.c文件:

#include

void thanks_2(void)

{

printf("Thank you very much!\n");

}

现在我们只需要单独编译thanks_2.c文件,再将两个目标文件联结重新生成可执行文件。不需要再去编译thanks.c

[senlong@linux ~]$ gcc -c thanks_2.c

[senlong@linux ~]$ gcc -o thanks thanks.o thanks_2.o

[senlong@linux ~]$ ./thanks

Hello World

Thank you very much!

之所以要生成目标文件,是因为源码文件很多时候不是单一文件,如果其中有一个文件变化了,只需要重新编译此文件,而不用全部文件再次编译

引用外部函数库

函数库指封装好的实现一定功能的程序。可以在别的程序直接引用,如以下实例:计算sina值,调用了sin()函数

sina.c

#include

#include

int main(void)

{

float value;

value = sin ( 3.14 / 2 );

printf("%f\n",value);

}

[senlong@linux ~]$ gcc sina.c

[senlong@linux ~]$ ./a.out

1.000000

以上介绍了编译源码的基本流程,可以很明显地看出,当我们的文件量大时,如有几百个、几千个文件时,如果还是按照以上这种手工编译的方式,那linux就不好玩了。下篇文章将介绍快速编译的方式。

敬请关注我的账号。

你可能感兴趣的:(linux从源码编译软件)