export的更多理解
环境变量与自定义变量的区别在于该变量是否会被子进程继续引用。具体地说,如果该变量是环境变量,那么该变量会被子进程继续引用;如果该变量是自定义变量,那么该变量不会被子进程继续引用。
当你登录Linux并且取得一个bash之后,你的bash就是一个独立的进程。接下来你在这个bash下面所执行的任何命令都是由这个bash衍生出来的,那些被执行的命令就被称为子进程了。
在原本运行的bash中执行另一个bash,操作的环境就会跑到第二个bash里面去,原本的bash会处于sleep状态。实线是整个命令的运行环境。当第二个bash结束后,会返回到原本的bash中去。
因为子进程仅仅会继承父进程的环境变量,子进程不会继承父进程的自定义变量。所以原本bash中的自定义变量在进入子进程后就消失不见了。直到子进程退出后,回到原本的父进程,这个自定义变量才会重新出现。
为什么环境变量的数据可以被子进程引用?
因为内存配置的关系。 当启动一个shell,操作系统会分配一块内存给shell使用,此内存的变量可以让子进程取用。如果在父进程中用export命令,可以将自定义变量的内容写到这块内存中。当加载一个shell子进程时,子shell可以将父shell的环境变量所在的内存内容导入自己的环境变量内存块中。
用这种方法,我们可以将某些变量在相关进程之间存在。
declare命令与作用
delare可以声明变量的类型,用法:
csdn1013@LAPTOP-QNFOQI5C:~$ declare [-aixr] variable
-a: 将后面名为variable的变量定义为数组(array)类型
-i: 将后面名为variable的变量定义为整数数字(integer)类型
-x:与export一样,就是将后面的variable变成环境变量
-r: 将变量设置为只读(read-only)类型,变量内容不可改变, 也不能重设
csdn1013@LAPTOP-QNFOQI5C:~$ sum=100+2
csdn1013@LAPTOP-QNFOQI5C:~$ echo $sum
100+2
csdn1013@LAPTOP-QNFOQI5C:~$ declare -i sum=100+2
csdn1013@LAPTOP-QNFOQI5C:~$ echo $sum
102
变量类型默认为字符串,所以若不指定变量类型,则1+2为一个字符串,而不是计算式。所以第一次查看sum的结果时100+2.
bash环境中的数值运算,默认仅能达到整数类型,所以1/3的结果时0
csdn1013@LAPTOP-QNFOQI5C:~$ declare -r sum
csdn1013@LAPTOP-QNFOQI5C:~$ sum=csdn
-bash: sum: readonly variable
将sum设置成只读后,修改sum的值会提示sum是一个只读变量,不能改变。
csdn1013@LAPTOP-QNFOQI5C:~$ declare -r sum
csdn1013@LAPTOP-QNFOQI5C:~$ sum=csdn
-bash: sum: readonly variable
csdn1013@LAPTOP-QNFOQI5C:~$ declare -p sum
declare -ir sum="102"
csdn1013@LAPTOP-QNFOQI5C:~$ declare -x sum
csdn1013@LAPTOP-QNFOQI5C:~$ export | grep sum
declare -irx sum="102"
csdn1013@LAPTOP-QNFOQI5C:~$ declare +x sum
csdn1013@LAPTOP-QNFOQI5C:~$ declare -p sum
declare -ir sum="102"
csdn1013@LAPTOP-QNFOQI5C:~$
数组变量类型
var[index]=content
读取:$(数组)
csdn1013@LAPTOP-QNFOQI5C:~$ var[0]="abc"
csdn1013@LAPTOP-QNFOQI5C:~$ echo ${var[0]}
abc
参考:鸟哥的Linux私房菜
?