环境变量操作函数

getenv获取环境变量值的函数;

setenv改变或者添加环境变量函数;

unsetenv 取消环境变量;

(可以在终端上man 函数名来获取详细的函数信息)

#include<stdio.h>
#include<stdlib.h>
#include<string.h>int main()
{char *val;const char *name = "ABD";val = getenv(name);  //获取name的环境变量值printf("1,%s = %s\n",name,val);setenv(name, "haha-day-and-night",1); //设置name的环境变量值为haha-day-and-night
val = getenv(name);printf("2,%s = %s\n",name,val);#if 0int ret = unsetenv("ABCDEFG");printf("ret = %d\n",ret);val = getenv(name);printf("3,%s = %s\n",name,val);
#elseint ret = unsetenv("ABD");  //取消环境变量name的值printf("ret = %d\n",ret);val = getenv(name);printf("3,%s = %s\n",name,val);
#endifreturn 0;
}    

运行结果:

ubuntu1604@ubuntu:~/wangqinghe/C/20190805$ gcc setenv.c -o setenv

ubuntu1604@ubuntu:~/wangqinghe/C/20190805$ ./setenv

1,ABD = (null)

2,ABD = haha-day-and-night

ret = 0

3,ABD = (null)

 

把if 0 改为 1

运行结果:

ubuntu1604@ubuntu:~/wangqinghe/C/20190805$ gcc setenv.c -o setenv

ubuntu1604@ubuntu:~/wangqinghe/C/20190805$ ./setenv

1,ABD = (null)

2,ABD = haha-day-and-night

ret = 0

3,ABD = haha-day-and-night

 

没有ABCDEFG这个环境变量,删除它时,是不会报错的。

 

但是如果把   int ret = unsetenv("ABCDEFG");

改为      int ret = unsetenv("ABD="); 这种时,它会报错。

 

运行结果:

ubuntu1604@ubuntu:~/wangqinghe/C/20190805$ ./setenv

1,ABD = (null)

2,ABD = haha-day-and-night

ret = -1

3,ABD = haha-day-and-night

转载于:https://www.cnblogs.com/wanghao-boke/p/11304929.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/384909.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Makefile(三)

在平时使用中&#xff0c;可以使用以下的makefile来编译单独的代码 src $(wildcard *.c) obj $(patsubst %.c, %.o, $(src))CC gcc CFLAGS -Wall -gall:$(target)$(target):%:%.c$(CC) $< -o $ $(CFLAGS).PHONY: clean all clean:-rm -rf $(target) 使用方法就是make 后…

位运算(C++)

C输出十六进制 #include<iostream> #include<iomanip> using namespace std;int main() {int a 60;int b 13;int c a &b;cout << "a : hex "<<hex << a << endl;cout << "b : hex "<<hex <<…

数学函数(C/C++)

C中包含头文件<math.h> C包含头文件<cmath> 函数 double cos&#xff08;double&#xff09; 该函数返回弧度角&#xff08;double型&#xff09;的余弦 double tan&#xff08;double&#xff09; 该函数返回弧度角&#xff08;double型&#xff09;的正切…

数据类型(C++)

不同系统会有不同差异&#xff1a; 类型 位(byte) 范围 char 1 -128—127 or 0 – 255 unsigned char 1 0 – 255 signed int 1 -128—127 int 4 -2^31 – 2^32-1 unsigned int 4 0 – 2^32 signed int 4 -2^31 – 2^32-1 short int 2 2^15 – 2^15-1 …

日期与时间(C/C++)

C继承了C语言用于日期和时间操作的结构和函数&#xff0c;使用之前程序要引用<ctime>头文件 有四个与时间相关的类型:clock_t、time_t、size_t、和tm。类型clock_t、size_t、和time_t能够把系统时间和日期表示为某种整数。 结构体tm把时间和日期以C结构的形式保存&#x…

标准输入输出(C++)

输入输出流函数&#xff08;模板&#xff09; #include<iostream> #include<iomanip> using namespace std; int main() {cout << setiosflags(ios::left|ios::showpoint); //设左对齐cout.precision(5); //设置除小数…

拷贝函数和构造函数

类的构造函数&#xff1a; 类的构造函数是类的一种特殊的成员函数&#xff0c;它会在每次创建类的新对象时执行。 构造函数的名称与类的名称是完全相同的&#xff0c;并且不会返回任何类型&#xff0c;也不会返回void。 构造函数可用于为某些成员变量初始值。 默认的构造函数是…

拷贝构造函数

