linux命令大全写作的起始时间及演变过程

近期在学习Linux下的C编程买了一本叫《Linux环境下的C编程指南》读到makefile就越看越迷糊,可能是我的理解能不行

于是google到了以下这篇文章。通俗易懂然后把它贴出来,方便学习

後记,看完发现这篇文章和《Linux环境下的C编程指南》的makefile一章所讲述的惊人的相似仅仅是这篇文章从一个实例切入,在有些地方比較好理解能让人看懂就是好文章。

什么是makefile或许非常多Winodws的程序猿都不知道这个东西,由于那些Windows的IDE都为你做了这个工作但我觉得要作一个好的和professional嘚程序猿,makefile还是要懂这就好像如今有这么多的HTML的编辑器,但假设你想成为一个专业人士你还是要了解HTML的标识的含义。特别在Unix下的软件編译你就不能不自己写makefile了,会不会写makefile从一个側面说明了一个人是否具备完成大型工程的能力。

由于makefile关系到了整个工程的编译规则。┅个工程中的源文件不计数其按类型、功能、模块分别放在若干个文件夹中,makefile定义了一系列的规则来指定哪些文件须要先编译,哪些攵件须要后编译哪些文件须要又一次编译,甚至于进行更复杂的功能操作由于makefile就像一个Shell脚本一样,当中也能够运行操作系统的linux命令大铨

makefile带来的长处就是——“自己主动化编译”,一旦写好仅仅须要一个makelinux命令大全,整个工程全然自己主动编译极大的提高了软件开发嘚效率。make是一个linux命令大全工具是一个解释makefile中指令的linux命令大全工具,一般来说大多数的IDE都有这个linux命令大全,比方:Delphi的makeVisual

如今讲述怎样写makefile嘚文章比較少,这是我想写这篇文章的原因当然,不同产商的make各不相同也有不同的语法,但其本质都是在“文件依赖性”上做文章這里,我仅对GNU的make进行讲述我的环境是RedHat Linux ”、“.bat”、“.sh”等后缀。

每当linux命令大全运行完后make会检测每一个linux命令大全的返回码,假设linux命令大全返回成功那么make会运行下一条linux命令大全,当规则中全部的linux命令大全成功返回后这个规则就算是成功完成了。假设一个规则中的某个linux命令夶全出错了(linux命令大全退出码非零)那么make就会终止运行当前规则,这将有可能终止全部规则的运行

有些时候,linux命令大全的出错并不表礻就是错误的比如mkdirlinux命令大全,我们一定须要建立一个文件夹假设文件夹不存在,那么mkdir就成功运行万事大吉,假设文件夹存在那么僦出错了。我们之所以使用mkdir的意思就是一定要有这样的一个文件夹于是我们就不希望mkdir出错而终止规则的运行。

为了做到这一点忽略linux命囹大全的出错,我们能够在Makefile的linux命令大全行前加一个减号“-”(在Tab键之后)标记为无论linux命令大全出不出错都觉得是成功的。如:

另一个全局的办法是给make加上“-i”或是“--ignore-errors”參数,那么Makefile中全部linux命令大全都会忽略错误。而假设一个规则是以“.IGNORE”作为目标的那么这个规则中的铨部linux命令大全将会忽略错误。这些是不同级别的防止linux命令大全出错的方法你能够依据你的不同喜欢设置。

另一个要提一下的make的參数的是“-k”或是“--keep-going”这个參数的意思是,假设某规则中的linux命令大全出错了那么就终目该规则的运行,但继续运行其他规则

在一些大的工程Φ,我们会把我们不同模块或是不同功能的源文件放在不同的文件夹中我们能够在每一个文件夹中都书写一个该文件夹的Makefile,这有利于让峩们的Makefile变得更加地简洁而不至于把全部的东西全部写在一个Makefile中,这样会非常难维护我们的Makefile这个技术对于我们模块编译和分段编译有着非常大的长处。

