Linux 打开shell的过程;bash基本使用
登录到shell的过程
- linux系统在调用init初始化进程之前,主要是完成系统级别的一系列动作,此时,用户根本无法使用系统,因为系统根本没有让用户控制系统的途径!
- init之所以存在,其意义应该是增加linux的灵活性 和 标准性:变异的linux完全可以调用其他的init程序;有了统一的init入口后,可以机动的定义之后的调用动作。
- 一般的linux总是调用init作为pid=1的进程,它是所有进程的起点!
- init调用login进程,进行登陆验证
- login调用shell。shell有很多中,找个适合你自己的就行了
- shell才是用户和linux的交互接口。这个接口就是为了让用户高效、方便、灵活、强大的控制和使用liunx而存在的!如果是特殊的应用。login完全可以不调用shell!
- shell会调用一系列初始化文件:
- /etc/profile --系统
- /etc/bashrc --系统
- ~/.bash_profile --user
- ~/.bashrc --user
- ~/.bash_login --user
- ~/.profle --user
- ~/.bash_logout --user logout
bash的基本用法
- bash显示变量:echo $环境变量
- bash设置变量:set 环境变量=值
- bash倒出到系统变量:export 环境变量=值
- bash以当前shell环境执行一个脚本,通常用于设置当前shell的环境变量:source【.】 脚本
- bash解释输入的顺序:命令空白..参数..回车。命令的优先级:
- 别名
- bash的编程关键字
- 函数
- 内置命令
- 外部命令
- bash的内置命令:help 获得内置命令的帮助
- bash的内置命令:type 获得查询命令的类型
- bash的内置命令:buildin、enable、command管理内、外命令是否生效
- bash命令执行状态的返回变量:$? 通常:0.成功;127.命令未找到;>=128.程序错误终止
- bash无条件执行多个命令:各命令以分号“;”分隔。执行的状态为最后一个命令的返回状态。如果想让多个命令的输出重定向到文件,需要把这些命令放到(命令1;命令2; )> out.txt 内,最后的命令必须加空格
- bash依赖条件执行多个命令:各命令以“&&”分隔,前边的执行成功才执行后边的
- bash依赖条件执行多个命令:各命令以“||”分隔,前边的执行失败才执行后边的
- bash后台执行命令:在命令后加上“&”。注意,如果该命令有屏幕输出就不好了,需要重定向到其他才不会影响前台的输入等
- bash终止当前运行的程序的执行:ctrol+c 或 ctrol + \
- bash将当前运行的程序放到后台以作业的形式运行:ctrol+z,注意这样实际上在后台上挂起的状态。$!变量获得最后放入后台的作业的进程pid
- bash作业管理:
-
-
- ctrol+z --后台挂起; 命令& --后台运行
- jobs --列车所有后台作业。 -r 正在运行的 ;-s 挂起的;%n 作业号;%name 作业名 ;%?name 含有name的作业; %+ 当前作业;%% 当前作业;%-上一个作业
- bg --执行后台作业
- fg --将后台作业放到前台执行
- stop --挂起后台作业
- stty tostop --如果后台作业有终端输出,则挂起
- kill --终止后台作业
- wait --等待后台作业及其返回值
-
- bash使用tab键自动完成命令 或 文件名
- bash命令历史功能:默认放在~/bash_history下。history内置命令显示历史记录。fc命令可以查看、执行历史命令;“!!”可以执行最后历史命令;“!n” 执行指定行号的历史命令;“!name”执行以name开头的最后执行的历史命令
-
bash编程
一:变量
- declare 或 直接赋值 的局部变量:declare var1=20 或 var2='as df\df'
- export的全局变量:var1=sdaf export var1 或 export var2=vdsf3
- 位置变量:$1 ---- $n
- 特殊预定于变量:$0--当前进程的文件名 $$--当前进程的spid $#--位置参数的个数 $!--后台最后执行的作业的作业号 $?--上一程序的执行状态 $@--全部位置参数--原样的参数列表 $*--全部位置参数--内部用单引号括起来的一个字符串
- 其他预定于的环境变量:$UID $PWD $PATH...........
- 变量扩展:虽然 $vars可能会——变量和周围文本通过空白分隔了——正确的工作,但${vars}总能正确的工作
- unset:删除环境变量,不能删除只读的环境变量
- readonly var=值:定义只读的环境变量。注意:只读的意思是可以修改值,但不能unset环境变量
- 命令替换:反单引号方式`ls ` 或 $(ls ) 方式
二:注释及魔数
# --行注释
#!/bin/bash --魔数
三:高级变量扩展:参数变量的替换
- ${v1-v2} --如果v1没义或为空有定,v2替换v1,v1不会被更改 --定义默认值
- ${v1+v2} --如果v1没义或为空有定,不做任何处理,否则v2替换v1,v1不会被更改 --强制使用默认值
- ${v1=v2} --如果v1没义或为空有定,v2替换v1,v1被更改为v2。--注意因为更改v1,这种用法被能用于位置参数
- ${v1?v2} --如果v1没义或为空有定,非交互模式下:类似于${v1-v2},但bash有标准错误输出;交互模式下:bash提示错误v1需要定义,提示内容为v2,并退出shell执行!
- ${var##*str} --开头长变量截去
- ${var#*str} --开头短变量截去
- ${var%%str*} --末尾长变量截去
- ${var%str*} --末尾短变量截去
- ${var/pattern} --开头模式匹配删除。可以通过在pattern上加上“#、%”来明确指示是开头还是结尾删除
- ${var//pattern} --模式匹配删除
- ${var/pattern/replace} --模式匹配替换
- ${var//pattern/replace} --模式匹配替换
- ${var:startpos:length} --截取指定位置和长度的字符串,开始位置、长度均可省略,默认为0或1、到末尾
四:条件测试表达式
数值测试,复合模式下,可以使用c的语法和运算符
- -eq 等于 --注意和字符串比较的 “=”类似
- -ne 不等于 --注意和字符串比较的 “!=”类似
- -gt 大于
- -lt 小于
- -ge 大于等于
- -le 小于等于
- ...
- ...
字符串比较:注意双引号引用的使用
- = 等于
- ==通配符比较
- != 不等于
- >
- <
- -z字符串 字符串长度等于0
- -n字符串 字符串长度大于0
文件测试
- -e文件名 文件存在
- -r文件名 文件存在且可读
- -w文件名 文件存在且可写
- -x文件名 文件存在且可执行
- -s文件名 文件存在且至少有一个字符
- -S文件名 文件存在且是套接字
- -d目录名 文件存在且目录存在
- -f文件名 文件存在且普通文件
- -c文件名 文件存在且字符文件
- -b文件名 文件存在且块文件
- -p文件名 文件存在且是管道文件
- -L|-h文件名 文件存在且是符号链接文件
- -N文件名 文件自最后读取后发生修改
- file1 -nt file2 file1 比 file2 文件新
- file1 -ot file2 file1 比 file2 文件旧
- file1 -ef file2 file1 是否是 file2 的硬连接
符合运算符
- test express 内置命令测试 等同于 [express] --不能屏蔽特殊字符如>、 <、 \、 (、) 等等
- [express] 内置命令测试 等同于 test express --不能屏蔽特殊字符如>、 <、 \、 (、) 等等
- [[express]] 字符串复合运算符表达式,指出通配符比较。
- ((express)) 算数复合运算符表达式 可以使用类似于c的语法
- let express 算数运算赋值测试内置命令
五:数值计算表达式
$((express)) 或 $[express]
六:基本流程控制语句。这些语句的关键字必须放在不同的行
if 条件测试
then
命令
elif [condition]
then
命令
else
命令
fi
for 变量 [in 列表] --注意这里的“变量”是循环控制变量
do
若干命令
done
例子1:
for myfile in /etc/r* /var/lo* ${ORACLE_HOME}/*
do
if [-d "$myfile"]
then
echo "$myfile is (dir)"
else
echo "$myfile is (file)"
fi
done
例子2:
#! /bin/bash
for param in "$@"
do
echo "$param"
done
while|until --区别在于while当“若干命令1”最后执行的状态为真时执行循环,until反之
若干命令1
do
若干命令2
done
case string in
exp1)
若干命令1
;;
exp2)
若干命令2
;;
.........
*)
其他命令
esac
breake 和 continue
七:函数。函数实际上是一组程序,是shell脚本程序的一部分
注意:bash的函数中定义的变量即是shell全局变量,所以必须注意变量的使用。可以通过在函数内定义的变量声明为local来避免对函数外部全局变量的影响!
functionname
{
local var=值
若干命令
}
函数的调用:functionname param1 param2 ...
shell将会自动将这些参数传给位置变量$1 $2 .... $# $*
八:命令分组
(命令) --shell打开新的子shell进程调用命令
{命令} --shell以管道的方式从自身的shell进程中运行命令
九:bash的执行和调试
执行:bash 脚本文件 或 将脚本文件设置为可执行
调试:bash 选项 脚本文件。常用的调试选项
- -n --读入命令但不执行
- -u --如果变量未设置,则认为程序错误
- -v --读入shell的输入行时显示出来
- -x --执行shell命令时,显示命令及其参数
- 在shell程序内使用echo等内部命令输出变量及中间结果
十:bash中特殊的函数、语句、其他
dirname 和 basename 是字符串函数
标识不同进制的数值:base#数字符号 --如 八进制057、 16进制0x23a、2进制2#0101、30进制30#12b
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)