别名和导出(和函数!)[Bash]有什么区别? [英] What is the difference between alias and export (and a function!)[BASH]?
问题描述
我很惊讶以前没人问过,但…
和别名⇢alias EXPORT='alias'
函数⇢function exporter() { echo $EXPORT }
和
导出⇢export ALIAS='export'
关于这件事...
alias export=$(function)
(j/k)
在bash
(zsh
等)
具体地说,我最感兴趣的是了解
alias this=that
和
export that=this
我把两个表单...都放在了中--我宁愿停止随意选择其中一个。😂
我相信在某个地方有很多关于"Unix外壳的范围和用例"的参考……但我想我应该把这个问题贴在这里,以正义正典的名义。
推荐答案
您问的是两类截然不同的东西:别名和函数定义了类似命令的行为;export
标记要导出到子进程的变量。让我先来看一下类似命令的内容:
alias ll='ls -l'
)定义命令的简写。它们旨在用于交互使用(实际上在外壳脚本中默认禁用它们),并且简单但不灵活。例如,您在别名后指定的任何参数都会简单地附加到命令的末尾;如果您想要像alias findservice='grep "$1" /etc/services'
这样的内容,则不能这样做,因为$1
在这里没有任何用处。
函数类似于别名的更灵活、更强大的版本。函数可以接受进程参数、包含循环、条件、此处文档等。基本上,可以使用外壳脚本执行的任何操作都可以在函数中完成。请注意,定义函数的标准方法实际上并不使用关键字function
,只是在名称后面加上圆括号。例如:findservice() { grep "$1" /etc/services; }
export
之前,我需要讨论一下未导出的变量。基本上,您可以定义一个变量具有某个(文本)值,然后如果您通过$variablename
引用该变量,它将被替换到命令中。这与别名或函数在两个方面不同:别名或函数只能作为命令中的第一个单词出现(例如,ll filename
将使用别名ll
,但echo ll
不会),以及必须使用$
显式调用变量(echo $foo
将使用变量foo,但echo foo
不会))。更根本的是,别名和函数旨在包含可执行代码(命令、外壳语法等),而变量旨在存储不可执行数据。
(顺便说一句,您几乎总是应该将变量引用放在双引号中--也就是说,使用echo "$foo"
而不只是echo $foo
。如果没有双引号,变量的内容将以某种奇怪的方式进行解析,这往往会导致错误。)
还有一些由外壳程序自动设置的"特殊"外壳变量(例如$HOME
),或者影响外壳程序的行为方式(例如$PATH
控制它查找可执行命令的位置),或者两者兼而有之。
export
ed变量既可以在当前的外壳中使用,也可以传递到任何子进程(子外壳、其他命令等)。例如,如果我使用LC_ALL=en_US.UTF-8
,就会告诉我的当前外壳使用"en_US.UTF-8"区域设置。另一方面,如果我这样做了export LC_ALL=en_US.UTF-8
,这将告诉当前的外壳及其执行的所有子进程和命令使用该区域设置。
请注意,可以将外壳变量标记为独立于定义它而导出,并且一旦导出,它将保持导出状态。例如,$PATH
(据我所知)总是导出,因此PATH=/foo:/bar
与export PATH=/foo:/bar
具有相同的效果(尽管仅在$PATH以某种方式尚未导出的情况下可能首选后者)。
还可以将赋值用作命令的前缀,从而将变量导出到特定的命令,而无需在当前的外壳中定义它。例如,LC_ALL=en_US.UTF-8 sort filename
将告诉sort
命令使用"en_US.UTF-8"区域设置,但不会将其应用于当前外壳程序(或任何其他命令)。
这篇关于别名和导出(和函数!)[Bash]有什么区别?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!