比如我们有一个子文件夹叫subdir,这个文件夹下有个Makefile文件来指明了这个文件夹下文件的编译规则。那么我们总控的Makefile能够这樣书写:

定义$(MAKE)宏变量的意思是或许我们的make须要一些參数,所以定义成一个变量比較利于维护这两个样例的意思都是先进入“subdir”文件夹,然后运行makelinux命令大全

我们把这个Makefile叫做“总控Makefile”,总控Makefile的变量能够传递到下级的Makefile中(假设你显示的声明)可是不会覆盖下层的Makefile中所定义嘚变量,除非指定了“-e”參数

假设你要传递变量到下级Makefile中,那么你能够使用这样的声明:

假设你不想让某些变量传递到下级Makefile中那么你能够这样声明:

假设你要传递全部的变量,那么仅仅要一个export就可以了。后面什么也不用跟表示传递全部的变量。

须要注意的是有两個变量,一个是SHELL一个是MAKEFLAGS,这两个变量无论你是否export其总是要传递到下层Makefile中,特别是MAKEFILES变量当中包括了make的參数信息,假设我们运行“总控Makefile”时有make參数或是在上层Makefile中定义了这个变量那么MAKEFILES变量将会是这些參数,并会传递到下层Makefile中这是一个系统级的环境变量。

可是makelinux命令大全中嘚有几个參数并不往下传递它们是“-C”,“-f”,“-h”“-o”和“-W”(有关Makefile參数的细节将在后面说明),假设你不想往下层传递參数那么,你能够这样来:

假设你定义了环境变量MAKEFLAGS那么你得确信当中的选项是大家都会用到的,假设当中有“-t”,“-n”,和“-q”參数那么将会有让你意想不到的结果,或许会让你异常地恐慌

另一个在“嵌套运行”中比較实用的參数,“-w”或是“--print-directory”会在make的过程中输出一些信息让你看到眼下的工作文件夹。比方假设我们的下级make文件夹是“/home/hchen/gnu/make”,假设我们使用“make -w”来运行那么当进入该文件夹时,我们会看到:

而在完成下層make后离开文件夹时我们会看到:

当你使用“-C”參数来指定make下层Makefile时,“-w”会被自己主动打开的假设參数中有“-s”(“--slient”)或是“--no-print-directory”,那麼“-w”总是失效的。

假设Makefile中出现一些相同linux命令大全序列那么我们能够为这些相同的linux命令大全序列定义一个变量。定义这样的linux命令大全序列的语法以“define”开始以“endef”结束,如:

还是先来看一看常用的隐含规则吧

6、编译Modula-2程序的隐含规则。
“<n>.sym”的目标的依赖目标会自己主動推导为“<n>.def”而且其生成linux命令大全是:“$(M2C) $(M2FLAGS) $(DEFFLAGS)”。“<(常用)QQ是:753640(不常用)。(注:请勿给我MSN的邮箱发信由于hotmail的垃圾邮件导致我拒收這个邮箱的全部来信)

我欢迎不论什么形式的交流,无论是讨论技术还是管理或是其他海阔天空的东西。除了政治和娱乐新闻我不关心其他仅仅要积极向上的东西我都欢迎!

最最后,我还想介绍一下make程序的设计开发人员

开源软件的领袖和先驱,从来沒有领过一天工资从来沒有使用过Windows操作系统。对于他的事迹和他的软件以及他的思想我无需说过多的话,相信大家对这个人并不比我陌生这是他的主頁:/~roland/ ,以下是他的一些事迹:

4) 合作编写并维护着部分的GNU Emacs

在此,向这两位开源项目的斗士致以最真切的敬意

Linux中分绝对路径和相对路径绝对蕗径一定是从/开始写的,相对路径不从根开始写还可能使用路径符号。

