Linux系统中(ylmf os 3.04.0)中如何运行c shell脚本?

最近在看深入理解计算机系统,看到一个函数叫做execve(),这个函数很有意思,可以在一个进程插入另外一个进程执行,但是又不像fork()一样产生一个子进程,execve()插入的进程和原进程共享进程号,就好像执行这进程就像执行过程调用一般随意。
函数原型如下:
int execve(const char *filename, char *const argv[], char *const envp[]);
The following program is designed to be execed by the second program below.
It just echoes its command-line one per line.
/* myecho.c */
#include &stdio.h&
#include &stdlib.h&
main(int argc, char *argv[])
for (j = 0; j & j++)
printf("argv[%d]: %s\n", j, argv[j]);
exit(EXIT_SUCCESS);
This program can be used to exec the program named in its command-line argument:
/* execve.c */
#include &stdio.h&
#include &stdlib.h&
#include &unistd.h&
main(int argc, char *argv[])
char *newargv[] = { NULL, "hello", "world", NULL };
char *newenviron[] = { NULL };
if (argc != 2) {
fprintf(stderr, "Usage: %s &file-to-exec&\n", argv[0]);
exit(EXIT_FAILURE);
newargv[0] = argv[1];
execve(argv[1], newargv, newenviron);
perror("execve");
/* execve() only returns on error */
exit(EXIT_FAILURE);
We can use the second program to exec the first as follows:
$ cc myecho.c -o myecho
$ cc execve.c -o execve
$ ./execve ./myecho
argv[0]: ./myecho
argv[1]: hello
argv[2]: world
插入一个shell脚本执行:
#include &stdio.h&
#include &stdlib.h&
#include &unistd.h&
main(int argc, char *argv[])
char *newargv[] = { "/etc" };
char *newenviron[] = { NULL };
if (argc != 2)
fprintf(stderr, "Usage: %s &file-to-exec&\n", argv[0]);
exit(EXIT_FAILURE);
newargv[0] = argv[1];
execve(argv[1], newargv, newenviron);
perror("execve");
/* execve() only returns on error */
exit(EXIT_FAILURE);
script.sh如下:
#!/bin/bash
./execve ./script.sh
会在当前终端下输出所有的文件
yca@ubuntu:~/桌面/hello$ ./execve ./script.sh
hello3.cpp
QuickSort.c
Quicksort1.c
很好很强大~~
阅读(...) 评论()怎么在windows系统中使用linux的shell脚本_Linux教程
怎么在windows系统中使用linux的shell脚本
学习啦【Linux教程】 编辑:晓斌
  的shell脚本提供了大量方便的工具,如:awk、grep、more、tail、wc等等,方便用户对文件、数据的分析,但是windows相对来说就没那么方便,要分析一个数据可能需要自己编程、编译然后才能对一些数据进行分析,对于一些轻量级的数据,不如shell脚本好用。下面就由学习啦小编为大家说说如何在windows下使用linux的shell脚本的。
  如何在windows下使用linux的shell脚本
  先下载cygwin对应于自己windows的版本:32位或64位
  (cygwin是一个在windows平台上运行的unix模拟环境,是cygnus solutions公司开发的自由软件)
  安提示安装好cygwin
  打开cygwin,就可以看到熟悉的命令行提示了,shell环境对应的根目录是软件的安装目录
  开始使用linux命令:grep、awk、less、vi等等,如果发现有缺少什么命令,重新运行setup.exe安装程序,搜索需求的命令,叉选上即可安装。
  以上就是学习啦小编为大家提供的解决方法,希望能帮助到大家!!!最后希望大家生活越来越好。
本文已影响 人
[怎么在windows系统中使用linux的shell脚本]相关的文章
看过本文的人还看了
689人看了觉得好
703人看了觉得好
1060人看了觉得好
【Linux教程】图文推荐
Copyright & 2006 -
All Rights Reserved
学习啦 版权所有博客访问: 109102
博文数量: 24
博客积分: 592
博客等级: 中士
技术积分: 313
注册时间:
IT168企业级官微
微信号:IT168qiye
系统架构师大会
微信号:SACC2013
分类: Python/Ruby
fork& ( /directory/script.sh) :如果shell中包含执行命令,那么子命令并不影响父级的命令,在子命令执行完后再执行父级命令。子级的环境变量不会影响到父级。
fork是最普通的, 就是直接在脚本里面用/directory/script.sh来调用script.sh这个脚本.
运行的时候开一个sub-shell执行调用的脚本,sub-shell执行的时候, parent-shell还在。
sub-shell执行完毕后返回parent-shell. sub-shell从parent-shell继承环境变量.但是sub-shell中的环境变量不会带回parent-shell
exec (exec /directory/script.sh):执行子级的命令后,不再执行父级命令。
exec与fork不同,不需要新开一个sub-shell来执行被调用的脚本.& 被调用的脚本与父脚本在同一个shell内执行。但是使用exec调用一个新脚本以后, 父脚本中exec行之后的内容就不会再执行了。这是exec和source的区别
source (source /directory/script.sh):执行子级命令后继续执行父级命令,同时子级设置的环境变量会影响到父级的环境变量。
与fork的区别是不新开一个sub-shell来执行被调用的脚本,而是在同一个shell中执行. 所以被调用的脚本中声明的变量和环境变量, 都可以在主脚本中得到和使用.
可以通过下面这两个脚本来体会三种调用方式的不同:
#!/bin/bashA=B&echo "PID for 1.sh before exec/source/fork:$$"export Aecho "1.sh: \$A is $A"case $1 in& && &&&exec)& && && && && & echo "using exec…"& && && && && &&exec ./2.;& && &&&source)& && && && && & echo "using source…"& && && && && &&. ./2.;& && &&&*)& && && && && & echo "using fork by default…"& && && && &&&& ./2.;esacecho "PID for 1.sh after exec/source/fork:$$"echo "1.sh: \$A is $A"
#!/bin/bashecho "PID for 2.sh: $$"echo "2.sh get \$A=$A from 1.sh"A=Cexport Aecho "2.sh: \$A is $A"
执行情况:
$ ./1.sh&&&&&PID for 1.sh before exec/source/fork:58453641.sh: $A is Busing fork by default…PID for 2.sh: 52429402.sh get $A=B from 1.sh2.sh: $A is CPID for 1.sh after exec/source/fork:58453641.sh: $A is B$ ./1.sh execPID for 1.sh before exec/source/fork:55626681.sh: $A is Busing exec…PID for 2.sh: 55626682.sh get $A=B from 1.sh2.sh: $A is C$ ./1.sh source&PID for 1.sh before exec/source/fork:51568941.sh: $A is Busing source…PID for 2.sh: 51568942.sh get $A=B from 1.sh2.sh: $A is CPID for 1.sh after exec/source/fork:51568941.sh: $A is C$
阅读(16002) | 评论(1) | 转发(2) |
相关热门文章
给主人留下些什么吧!~~
请登录后评论。10672人阅读
成长积累(C/C++)(47)
#include &stdlib.h&
int system(const char *string);
例:在~/myprogram/目录下有shell脚本test.sh,内容为
  #!bin/bash
  #test.sh
  echo $HOME
  在该目录下新建一个c文件systemtest.c,内容为:
  #include&stdlib.h&
  main()
  system(&~/myprogram/test.sh&);
  执行结果如下:
  xiakeyou@ubuntu:~/myprogram$ gcc systemtest.c -o systemtest
  xiakeyou@ubuntu:~/myprogram$ ./systemtest
  /home/d/e/xiakeyou
  xiakeyou@ubuntu:~/myprogram$
  2)popen(char *command,char *type)
  执行过程:popen()会调用fork()产生子进程,然后从子进程中调用/bin/sh -c来执行参数command的指令。参数type可使用“r”代表读取,“w”代表写入。依照此type值,popen()会建立管道连到子进程的标准输出设备或标准输入设备,然后返回一个文件指针。随后进程便可利用此文件指针来读取子进程的输出设备或是写入到子进程的标准输入设备中。此外,所有使用文件指针(FILE*)操作的函数也都可以使用,除了fclose()以外。
  返回值:若成功则返回文件指针,否则返回NULL,错误原因存于errno中。
  注意:在编写具SUID/SGID权限的程序时请尽量避免使用popen(),popen()会继承环境变量,通过环境变量可能会造成系统安全的问题。
  例:C程序popentest.c内容如下:
  #include&stdio.h&
  main()
  FILE *
  charbuffer[80];
  fp=popen(“~/myprogram/test.sh”,”r”);
  fgets(buffer,sizeof(buffer),fp);
  printf(“%s”,buffer);
  pclose(fp);
  执行结果如下:
  xiakeyou@ubuntu:~/myprogram$ vim popentest.c
  xiakeyou@ubuntu:~/myprogram$ gcc popentest.c -o popentest
  xiakeyou@ubuntu:~/myprogram$ ./popentest
  /home/d/e/xiakeyou
  xiakeyou@ubuntu:~/myprogram$
  只是偶能力可能有点有限,没有太看懂。直接用system()倒是脚本可是执行,只是返回值却是一塌糊涂,试了多次也没有找到什么规律。不免又看了一下上面的那篇博文,得到一些启发,可以这样来实现:
  先将脚本的返回值利用 echo & XXXXX 输出到一个本地文件中
  当需要这个返回值是,可是通过C语言的文件操作函数来直接从文件中读取
  后来一想,这应该就是上文中POPEN的实现方法!
