


GNU-based operating systems like Linux rely on a command language interpreter or shell called Bash to accomplish most of their computing tasks and goals .
Bash is the abbreviation of Bourne Again Shell. Bunne Again Shell is a pun name that pays tribute to Bourne Shell (invented by Steven Bourne). In terms of compatibility, Bash and sh are a perfect match. Useful features evident in the C shell ( csh ) and Korn shell ( ksh ) are also included in this shell language interpreter.
In terms of implementation, Bash aims to conform to the tools portion of the IEEE POSIX specification (IEEE Standard 1003.1) and the IEEE POSIX Shell. Therefore, as an interactive and programming tool, Bash provides functional improvements over those in sh.
Users of Linux and other GNU-based operating systems do not have to rely solely on Bash as their primary command language interpreter, since versions of shells like csh are also pre-packaged on these systems. Due to its unique shell properties such as portability, Bash is only configured to be used as the default Linux shell.
Comparing $() with ${} in Bash
In order to compare these two properties related to the Bash environment, we must reiterate $() to$(command)
and ${}to ${parameter}
. So we can try to define these two Bash entities.
Understanding $(command)
$(command)
Involves command substitution in Bash. More specifically, the command part in$(command)
is executed and its output is captured and printed on standard output. The syntax behind
牛逼啊!接私活必备的 N 个开源项目!赶快收藏
$(command)
is token level. Consider executing the following command, which is designed to print out the current date on the terminal.
echo "今天是 $(date). LinuxMi.com 又是美好的一天。"
在 Linux 中打印日期
上述执行可以用以下方式解释。首先,执行 date 命令并将其输出作为参数包含在 echo 命令中。
在这里,我们可以假设命令替换在重新包含在主 shell 之前在单独的子 shell 中执行。
了解 ${parameter}
${parameter}
在Bash中涉及参数替换。根据 Bash 手册页,参数是一个值存储实体。参数实体可以与名称、数字或特殊字符相关联。
大括号{}
暗示我们在处理位置参数,或者在使用的参数(参数值)后面是一个与参数名称不相关的非解释性字符,例如${animal}s
。
至于位置参数,可以用一个或多个数字来表示(单个数字 0 除外)。因此,如果我们有一个名为$variable_name
的变量,则可以使用参数 替换${parameter}
来检索关联的变量值。
考虑以下变量声明命令:
$ animal=lion
让我们调用 animal 变量以尝试将变量值复数:
$ echo $animals
在命令中声明变量
在标准输出中不会打印任何内容,因为 Bash 不理解变量$animals
。但是,我们可以通过如下方式使用参数替换方法成功调用我们的$animals
变量:
$ echo ${animal}s
在命令中调用变量
在某些情况下,感叹号可能会在参数替换实现的第一个左大括号之后出现。在这种情况下,就会出现变量间接的概念。另外,搜索公众号Linux就该这样学后台回复“猴子”,获取一份惊喜礼包。
变量值优先于参数值,如下所示:
$ animal=lion $ echo $animal $ lion=rafiki $ echo $lion $ echo ${!animal}
参数值的优先级
希望本文能够说明 Bash 中$()
和${}
之间的区别。
The above is the detailed content of What is the difference between ${} and $() in Bash. For more information, please follow other related articles on the PHP Chinese website!

The core components of Linux include the kernel, file system, shell and common tools. 1. The kernel manages hardware resources and provides basic services. 2. The file system organizes and stores data. 3. Shell is the interface for users to interact with the system. 4. Common tools help complete daily tasks.

The basic structure of Linux includes the kernel, file system, and shell. 1) Kernel management hardware resources and use uname-r to view the version. 2) The EXT4 file system supports large files and logs and is created using mkfs.ext4. 3) Shell provides command line interaction such as Bash, and lists files using ls-l.

The key steps in Linux system management and maintenance include: 1) Master the basic knowledge, such as file system structure and user management; 2) Carry out system monitoring and resource management, use top, htop and other tools; 3) Use system logs to troubleshoot, use journalctl and other tools; 4) Write automated scripts and task scheduling, use cron tools; 5) implement security management and protection, configure firewalls through iptables; 6) Carry out performance optimization and best practices, adjust kernel parameters and develop good habits.

Linux maintenance mode is entered by adding init=/bin/bash or single parameters at startup. 1. Enter maintenance mode: Edit the GRUB menu and add startup parameters. 2. Remount the file system to read and write mode: mount-oremount,rw/. 3. Repair the file system: Use the fsck command, such as fsck/dev/sda1. 4. Back up the data and operate with caution to avoid data loss.

This article discusses how to improve Hadoop data processing efficiency on Debian systems. Optimization strategies cover hardware upgrades, operating system parameter adjustments, Hadoop configuration modifications, and the use of efficient algorithms and tools. 1. Hardware resource strengthening ensures that all nodes have consistent hardware configurations, especially paying attention to CPU, memory and network equipment performance. Choosing high-performance hardware components is essential to improve overall processing speed. 2. Operating system tunes file descriptors and network connections: Modify the /etc/security/limits.conf file to increase the upper limit of file descriptors and network connections allowed to be opened at the same time by the system. JVM parameter adjustment: Adjust in hadoop-env.sh file

This guide will guide you to learn how to use Syslog in Debian systems. Syslog is a key service in Linux systems for logging system and application log messages. It helps administrators monitor and analyze system activity to quickly identify and resolve problems. 1. Basic knowledge of Syslog The core functions of Syslog include: centrally collecting and managing log messages; supporting multiple log output formats and target locations (such as files or networks); providing real-time log viewing and filtering functions. 2. Install and configure Syslog (using Rsyslog) The Debian system uses Rsyslog by default. You can install it with the following command: sudoaptupdatesud

When choosing a Hadoop version suitable for Debian system, the following key factors need to be considered: 1. Stability and long-term support: For users who pursue stability and security, it is recommended to choose a Debian stable version, such as Debian11 (Bullseye). This version has been fully tested and has a support cycle of up to five years, which can ensure the stable operation of the system. 2. Package update speed: If you need to use the latest Hadoop features and features, you can consider Debian's unstable version (Sid). However, it should be noted that unstable versions may have compatibility issues and stability risks. 3. Community support and resources: Debian has huge community support, which can provide rich documentation and

This article describes how to use TigerVNC to share files on Debian systems. You need to install the TigerVNC server first and then configure it. 1. Install the TigerVNC server and open the terminal. Update the software package list: sudoaptupdate to install TigerVNC server: sudoaptinstalltigervnc-standalone-servertigervnc-common 2. Configure TigerVNC server to set VNC server password: vncpasswd Start VNC server: vncserver:1-localhostno


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

DVWA
Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

SublimeText3 English version
Recommended: Win version, supports code prompts!

WebStorm Mac version
Useful JavaScript development tools

SublimeText3 Linux new version
SublimeText3 Linux latest version