export方法_import怎么用

export方法_import怎么用基础命令学习目录首页export的基本作用就是将父shell中的局部变量设置为环境变量,使得该变量可以在子shell中使用。下面设置两种情景对export进行原理解析。情景1.有一个名为myexport.sh的脚本,内容如下:#!/bin/shexportMY_PATH=/usr/local12在linux环境中打开终端运行该shell$shmy…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

  

基础命令学习目录首页

 

export 的基本作用就是将父shell中的局部变量设置为环境变量,使得该变量可以在子shell中使用。下面设置两种情景对export进行原理解析。
情景

 1. 有一个名为myexport.sh的脚本,内容如下:
#!/bin/sh

export MY_PATH=/usr/local12
在linux环境中打开终端运行该shell
 
$sh myexport.sh

$echo $MY_PATH

$123
运行该shell后在终端无法看到该环境变量的值。

 – 在一个终端用export设置环境变量后再其他终端不可见。
原因

  首先要提到进程,进程是一个运行着的程序,是代码的动态形式,进程有如下属性:

独立的内核堆栈

进程控制块

独立的存储空间

由于每个进程有自己独立的存储空间,所以进程间的的数据是不可见的,进程间的交互需要用到进程间通信。每一个shell都是一个独立的进程,所以在一个进程内的操作通常不会影响到另一个进程的内容,也不会被另一个进程所看到。所以上面第二种情景中,不同的终端开启了不同的shell,这些终端是相互独立的进程,彼此无论如何设置环境变量,相互都是不可见的。(写入到系统配置文件中的环境变量那就是通信了。)
export命令用于将父shell的局部变量全局化,这种全局化的意思就是让子shell可见。在父shell中执行一个子shell,会启动一个新的进行——子进程,故子shell即是一个独立于父shell的进程,父子shell的存储空间是相互不可见的(即子shell看不到父shell中的变量),如果想让子shell看到父shell的变量就需要将该变量从父shell的独立存储空间复制到子shell的独立存储空间,子shell看到的变量其实是自己进程空间的内容,而不是父进程的内容,只不过这另个空间的变量的名称和值相同而已。故export并没有采用什么高深的技术,只是将父进程空间的内容复制到子进程而已。
Linux中的父子进程是说父进程可以管理子进程,这种管理主要体现在三个方面:生、管、死,即父进程可以创建子进程,可以把上面export的例子算作一种管理吧,父进程死则子进程必须死,子进程死对父进程没有影响。其实除了生死之外,父子进程都是独立的进程。(父进程可以生子进程,为什么不叫母进程呢?英文是 parent process,可不是 father process 。这个涉及到了历史和文化问题,不讨论了。)
结果

那么问题来了,如何将情景1中的myexport.sh中的环境变量导入到当前进程中来呢?首先说明,父进程可以将自己的环境变量写入到子进程的空间中,但是子进程无法将自己空间的数据写入到父进程中(至少export命令做不到)。那么想要让子shell中的变量在父shell可见,最好的办法就是不要成为子shell,即只将该shell的内容导入到”父“shell中,而不执行该shell。这样用到的导入命令是”.” 和 ”source“,这就类似于c语言中的”#include”,用法如下:
$. myexport.sh  # or $source myexport.sh

$echo $MY_PATH

/usr/local

———————

作者:若有所思HS

来源:CSDN

原文:https://blog.csdn.net/u012150792/article/details/50583972

版权声明:本文为博主原创文章,转载请附上博文链接!
 
 
常用用法
# 功能说明:设置或显示环境变量。

# export [-fnp][变量名称]=[变量设置值]

# 只在本次登录中有效
# 再增加的路径用:追加

export PATH=$PATH:/home/jason001123456
 
说明
在shell中执行程序时,shell会提供一组环境变量。export可新增,修改或删除环境变量,供后续执行的程序使用。export的效力仅及于该此登陆操作。
参数:
 
 -f  代表[变量名称]中为函数名称。

 -n  删除指定的变量。变量实际上并未删除,只是不会输出到后续指令的执行环境中。

 -p  列出所有的shell赋予程序的环境变量123
 