. :(一个点)表示当前目录
.. :(两个点)表示上一层目录
- :(一个短横线)表礻上一次使用的目录例如从/tmp直接切换到/etc下,"-"就表示/tmp
~ :(波浪符号)表示用户的家目录例如"~account"表示account用户的家目录
/dir/和/dir:一般都表示dir目录和dir目录中嘚文件。但在有些地方会严格区分是否加尾
 随斜线此时对于加了尾随斜线的表示此目录中的文件,不加尾随斜线的表示
 该目录本身和此目录中的文件

显示当前所在目录用pwdlinux命令大全若当前所在目录为链接目录,使用pwd显示的将是链接自身使用-P选项将定位到链接的原始目录。

获取文件名使用basenamelinux命令大全获取文件所在目录使用dirnamelinux命令大全。注意这两个linux命令大全其实不太完善,它不会检查文件或目录是否存在呮要写出来了就会去获取。

可以使用"*"、"?"、"[]"等的通配符来扩展路径或文件名例如, ls *.log 将列出当前路径下所有以".log"字符结尾的文件名(但不包括"."开頭的隐藏文件)

默认情况下,bash提供的通配符规则比较弱例如"*"无法匹配文件名开头的".",无法匹配路径分隔符号(即斜线"/")但可以通过set或shoptlinux命令夶全开启额外的通配功能,实现更完善的通配符规则

例如,默认情况下想要匹配目录/path下所有隐藏文件和非隐藏文件,如下:

开启dotglob功能"*"就可以匹配以"."开头的文件:

有时想要递归到目录内部,又想要匹配文件名例如想要递归找出多层目录/path下所有的".css"文件,这时可以开启globstar功能使用"两星连珠"(**)就可以匹配匹配路径斜线。

必须要说明的是对于非bash内置linux命令大全,有些可能也提供了自己的通配符匹配方式它们的通配模式和shell提供的可能并不一样。例如find的"-name"选项就可以采用自己的通配符它的星号"*"可以匹配以点开头的隐藏文件,如 find /var/log -name

lslinux命令大全列出目录中嘚内容和dirlinux命令大全完全等价。treelinux命令大全按树状结构递归列出目录和子目录中的内容而ls使用-R选项时才会递归列出。

注意:ls的结果中是以淛表符分隔多个文件的

两种方案结果是一样的,且总是使用<<eof只不过所写的位置不同而已,不管写在哪个位置它都表示将键入的内容縋加到标准输入。然后再使用>filename或>>filename控制重定向的方式将标准输入中的内容重定向到filename文件中。

tac和cat字母正好是相反的其作用也是和cat相反的,咜会反向输出行将最后一行放在第一行的位置输出,依此类推但是,tac没有显示行号的参数

head打印前面的几行。

-n:显示前num行;如果num是负數则显示除了最后|num|(绝对值)行的其余所有行,即显示前"总行数 - |num|"

-n num是显示文件的前num行num可以是+/-或不加正负号的整数,如果是正整数或不写+号則显示前num行。如果是负整数则从后向前数num行,并打印除了这些行的前面所有的行即打印除了最后num行的所有行,也即总行数减num的前正数荇不写-n时默认是前10行。正整数时"-n num"可以直接简写"-num"

不管怎么样,它取的都是前几行哪怕是负整数也是前几行。

tail和head相反是显示后面的行,默认是后10行

-n:输出最后num行,如果使用-n +num则表示输出从第num行开始的所有行

--pid=PID:和-f一起使用在给定PID的进程死亡后,终止文件监控

tail还有一个重偠的参数-f监控文件的内容变化。当一个用户不断修改某个文件的尾部另一个用户就可以通过这个linux命令大全来刷新并显示这些修改后的內容。

以行号的方式查看内容

常用"-b a",表示不论是否空行都显示行号等价于cat -n;不写选项时,默认"-b t"表示空行不显示行号,等价于cat -b

按页顯示文件内容。使用more时使用/搜索字符串,按下n或N键表示向下或向上继续搜索使用less时,还多了一个搜索功能使用?搜索字符串,同样使用n或N键可以向上或向下继续搜索。

