`sh` 与 `bash` 的区别详解
sh 与 bash 的区别详解
1. 历史背景
-
sh(Bourne Shell):
由 Stephen Bourne 在 1977 年开发,是 Unix 系统的默认 Shell。语法简洁,但功能有限。 -
bash(Bourne Again Shell):
由 Brian Fox 在 1989 年开发,是sh的扩展版本,兼容sh语法并添加了大量新特性(如命令行编辑、历史记录等)。
2. 主要区别与示例
2.1 脚本声明差异
-
sh脚本
默认使用#!/bin/sh,遵循 POSIX 标准。#!/bin/sh echo "Hello, sh!" -
bash脚本
使用#!/bin/bash,支持非 POSIX 扩展语法。#!/bin/bash echo "Hello, bash!"
2.2 变量与数组
-
sh不支持数组
sh原生不支持数组,需用字符串模拟:#!/bin/sh list="one two three" for item in $list; doecho "$item" done -
bash支持数组
bash提供原生数组语法:#!/bin/bash arr=("one" "two" "three") echo "First element: ${arr[0]}" # 输出 "one"
2.3 字符串操作
-
sh功能有限
字符串截取需依赖外部命令(如cut):#!/bin/sh str="abcdef" substr=$(echo "$str" | cut -c1-3) # 输出 "abc" -
bash内置字符串操作
支持直接截取:#!/bin/bash str="abcdef" substr=${str:0:3} # 输出 "abc"
2.4 条件测试语法
-
sh使用test或[ ]
sh不支持[[ ]],需严格遵循空格规则:#!/bin/sh if [ "$a" -eq 1 ] && [ "$b" -eq 2 ]; thenecho "Conditions met." fi -
bash支持[[ ]]
更安全的语法,支持正则匹配:#!/bin/bash if [[ $a == 1 && $b =~ ^2 ]]; thenecho "Conditions met." fi
2.5 命令行扩展
-
bash特有扩展- 大括号扩展:
echo {1..5} # 输出 "1 2 3 4 5" - 进程替换:
diff <(ls dir1) <(ls dir2)
sh不支持上述语法。 - 大括号扩展:
2.6 错误处理
-
bash支持更多选项
如set -e(出错退出)和set -o pipefail(管道错误捕获):#!/bin/bash set -euo pipefail grep "pattern" file.txt | sortsh对部分选项支持有限。
3. 兼容性
bash兼容模式
通过#!/bin/sh调用bash时,若bash是系统默认 Shell,会尽量模拟sh行为:# 使用 `bash --posix` 强制启用 POSIX 模式
4. 总结与使用场景
| 场景 | 推荐 Shell |
|---|---|
| 需严格遵循 POSIX 标准 | sh |
| 需要高级功能或交互式操作 | bash |
| 跨平台脚本 | sh(避免依赖扩展) |
- 验证当前 Shell:
echo $SHELL # 显示默认 Shell echo $0 # 显示当前运行 Shell
相关文章:
`sh` 与 `bash` 的区别详解
sh 与 bash 的区别详解 1. 历史背景 sh (Bourne Shell): 由 Stephen Bourne 在 1977 年开发,是 Unix 系统的默认 Shell。语法简洁,但功能有限。 bash (Bourne Again Shell): 由 Brian Fox 在 1989 年开发,是 sh 的扩…...
*PyCharm 安装教程
PyCharm 安装教程,适用于 Windows、macOS 和 Linux 系统: 1. 下载 PyCharm 官网地址:https://www.jetbrains.com/pycharm/版本选择: Community(社区版):免费,适合基础 Python 开发…...
[特殊字符] Elasticsearch 双剑合璧:HTTP API 与 Java API 实战整合指南
🚀 Elasticsearch 双剑合璧:HTTP API 与 Java API 实战整合指南 一、HTTP API 定义与用途 Elasticsearch 的 HTTP API 是基于 RESTful 接口设计的核心交互方式,支持通过 URL 和 JSON 数据直接操作索引、文档、集群等资源。适用于快速调试、…...
网络和操作系统基础篇
网络和操作系统基础篇 TCP三次握手 客户端——发送带有SYN标志的数据包——服务端一次握手Client进入syn_sent状态;服务端——发送带有SYN/ACK标志的数据包——客户端二次握手服务端进入syn_rcvd;客户端——发送带有ACK标志的数据包——服务端三次握手…...
Oracle 连接报错:“ORA-12541:TNS:no listener ”,服务组件中找不到监听服务
一、 报错: navicat连接数据库报错:ORA-12541:TNS:no listener 二、排查问题 三、 解决问题 删除Oracle安装目录下选中的配置:listener.ora 及 listener*.bak相关的 cmd,用管理员打开 执行:netca 命…...
内外网文件传输 安全、可控、便捷的跨网数据传输方案
一、背景与痛点 在内外网隔离的企业网络环境中,员工与外部协作伙伴(如钉钉用户)的文件传输面临以下挑战: 安全性风险:内外网直连可能导致病毒传播、数据泄露。 操作繁琐:传统方式需频繁切换网络环境&…...
基于Flask的租房信息可视化系统的设计与实现
【Flask】基于Flask的租房信息可视化系统的设计与实现(完整系统源码开发笔记详细部署教程)✅ 目录 一、项目简介二、项目界面展示三、项目视频展示 一、项目简介 随着互联网的快速发展,租房市场日益繁荣,信息量急剧增加ÿ…...
《Keras 2 :使用 RetinaNet 进行对象检测》:此文为AI自动翻译
《Keras 2 :使用 RetinaNet 进行对象检测》 作者:Srihari Humbarwadi 创建日期:2020/05/17 最后修改日期:2023/07/10 描述:实施 RetinaNet:用于密集对象检测的焦点损失。 (i) 此示例使用 Keras 2 在 Colab 中查看 • 介绍 目标检测是计算机中非常重要的问题 视觉。在…...
【Erdas实验教程】010:监督分类及后处理、精度评价
文章目录 一、监督分类介绍二、监督分类流程1. 定义分类模板2. 评价分类模板3. 执行监督分类4. 评价分类结果4.1 叠加显示4.2 动态窗口链接4.3 阈值处理4.4 分类精度评价5. 分类后处理5.1 集聚处理5.2 滤网分析5.3 去除分析5.4 重编码一、监督分类介绍 遥感图像计算机分类的依…...
Moonshot AI 新突破:MoBA 为大语言模型长文本处理提效论文速读
前言 在自然语言处理领域,随着大语言模型(LLMs)不断拓展其阅读、理解和生成文本的能力,如何高效处理长文本成为一项关键挑战。近日,Moonshot AI Research 联合清华大学、浙江大学的研究人员提出了一种创新方法 —— 混…...
【Python量化金融实战】-第1章:Python量化金融概述:1.2 Python在量化金融中的优势与生态
本小节学习建议:Python在量化金融领域的统治地位不仅体现在当前的技术栈中,更在于其持续进化的能力。随着AI、区块链等新技术的融合,Python开发者将始终处于金融创新的最前沿。建议学习者从构建完整的策略生产线开始,逐步深入高频…...
react路由总结
目录 一、脚手架基础语法(16~17) 1.1、hello react 1.2、组件样式隔离(样式模块化) 1.3、react插件 二、React Router v5 2.1、react-router-dom相关API 2.1.1、内置组件 2.1.1.1、BrowserRouter 2.1.1.2、HashRouter 2.1.1.3、Route 2.1.1.4、Redirect 2.1.1.5、L…...
edge浏览器将书签栏顶部显示
追求效果,感觉有点丑,但总归方便多了 操作路径:设置-外观-显示收藏夹栏-始终...
AIGC-Stable Diffusion模型介绍
Stable Diffusion模型介绍 Stable Diffusion模型介绍模型架构Stable Diffusion模型特点 模型原理扩散过程 代码示例 Stable Diffusion模型介绍 Stable Diffusion是一种基于深度学习的图像生成模型,特别适用于生成高质量的图像。它利用扩散模型(diffusio…...
【算法】游艇租贷
问题 ⻓江游艇俱乐部在⻓江上设置了 n 个游艇租聘站,游客可以在这些租聘站租 ⽤游艇,然后在下游的任何⼀个租聘站归还。游艇出租站 i 到 j 的租⾦为 r(i, j),1 ≤i< j≤n,设计⼀个算法,计算从出租站 i 到 j 所需的…...
科普:Docker run的相关事项
一、镜像名(含标签)太长 如,通过如下命令行: docker pull designthru2019/dify:56c6d1af0944dbdb5e0115cb623ff0e118a4ac62拉取的镜像名(及标签)太长,可以通过改名的方法变短。 在 Docker 中&…...
Ryu:轻量开源,开启 SDN 新程
1. Ryu 控制器概述 定位:轻量级、开源的SDN控制器,专为开发者和研究人员设计,基于Python实现。开发者:由日本NTT实验室主导开发,遵循Apache 2.0开源协议。核心理念:简化SDN应用开发,提供友好的…...
Python游戏编程之赛车游戏6-2
3.2 move()方法的定义 Player类的move()方法用于玩家控制汽车左右移动,当玩家点击键盘上的左右按键时,汽车会相应地进行左右移动。 move()方法的代码如图7所示。 图7 move()方法的代码 其中,第20行代码通过pygame.key.get_pressed()函数获…...
IDEA + 通义灵码AI程序员:快速构建DDD后端工程模板
作者:陈荣健 IDEA 通义灵码AI程序员:快速构建DDD后端工程模板 在软件开发过程中,一个清晰、可维护、可扩展的架构至关重要。领域驱动设计 (DDD) 是一种软件开发方法,它强调将软件模型与业务领域紧密结合,从而构建更…...
libwebsockets交叉编译全流程
libwebsocket中的webscoket加密功能需要依赖于Openssl库因此需要提前准备好openssl开源库。 交叉编译openssl 下面演示源码方式交叉编译OpenSSL为动态库。 创建个Websocket文件夹,把后续的成果物均放在这个文件中,文件夹中创建子文件夹OpenSSL和libWeb…...
3个超实用技巧:Snap.Hutao让你告别原神数据管理烦恼
3个超实用技巧:Snap.Hutao让你告别原神数据管理烦恼 【免费下载链接】Snap.Hutao 实用的开源多功能原神工具箱 🧰 / Multifunctional Open-Source Genshin Impact Toolkit 🧰 项目地址: https://gitcode.com/GitHub_Trending/sn/Snap.Hutao…...
FanControl终极配置指南:Windows平台精准散热控制解决方案
FanControl终极配置指南:Windows平台精准散热控制解决方案 【免费下载链接】FanControl.Releases This is the release repository for Fan Control, a highly customizable fan controlling software for Windows. 项目地址: https://gitcode.com/GitHub_Trendin…...
3分钟解决Word学术引用难题:免费获取APA第7版完整模板
3分钟解决Word学术引用难题:免费获取APA第7版完整模板 【免费下载链接】APA-7th-Edition Microsoft Word XSD for generating APA 7th edition references 项目地址: https://gitcode.com/gh_mirrors/ap/APA-7th-Edition 还在为学术论文的引用格式而烦恼吗&a…...
从报表到大屏:手把手教你用 ECharts 坐标轴打造专业级数据可视化风格
从报表到大屏:手把手教你用 ECharts 坐标轴打造专业级数据可视化风格 数据可视化是现代商业决策和运营分析的核心工具。从简洁的商务报表到复杂的指挥中心大屏,如何通过坐标轴配置提升数据呈现的专业度,是每个前端工程师和数据分析师必须掌握…...
AGI自主进化已启动?2026奇点大会披露3项未公开实验数据:区块链如何为通用智能提供不可篡改的认知锚点
第一章:2026奇点智能技术大会:AGI与区块链 2026奇点智能技术大会(https://ml-summit.org) AGI系统与去中心化共识的协同演进 大会首次设立“AGI-Chain”联合实验室,聚焦通用人工智能体在无信任环境中自主协商、验证与执行复杂任务的能力。核…...
别再手动示教了!用RobotStudio的Offs函数搞定ABB机器人复杂码垛(附完整RAPID代码)
告别示教噩梦:用RobotStudio的Offs函数实现ABB机器人智能码垛 在工业自动化领域,码垛作业是最常见也最耗时的任务之一。传统的手动示教方式需要工程师逐个点位进行示教,不仅效率低下,而且容易出错。想象一下,面对一个3…...
二叉搜索树(BST)与哈夫曼树(HFM)
本篇,我们以搜索树和哈夫曼树为例,探究二叉树建立和遍历过程。 二叉树定义: 二叉树 是一种有限的、非线性的树形数据结构,每个节点最多只有两个子节点,分别称为:左孩子(左子树)、右孩…...
别再写跨线程异常了!WPF中Application.Current.Dispatcher的3种实战用法(附CheckAccess避坑)
WPF多线程UI更新实战:Dispatcher的深度应用与避坑指南 在WPF开发中,跨线程操作UI元素是个永恒的话题。每当看到"调用线程无法访问此对象"的异常提示,开发者们都会会心一笑——这几乎是每个WPF程序员成长路上的必经之痛。本文将带你…...
Multrin自定义开发指南:扩展你的窗口组织功能
Multrin自定义开发指南:扩展你的窗口组织功能 【免费下载链接】multrin Organize apps windows in tabs like in abandoned Windows Sets and more 项目地址: https://gitcode.com/gh_mirrors/mu/multrin Multrin是一款强大的窗口组织工具,它允许…...
考研408笔记之计算机组成原理(六)——总线
计算机组成原理(六)——总线 1. 总线的概述 在之前的学习过程中,虽然没有对总线进行详细的学习,但是对总线已经有了一定的接触,在之前会画这样的一个图,如上面,CPU可以通过地址总线给主存或给打…...