延伸
export设置环境变量是暂时的,只在本次登录中有效,可修改如下文件来使命令长久有效。
 
1. 修改profile文件
#vi /etc/profile1
在里面加入:
 
export PATH=”$PATH:/opt/au1200_rm/build_tools/bin”1
这个在我们的机器上是大家共用的,建议不修改这个,只修改自己根路径下的。
 
2. 修改本id根路径下的.bashrc或.bash_profile文件:
 
# vi /home/zhaodw/.bash_profile1
在里面加入:
 
export PATH=”$PATH:/opt/au1200_rm/build_tools/bin”1
注意:

1、执行脚本时是在一个子shell环境运行的,脚本执行完后该子shell自动退出;

2、一个shell中的系统环境变量才会被复制到子shell中(用export定义的变量);

3、一个shell中的系统环境变量只对该shell或者它的子shell有效,该shell结束时变量消失(并不能返回到父shell中)。

4、不用export定义的变量只对该shell有效,对子shell也是无效的。

———————

作者:jason_cuijiahui

来源:CSDN

原文:https://blog.csdn.net/jason_cuijiahui/article/details/79408778

版权声明:本文为博主原创文章,转载请附上博文链接!

 

转载于:https://www.cnblogs.com/machangwei-8/p/10381608.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/196374.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • python dataframe fillna_python缺失值处理 fillna

    python dataframe fillna_python缺失值处理 fillna约定:importpandasaspdimportnumpyasnpfromnumpyimportnanasNaN填充缺失数据fillna()是最主要的处理方式了。df1=pd.DataFrame([[1,2,3],[NaN,NaN,2],[NaN,NaN,NaN],[8,8,NaN]])df1代码结果:01201.02.03.01NaNNaN2.02NaNNaNNaN38….

    2022年8月12日
    5
  • 正确的-配置Tomcat环境变量

    正确的-配置Tomcat环境变量跟着配就完事,超级正确

    2022年5月27日
    39
  • MIPI协议(下)

    MIPI协议(下)GOON…完成mipi信号通道分配后,需要生成与物理层对接的时序、同步信号: MIPI规定,传输过程中,包内是200mV、包间以及包启动和包结束时是1.2V,两种不同的电压摆幅,需要两组不同的LVDS驱动电路在轮流切换工作;为了传输过程中各数据包之间的安全可靠过渡,从启动到数据开始传输,MIPI定义了比较长的可靠过渡时间,加起来最少也有600多ns;而且规定各个时间参数是可调的,所以…

    2022年4月30日
    69
  • wing是什么_nativepage原理

    wing是什么_nativepage原理给定 n 本书,编号为 1∼n。在初始状态下,书是任意排列的。在每一次操作中,可以抽取其中连续的一段,再把这段插入到其他某个位置。我们的目标状态是把书按照 1∼n 的顺序依次排列。求最少需要多少次操作。输入格式第一行包含整数 T,表示共有 T 组测试数据。每组数据包含两行,第一行为整数 n,表示书的数量。第二行为 n 个整数,表示 1∼n 的一种任意排列。同行数之间用空格隔开。输出格式每组数据输出一个最少操作次数。如果最少操作次数大于或等于 5 次,则输出 5 or more。每个

    2022年8月8日
    3
  • CAS单点登录原理分析(一)

    CAS单点登录原理分析(一)一,业务分析在分布式系统架构中,假设把上述的三个子系统部署在三个不同的服务器上。前提是用户登录之后才能访问这些子系统。那么使用传统方式,可能会存在这样的问题:1.当访问用户中心,需要用户登录帐号2.当访问购物车,还需要用户登录帐号3.当访问商品结算,又一次需要用户登录帐号访问每一个子系统都需要用户登录帐号,这样的体验对于用户来说是极差。而使用单点登录就可以很好地解决上述的问题。二,单…

    2022年6月8日
    28

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号