功能更齐全!Unix shell Bash 5.0释出

2023-11-01 14:38

本文主要是介绍功能更齐全!Unix shell Bash 5.0释出,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

常用的Unix shell Bash释出第5个主要版本,这个版本主要修复了Bash 4.4中几个明显的错误,同时也加入了一些新功能。Bash是一个完整的POSIX壳层规范实作,除了有交互式命令行编辑功能,还在基础架构上支持工作控制,并提供类似csh的功能等。Bash 5.0主要解决Bash 4.4的错误,是改变对nameref变量解析的方法,和一系列以模糊测试发现的潜在超出范围值内存错误。另外,Bash 5.0在不执行单词拆解以符合Posix标准解释的情况下,在不同的上下文中,$@和$*的扩充也有许多改变,而且还解决不少极端案例以增加Posix的一致性。

而本次最重要的功能更新,则是增加了新的壳层变量,BASH_ARGV0、EPOCHSECONDS和EPOCHREALTIME。而内建的History功能现在可以用来删除历史条目的范围,并且将负的参数当作历史列表末端的偏移量。Bash 5.0还增加了一个选项,允许局部变量继承前一个作用域中,具有相同名称的变量值。另外,还加入一个新的shell选项,启用后将允许shell只尝试扩展关联数组下标(Subscripts)一次,但官方表示,这个功能在数学表示式中使用仍会出现问题。Bash 5.0现在会默认启用globasciiranges的shell选项,用户可以在配置阶段将其设定为预设关闭。

官方提醒,Bash 4.4与Bash 5.0之间存在部分不兼容的更新,像是nameref变量解析方法的变更,代表着使用namerefs会出现不同的行为,尽管官方提到他们已经尽可能减少这种兼容性问题,但仍有部分无可避免。除此之外,现在于预设情况下,当启用扩充侦错模式的时候,则壳层才会在启动时配置BASH_ARGC和BASH_ARGV,官方表示,这是一个之前的设定疏忽,在传递大量参数时,会造成效能低落问题。官方建议使用者可以将Bash链结到已经安装的Readline函式库,而非使用lib/readline中的私有版本,因为只有Readline 8.0以及更新的版本,才能提供所有Bash 5.0需要的符号,使用早前的Readline函式库版本将无法正常运作。

这篇关于功能更齐全!Unix shell Bash 5.0释出的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/323680

相关文章

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

linux下shell脚本启动jar包实现过程

《linux下shell脚本启动jar包实现过程》确保APP_NAME和LOG_FILE位于目录内,首次启动前需手动创建log文件夹,否则报错,此为个人经验,供参考,欢迎支持脚本之家... 目录linux下shell脚本启动jar包样例1样例2总结linux下shell脚本启动jar包样例1#!/bin

Java实现预览与打印功能详解

《Java实现预览与打印功能详解》在Java中,打印功能主要依赖java.awt.print包,该包提供了与打印相关的一些关键类,比如PrinterJob和PageFormat,它们构成... 目录Java 打印系统概述打印预览与设置使用 PageFormat 和 PrinterJob 类设置页面格式与纸张

MySQL 8 中的一个强大功能 JSON_TABLE示例详解

《MySQL8中的一个强大功能JSON_TABLE示例详解》JSON_TABLE是MySQL8中引入的一个强大功能,它允许用户将JSON数据转换为关系表格式,从而可以更方便地在SQL查询中处理J... 目录基本语法示例示例查询解释应用场景不适用场景1. ‌jsON 数据结构过于复杂或动态变化‌2. ‌性能要

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

Golang如何用gorm实现分页的功能

《Golang如何用gorm实现分页的功能》:本文主要介绍Golang如何用gorm实现分页的功能方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录背景go库下载初始化数据【1】建表【2】插入数据【3】查看数据4、代码示例【1】gorm结构体定义【2】分页结构体

Java Web实现类似Excel表格锁定功能实战教程

《JavaWeb实现类似Excel表格锁定功能实战教程》本文将详细介绍通过创建特定div元素并利用CSS布局和JavaScript事件监听来实现类似Excel的锁定行和列效果的方法,感兴趣的朋友跟随... 目录1. 模拟Excel表格锁定功能2. 创建3个div元素实现表格锁定2.1 div元素布局设计2.

shell中set -u、set -x、set -e的使用

《shell中set-u、set-x、set-e的使用》本文主要介绍了shell中set-u、set-x、set-e的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录✅ 1. set -u:防止使用未定义变量 作用: 示例:❌ 报错示例输出:✅ 推荐使用场景:✅ 2. se

HTML5实现的移动端购物车自动结算功能示例代码

《HTML5实现的移动端购物车自动结算功能示例代码》本文介绍HTML5实现移动端购物车自动结算,通过WebStorage、事件监听、DOM操作等技术,确保实时更新与数据同步,优化性能及无障碍性,提升用... 目录1. 移动端购物车自动结算概述2. 数据存储与状态保存机制2.1 浏览器端的数据存储方式2.1.