# alias

定义或显示别名。

## 概要

```
alias [-p] [name[=value] ...]
```

## 主要用途

* 简化较长的命令。
* 定义一个或多个别名。
* 修改一个或多个已定义别名的值。
* 显示一个或多个已定义别名。
* 显示全部已定义的别名。

## 选项

```
-p：显示全部已定义的别名。
```

## 参数

name（可选）：指定要（定义、修改、显示）的别名。

value（可选）：别名的值。

### 返回值

alias返回true除非您要显示的别名未定义。

## 例子

```
# 显示全部已定义的别名
alias
alias -p

# 显示已定义的别名（假设当前环境存在以下别名）
alias ls
alias ls grep

# 定义或修改别名的值
alias ls='ls --color=auto'
alias ls='ls --color=never' grep='grep --color=never'
```

## 知识点

直接在shell里设定的命令别名，在终端关闭或者系统重新启动后都会失效，如何才能永久有效呢？

使用编辑器打开`~/.bashrc`，在文件中加入别名设置，如：alias rm='rm -i'，保存后执行`source ~/.bashrc`，这样就可以永久保存命令的别名了。

因为修改的是当前用户目录下的`~/.bashrc`文件，所以这样的方式只对当前用户有用。如果要对所有用户都有效，修改`/etc/bashrc`文件就可以了。

> 请注意，以下内容可能与您实际使用的系统有出入:
>
> 在CentOS7下，这个文件是`/etc/bash.bashrc`。此外在CentOS7下，细看`~/.bashrc`文件，会发现有这样一段代码：
>
> ```
> if [ -f ~/.bash_aliases ]; then
>   . ~/.bash_aliases
> fi
> ```
>
> 这个代码的意思就是如果存在那么就加载`.bash_aliases`文件，所以也可以在用户根目录下新建该文件用于单独存放命令别名设置。

## 错误用法

* 要显示的别名未定义。
* 当您定义（修改）别名的值的时候，由于值的字符串有空格但您没有用**单引号扩起**，那么会导致严重的问题：

```
# 为方便演示，删除全部别名
unalias -a
# 没有用单引号扩起
alias rm=rm -rf
# 执行命令后报错 bash: alias: -rf: not found
# 这时使用alias查看rm的别名时返回 alias rm='rm'
```

```
# 更具有迷惑性的例子
# 为方便演示，删除全部别名
unalias -a
# 仍然没有用单引号括起
alias ls=ls --color=never
# 执行命令后看起来没有报错

# 使用alias查看全部别名会发现运行结果如下：
# alias --color=never
# alias ls='ls'
# alias处理时将它们看成了两组
```

## Q\&A

Q：如果我要显示一到多个别名，但不知道其中是否有未定义的该怎么办？

A：正常执行就是了，alias不会因为有一个未定义的别名就结束对剩余参数的执行。

Q：如果我这么定义`alias cd='ls' ls='cd'`，会有什么后果？

A：运行cd依然会切换目录，运行ls依然会列出文件夹的内容；不要这样定义。

### 注意

1. **执行脚本时请注意：**

> 使用`source`命令执行的bash脚本如果执行了`alias`或`unalias`命令，那么有可能会对终端环境的别名设置产生影响；终端环境的别名设置也可能改变运行结果；
>
> 通过`sh`方式调用的bash脚本或直接运行当前用户有执行权限的脚本不受终端环境的别名影响。

1. 删除别名，请查看`unalias`命令。
2. 建议您不要对`mv cp rm`等命令的别名设置危险的`-f`选项，比如`alias rm='rm -f'`。
3. 需要注意别名是否和其他命令有冲突的情况。
4. 该命令是bash内建命令，相关的帮助信息请查看`help`命令。

### 其他参考链接

[Linux命令详解：\[8\]alias创建自己的命令](https://jingyan.baidu.com/article/ac6a9a5e6738422b653eac01.html)


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://hezhiqiang.gitbook.io/linux/ming-ling/alias.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