C程序调用shell脚本共有三种法子 :system()、popen()、exec系列函数 system() 不用你自己去产生进程,它已经封装了,直接加入自己的命令exec 需要你自己 fork 进程,然后exec 自己的命令
popen() 也可以实现执行你的命令,比system 开销小
1)system(shell命令或shell脚本路径);
system()会调用fork()产生 子历程,由子历程来调用/bin/sh-c string来履行 参数string字符串所代表的命令,此命令履行 完后随即返回原调用的历程。在调用system()期间SIGCHLD 信号会被暂时搁置,SIGINT和SIGQUIT 信号则会被漠视 。
返回值:如果system()在调用/bin/sh时失败则返回127,其他失败原因返回-1。若参数string为空指针(NULL),则返回非零值。 如果 system()调用成功 则最后会返回履行 shell命令后的返回值,但是此返回值也有可能为system()调用/bin/sh失败所返回的127,因 此最好能再反省 errno 来确认履行 成功 。
system命令以其简略 高效的作用得到很很广泛 的利用 ,下面是一个例子
例:在~/test/目录下有shell脚本test.sh,内容为
#!bin/bash
echo hello
在同层目录下新建一个c文件system_test.c,内容为:
#include&stdlib.h&
int main()
system(&~/test/test.sh&);
履行 效果 如下:
[root@localhost test]$gcc system_test.c -o system_test
[root@localhost test]$./system_test
[root@localhost test]$
2)popen(char *command,char *type)
popen()会调用fork()产生 子历程,然后从子历程中调用/bin/sh -c来履行 参数command的指令。参数type可应用 “r”代表读取,“w”代表写入。遵循此type值,popen()会建立 管道连到子历程的标准 输出设备 或标准 输入设备 ,然后返回一个文件指针。随后历程便可利用 此文件指针来读取子历程的输出设备 或是写入到子历程的标准 输入设备 中。此外,所有应用 文 件指针(FILE*)操作的函数也都可以应用 ,除了fclose()以外。
返回值:若成功 则返回文件指针,否则返回NULL,差错 原因存于errno中。注意:在编写具SUID/SGID权限的程序时请尽量避免应用 popen(),popen()会继承环境变量,通过环境变量可能会造成系统安全的问题。
例:C程序popentest.c内容如下:
#include&stdio.h&
charbuffer[80];
fp=popen(“~/myprogram/test.sh”,”r”);
fgets(buffer,sizeof(buffer),fp);
printf(“%s”,buffer);
pclose(fp);
履行 效果 如下:
[root@localhost test]$ vim popentest.c
[root@localhost test]$ gcc popentest.c -o popentest
[root@localhost test]$ ./popentest
参考知识库
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:602864次
积分:6944
积分:6944
排名:第2245名
原创:101篇
转载:158篇
评论:59条
(1)(1)(4)(1)(3)(3)(2)(3)(3)(9)(7)(10)(15)(5)(2)(2)(1)(21)(11)(3)(7)(13)(11)(8)(4)(12)(19)(11)(22)(1)(2)(3)(20)(7)(13)Linux(Ylmf OS4.0)软件安装问题_百度知道}

我要回帖

更多关于 ylmf os 3.0 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信