linux源码安装软件系列1

linux源码安装软件系列1_第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

你可能感兴趣的:(linux源码安装软件系列1)