拷贝构造函数是一种特殊的构造函数&#xff0c;它在创建对象时&#xff0c;使用的是同一类中之前创建的对象来初始化新创建的对象。拷贝构造函数通常用于&#xff1a; l 通过使用另一个同类型的对象来初始化新创建的对象&#xff1b; l 复制对象把它作为参数传递给函数&#…

Linux进程通信之管道

进程间完成数据传递需要借助操作系统提供的特殊的方法&#xff0c;比如&#xff1a;文件、管道、信号、共享内存、消息队列、套接字、命名管道等。但现在常用的进程间通信方式有&#xff1a; 管道 – 使用最简单 pipe 管道一般读写行为 FIFO&#xff08;有名管道&#xff09;&a…

Linux进程通信之文件

父子进程共享打开的文件描述符------使用文件完成进程间通信. /*** fork_share_fd.c***/ #include <stdio.h> #include <unistd.h> #include <string.h> #include <stdlib.h> #include <fcntl.h> #include <sys/wait.h>int main(void) {in…

dup2函数

将当前系统中的进程信息打印到文件中 命令行&#xff1a;ps aux > out 将ps得到的信息重定向到out文件中 使用dup2文件在程序中完成。 int dup2(int oldfd,int newfd); /*** dup2.c ***/ #include<stdio.h> #include<fcntl.h> #include<unistd.h> #includ…

wait()函数

wait()函数&#xff1a;回收僵尸进程 父进程调用wait函数可以回收子进程终止信息。该函数有三个功能&#xff1a; 1&#xff09; 阻塞等待子进程退出 2&#xff09; 回收子进程残留资源 3&#xff09; 获取子进程结束状态&#xff08;退出原因&#xff09; /*** zoom_test.c **…

waitpid()函数

waitpid函数 作用同于wait&#xff0c;但可指定pid进程清理&#xff0c;可以不阻塞。 pid_t waitpid(pid_t pid,int *status,int options);成功&#xff1a;返回清理掉的子进程ID&#xff1b;失败&#xff1a;-1&#xff08;无子进程&#xff09; 特殊参数和返回情况&#xff1…

孤儿进程、僵尸进程

孤儿进程&#xff1a;父进程先于子进程结束&#xff0c;则子进程成为孤儿进程&#xff0c;子进程的父进程成为init进程&#xff0c;称为init进程领养孤儿进程。 /*** orphan.c ***/ #include <stdio.h> #include <unistd.h> #include <sys/wait.h>int main(v…

友元函数

类的友元函数是定义在类外部&#xff0c;但有权访问类的所有私有成员和保护成员。尽管友元函数的原型有在类的定义中出现过&#xff0c;但友元函数并不是成员函数。 友元可以是一个函数&#xff0c;该函数被称为友元函数&#xff1b;友元也可以是一个类&#xff0c;该类被称为友…

this指针

在C中&#xff0c;每一个对象都能够通过this指针来访问自己的地址。this指针是所有成员函数的隐含参数。因此&#xff0c;在成员函数内部&#xff0c;它可以用来指向调用对象。 友元函数是没有this指针的&#xff0c;因为友元不是类的成员&#xff0c;只有成员函数才有this指针…

静态成员

我们可以使用static关键字把类成员定义为静态的。当我们声明类的成员为静态时&#xff0c;这意味着无论创建多少个类的对象&#xff0c;静态成员都只有一个副本。 静态成员在类的所有对象都是贡献的。如果不存在其他的初始化语句&#xff0c;在创建第一个对象时&#xff0c;所有…

Linux进程通信之mmap

mmap()函数&#xff1a; void *mmap(void* addr,size_t length,int port,int flags,int fd,off_t offset); 返回&#xff1a;成功&#xff1a;返回创建的映射区首地址&#xff1b;失败&#xff1a;MAP_FAILED 宏 参数&#xff1a; addr: 建立映射区的首地址&#xff0c;由…

Linux之文件通信

/** 后执行,尝试读取另外一个进程写入文件的内容*/ #include <stdio.h> #include <unistd.h> #include <stdlib.h> #include <fcntl.h> #include <string.h>int main(void) {char buf[1024];char *str "----------test2 write secesuss---…

重载函数和重载运算符

C允许在同一个作用域中的某个函数和运算符指定多个定义&#xff0c;分别称为函数重载和运算符重载。 重载声明是指一个与之前已经在该作用域内声明过的函数或方法具有相同名称的声明&#xff0c;但他们的参数列表和定义&#xff08;实现&#xff09;不相同。 当调用一个重载函数…