shell变量的可见性

注意:
后续谈到进程默认都是shell进程,也就是运行shell的进程。
一、前言

  • 执行脚本时,其实是在当前shell新建了另外一个子进程,由该子进程执行脚本指令。子进程会继承父进程的shell环境,脚本执行完该子进程也会被回收。
  • shell环境其实就是一个含有kv值的集合,包括环境变量和exported变量。
  • 进程执行的任何命令可以理解为子进程在执行一个个函数。而执行一个shell脚本就是创建一个新进程,里面的命令在这些新进程里执行。而为了让执行这些shell脚本就跟执行命令一样,不创建新进程,就在该进程里执行操作,可以用source(或者一个“.”)命令。

二、bash shell三种可见性级别的变量
按照可见性从小到大排序:
1.局部变量
local修饰符标识,只能在脚本的函数或者代码块中被访问,即使在该脚本内也不能访问到。

my_local_var="hello"
# Define a local variable inside a function
my_function() {
    local my_local_var="world"
    echo "Inside function: $my_local_var"    # prints "Inside function: world"
}

# Call the function and print the value of the local variable
my_function
echo "Outside function: $my_local_var"    # prints "Outside function: hello"

2. 普通(全局)变量
可以被整个脚本或者shell进程访问到,但是也仅此而已。子进程和父进程都访问不到。

-------------test1.sh-------------
#!/bin/bash
my_var=2
./test2.sh
echo "my_var_2=$my_var_2" #打印空

-------------test2.sh-------------
echo "test2 retrieving my_var=$my_var" #打印空
my_var_2=21
-------------test1.sh-------------
#!/bin/bash
my_var=2
source ./test2.sh
echo "my_var_2=$my_var_2" #打印空

-------------test2.sh-------------
echo "test2 retrieving my_var=$my_var" #打印2
my_var_2=21

3. exported变量
export修饰符标识,当把一个变量export时,他会把这个变量以key-value的形式添加到当前shell环境中。因此可以被子进程读取到,但是跟普通变量一样父进程读取不到该值。

-------------test1.sh-------------
#!/bin/bash
export my_export_var=1
./test2.sh
-------------test2.sh-------------
echo "test2 retrieving my_export_var=$my_export_var" #打印1
--------运行test1.sh的终端---------
echo $my_export_var #打印空
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
什么是makefile?或许很多Windows的程序员都不知道这个东西,因为那些Windows 的IDE都为你做了这个工作,但我觉得要作一个好的和professional的程序员, makefile还是要懂。这就好像现在有这么多的HTML的编辑器,但如果你想成为一个专业 人士,你还是要了解HTML的标识的含义。特别在Unix下的软件编译,你就不能不自己写 makefile了,会不会写makefile,从一个侧面说明了一个人是否具备完成大型工程的能 力。 因为,makefile关系到了整个工程的编译规则。一个工程中的源文件不计数,其按类型、 功能、模块分别放在若干个目录中,makefile定义了一系列的规则来指定,哪些文件需要 先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作,因 为makefile就像一个Shell脚本一样,其中也可以执行操作系统的命令。 makefile带来的好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工 程完全自动编译,极大的提高了软件开发的效率。make是一个命令工具,是一个解释 makefile中指令的命令工具,一般来说,大多数的IDE都有这个命令,比如:Delphi的 make,Visual C++的nmake,Linux下GNU的make。可见,makefile都成为了一种 在工程方面的编译方法。 现在讲述如何写makefile的文章比较少,这是我想写这篇文章的原因。当然,不同产商的 make各不相同,也有不同的语法,但其本质都是在“文件依赖”上做文章,这里,我仅 对GNU的make进行讲述,我的环境是RedHat Linux 8.0,make的版本是3.80。必竟, 这个make是应用最为广泛的,也是用得最多的。而且其还是最遵循于IEEE 1003.2-1992 标准的(POSIX.2)。 在这篇文档中,将以C/C++的源码作为我们基础,所以必然涉及一些关于C/C++的编译的 知识,相关于这方面的内容,还请各位查看相关的编译器的文档。这里所默认的编译器是 UNIX下的GCC和CC。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值