通过文件编程小应用修改文件的信息这个代码
把修改文件的通过
gcc dema.c -o change
产生一个可执行文件change
int main()
{
pid_t pid;
int deta;
while(1){
printf("please data\n");
scanf("%d",&deta);
if(deta==1){
pid=fork();
//使用fork函数生成子进程
if(pid>0){
wait(NULL);
}
else if(pid==0){
execlp("./change","change","config",NULL);
//通过execlp函数调用可执行文件change
}
}else{
printf("wait,no do thing\n");
}
}
return 0;
}
system函数
int system(const char * cmdstring)
system(); 括号里面表示的是一个字符串 如果前面定义了该字符串 那么这时,使用该字符串就可以直接
char cmd[16]=“ls”;
system(cmd);
如果要在system中直接使用 ls 那么
system(“ls”); 这样使用该函数
阶段1:创建子进程等准备工作。如果失败,返回-1。
阶段2:调用/bin/sh拉起shell脚本,如果拉起失败或者shell未正常执行结束(参见备注1),原因值被写入到status的低8~15比特位中。system的man中只说明了会写了127这个值,但实测发现还会写126等值。
上面函数execip函数变成下面的也可以实现同样的功能
直接使用在函数里面使用的话
使用./a.out config
sprintf(cmd,“kill -%d %d”,pid,signum);
执行脚本使用system(cmd);
system("./change config");
system 最后还会返回到原函数当中执行
执行一个指令 想把指令打印出来的东西保存在字符串里 system 的源码 函数是通过exec族函数使用的 因此结果不会返回文件中
但是函数的执行结果不会返回到函数里面来
popen函数
popen函数就可以把指令的运行结果返回到字符串中并且显示来
函数原型:
#include “stdio.h”
FILE popen( const char command, const char* mode )
参数说明:
command: 是一个指向以 NULL 结束的 shell 命令字符串的指针。这行命令将被传到 bin/sh 并使用 -c 标志,shell 将执行这个命令。
mode: 只能是读或者写中的一种,得到的返回值(标准 I/O 流)也具有和 type 相应的只读或只写类型。如果 type 是 “r” 则文件指针连接到 command 的标准输出;如果 type 是 “w” 则文件指针连接到 command 的标准输入。
返回值:
如果调用成功,则返回一个读或者打开文件的指针,如果失败,返回NULL,具体错误要根据errno判断
int pclose (FILE* stream)
参数说明:
stream:popen返回的文件指针
返回值:
如果调用失败,返回 -1
作用:
popen() 函数用于创建一个管道:其内部实现为调用 fork 产生一个子进程,执行一个 shell 以运行命令来开启一个进程这个进程必须由 pclose() 函数关闭。
char ret[1024]={0};
FILE * fd=NULL;
fd=popen("ps","r");
int n_read=fread(ret,1,1024,fd);
printf("文件的字节大小%d,输出的字符是%s",n_read,ret);
fclose(fd);