『忘了再学』Shell基础 — 17、预定义变量
我们之前说过,Shell中的变量不是按照变量值的类型来进行分类的,而是按照Linux系统中定义的变量类别来分类的。
预定义变量就是,事先把变量的名称和作用确定好(都是不可变的),只能修改变量的内容,也就是变量的值。
其实预定义变量和位置参数变量都可以统称为预定义变量(有分开说明的,也有一起说明的,知道就行)。
预定义变量如下:
| 预定义变量 | 作用 |
|---|---|
$? |
$?中存的值,是最后一次执行的命令的返回状态。如果这个变量的值为0,证明上一个命令正确执行; 如果这个变量的值为非0(具体是哪个数,由命令自己来决定), 则证明上一个命令执行不正确了。(常用) |
$$ |
当前进程的进程号(PID)。 |
$! |
后台运行的最后一个进程的进程号(PID)。 |
1、预定义变量$?
$?这个预定义变量,在我们写Shell脚本的时候,还是比较常用。
我们下边来写一个例子进行说明。
# 执行ls命令
# ls命令正确执行
[root@Lyl tmp]# ls
count.sh for.sh parameter.sh param.sh
# 预定义变量"$?"的值是0,证明上一个命令执行正确,
# "$?"记录的是在执行"$?",或者值查询"$?"之前,
# 最后一条命令的执行返回状态。
[root@Lyl tmp]# echo $?
0
# 当前目录中没有install.log文件,所以ls命令报错了。
[root@Lyl tmp]# ls install.log
ls: 无法访问install.log: 没有那个文件或目录
# 变量"$?"返回一个非0的值,证明上一个命令没有正确执行,
# 至于错误的返回值到底是多少,是在编写ls命令时定义好的,
# 如果碰到文件不存在就返回数值2。
[root@Lyl tmp]# echo $?
2
# 输出错误命令的时候,命令状态返回值一般都是127。
[root@Lyl tmp]# adfasdf
-bash: adfasdf: command not found
[root@Lyl tmp]# echo $?
127
预定义变量$?的常用使用方式:
比如在写一个脚本的时候,要判断apache服务是否在运行。
有很多种实现方式,
比如搜索Linux系统中是否有apache服务的进程id号,如果能找到,$?的返回值为0,就确认了apache服务正在运行。
如果$?值不等于0,则证明apache服务没有启动。
有一个例子,我们前边在说Bash多命令顺序执行的时候,文章如下:
https://www.cnblogs.com/liuyuelinfighting/p/16082830.html
判断的条件就是$?=0。
2、预定义变量$$和$!
预定义变量$$和$!,在实际工作中用的不多,了解一下。(但是都要记住)
Linux系统下的进程是依赖进程的id号进行区分的,叫做pid,也就是进程id。
# 定义一个脚本variable.sh
[root@Lyl tmp]# variable.sh
# 脚本内容如下:
#!/bin/bash
# 输出当前进程的PID。
# 这个PID就是variable.sh这个脚本执行时,生成的进程的PID。
echo "The current process is $$"
# 使用find命令在root目录下查找hello.sh文件
# 符号&的意思是把命令放入后台执行。
find /root -name hello.sh &
# 输出这个后台执行命令的进程的PID,
# 也就是输出find命令的PID号
echo "The last one Daemon process is $!"
提示:将命令放入后台执行,请查看文章:https://www.cnblogs.com/liuyuelinfighting/p/15710694.html。
『忘了再学』Shell基础 — 17、预定义变量的更多相关文章
- 『忘了再学』Shell基础 — 12、用户自定义变量
目录 1.变量定义 2.变量调用 3.变量的修改 4.查看变量 (1)-u选项说明: (2)-x选项说明: (3)set命令说明: 5.变量删除 1.变量定义 变量正确定义. 格式:变量名=" ...
- 『忘了再学』Shell基础 — 16、位置参数变量
目录 1.位置参数变量$n 2.位置参数变量$*和$@ 3.位置参数变量$# 位置參数变量的作用主要用于脚本的传参. 位置參数变量的名称和作用都是确定不能改变的,但是该变量的内容是可以更改的,也就是变 ...
- 『忘了再学』Shell基础 — 13、环境变量(一)
目录 1.用户自定义的环境变量 (1)环境变量设置 (2)查询自定义环境变量 (3)删除自定义环境变量 2.系统自带的环境变量--PATH环境变量 (1)PATH环境变量 (2)PATH环境变量的作用 ...
- 『忘了再学』Shell基础 — 14、环境变量(二)
目录 1.PS1变量的作用 2.PS1变量的查看 2.PS1可以支持的选项 3.PS1环境变量的配置 4.总结 提示: 在Linux系统中,环境变量分为两种.一种是用户自定义的环境变量,另一种是系统自 ...
- 『忘了再学』Shell基础 — 15、环境变量(三)
目录 1.LANG语系变量介绍 2.如何查看Linux中支持的语系 3.查看当前系统的语系 4.总结 提示: 在Linux系统中,环境变量分为两种.一种是用户自定义的环境变量,另一种是系统自带的环境变 ...
- 『忘了再学』Shell基础 — 11、变量定义的规则和分类
目录 1.定义变量的规则 2.变量的分类 1.定义变量的规则 在定义变量时,有一些规则需要遵守 变量名称可以由字母.数字和下划线组成,但是不能以数字开头.如果变量名是2name则是错误的. 在Bash ...
- 『忘了再学』Shell基础 — 9、Bash中的特殊符号(一)
目录 1.双单引号 2.双引号 3.$符号 4.反引号 5.$()符号 6.#符号 7.\符号 1.双单引号 '':单引号.在单引号中所有的特殊符号,如$和"`"(反引号)都没有特 ...
- 『忘了再学』Shell基础 — 3、echo命令的介绍与使用
目录 1.echo命令的作用 2.echo命令的基本用法 3.echo命令的-e选项用法 4.echo命令一些特殊用法 (1)输出字符带有字体颜色 (2)输出字符带有背景颜色 在讲Shell脚本之前, ...
- 『忘了再学』Shell基础 — 10、Bash中的特殊符号(二)
提示:本篇文章接上一篇文章,主要说说()小括号和{}大括号的区别与使用. 8.()小括号 ():用于一串命令执行时,()中的命令会在子Shell中运行.(和下面大括号一起说明) 9.{}大括号 {}: ...
随机推荐
- 让子弹飞,零成本让你的网站更快一点,boxopened http/3 (QUIC) 协议实战
最近HTTP-over-QUIC 协议被正式命名为 HTTP/3,协议带来的最大改变是协议底层将采用UDP协议,而不再是TCP协议,这样的好处吗,就是更低时延,更好的拥塞控制,更精确的RTT时间,更高 ...
- js原生的Ajax
js原生的Ajax其实就是围绕浏览器内内置的Ajax引擎对象进行学习的,要使用js原 生的Ajax完成异步操作,有如下几个步骤: 1)创建Ajax引擎对象 2)为Ajax引擎对象绑定监听(监听服务器已 ...
- MyBatis 及 MyBatis Plus 纯注解方式配置(Spring Boot + Postgresql)
说明 当前的版本为 MyBatis 3.5.9 MyBatis Plus 3.5.1 Spring Boot 2.6.4 Postgresql 42.3.3 与 Spring Boot 结合使用 My ...
- Python入门-多进程
1.获取本机CPU # 早期的CPU是单核:实现多个程序并行,在某一时间点,其实只有一个进程 # 后来硬件多核CPU:多个进程是并行执行. from multiprocessing import cp ...
- 2021.07.23 P2474 天平(差分约束)
2021.07.23 P2474 天平(差分约束) [P2474 SCOI2008]天平 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 题意: 已知A,B和每两个点点权,求点权i, ...
- Xml外部实体注入漏洞
Xml外部实体注入漏洞(XXE) Xml介绍 XML 不是 HTML 的替代. XML 和 HTML 为不同的目的而设计: XML 被设计为传输和存储数据,其焦点是数据的内容. HTML 被设计用来显 ...
- Flex 的 多种对齐属性
1. html 结构 <div id="container"> <div class="item item-1"> <h3> ...
- Revit二次开发之添加选项卡和按钮
我们日常在revit开发中经常会用到按钮,可以通过revitAPI提供的接口创建按钮,今天我简单介绍一下两种按钮,一种是单命令按钮,另一种是含下拉菜单的按钮,包括创建他们的方法. 实现方法 1.实 ...
- 创建第一个c程序
创建,组织,生成 ,生成. 1.我们先创建一个win32项目. 文件->新建->项目->Visual C++ ->Win32 输入项目名称 选择项目保存位置 很重要的一 ...
- vue-cli4 vue-config.js配置及其备注
// vue.config.js const path = require('path'); const CompressionWebpackPlugin = require("compre ...