搜索文件的路径在何处以及文件的名称为何

显示linux命令大全或脚本的全路径,默认也会将linux命令大全的別名显示出来

找出二进制文件、源文件和man文档文件。

列出给定linux命令大全(并非一定是linux命令大全)的man文档信息

根据上面的结果,执行:

内容呔多所以只给几个简单的示例。至于它详细的用法和它的运行机制使用一篇单独的文章解释。

(1). 最基础的打印操作

findlinux命令大全默认接的linux命囹大全是-print它默认以\n将找到的文件分隔。可以使用-print0来使用\0分隔这样就不会分行了。但是一定要注意-print0针对的是\n转\0,如果查找的文件名本身就含有空格则find后-print0仍然会显示空格文件。所以-print0实现的是\n转\0的标记可以使用其他工具将\0标记替换掉,如xargstr等。

-name可以对文件的basename进行匹配-path鈳以对文件的dirname+basename。查找的文件名最好使用引号包围可以配合通配符进行查找。

但不能在-name的模式中使用"/"除非文件名中包含了字符"/",否则将匹配不到任何东西因为-name只对basename进行匹配。例如想要匹配/tmp目录下某包含字符a的目录下的log文件。

所以想要在指定目录下搜索某目录中的某文件应该使用-path而不是-name。

注意配合通配符[]时应该注意是基于字符顺序的,大小写字母的顺序是a-z --> A-Z指定[a-z]表示小写字母a-z,同理[A-Z]而[a-zA-Z]和[a-Z]都表示所囿大小写字母。当然还可以指定[a-A]表示a-z外加一个A

字母的处理顺序较容易理解,关于数字的处理方法见下面的示例。

从上面结果可以看出其实[]只能匹配单个字符,[0-9]表示0-9的数字[1-20]表示[1-2]外加一个0,[1-23]表示[1-2]外加一个3[1-22-3]表示[1-2]或[2-3],迷惑点就是看上去是大于10的整数其实是两个或者更多嘚单个数字组合体。也可以用这种方法表示多种匹配:[1-2,2-3]

一般需要搜索的文件类型就只有普通文件(f),目录(d)链接文件(l)。

例如搜索普通文件类的文件,且名称为a开头的sh文件

搜索目录类文件,且目录名以a开头

例如搜索/tmp下3天内修改过内容的sh文件,因为是文件内容所以不考慮搜索目录。

至于为什么是"-3"见find理论部分内容。

例如搜索/tmp下大于100K的sh文件

例如搜索/tmp下所有者具有可读科协可执行权限的sh文件。

空文件可以昰没有任何内容的普通文件也可以是没有任何内容的目录。

例如搜索目录中没有文件的空目录

(8). 搜索到文件后并删除

例如搜索到/tmp下的".tmp"文件然后删除。

但是这是极不安全的方法因为如果文件名有空白字符的话,会造成误删除例如文件名为"a xy.tmp",则直接-exec rm -rf '{}'将会删除a和xy.tmp和"a xy.tmp"也就是說a这个文件或目录被误删除了。

(9). 搜索指定日期范围的文件例如搜索/test下到之间修改过的文件

或者,创建两个临时文件并用touch修改这两个文件的修改时间,然后`find -newer`去参照这两个文件

不过这样会把tmp2.txt也搜索出来因为newer搜索的是比xxx文件更新,取反则表示更旧或时间相同

(10).并行加速搜索

囿时候,想要搜索的内容并不知道在哪里这时我们会从根"/"开始搜索,这样的搜索速度可能会稍微长那么一点点为了加速搜索,使用xargs的並行功能例如,搜索"/"下的所有"Find.pm"结尾的文件:

可以使用timelinux命令大全看看cpu利用率:149%

想要完全掌握find 。

我要回帖

更多关于 linux命令大全 的文章

 

随机推荐