输入C程序 main() { char a printf("please enter a char:")scanf("%s",&a) printf("%s",a)}
输入命令gcc -o char char.c 进行编译连接 生成一个char.c文件
输入./char 执行此文件
在键盘上输入一个字符 回车 即可看到刚刚输入的字符
2)设计、编辑、编译、连接以及运行一个C程序,从键盘输入一个字符串然后向屏幕输出这个字符串
设计、编辑C程序
#!/bin/sh
Read char a
$A=a
Echo $A
编译、连接gcc -o a a.c
执行 ./a
任意从键盘上输入amsn
结果屏幕输出:amsn
将上面SHELL程序后台运行。观察原C程序运行时输入输出情况
进入首局后台运行命令
#!/bin/sh
a.c &
/*author:Samsonsdate:2015.4.10*/
#include <stdio.h>
#include <signal.h>
#include <unistd.h>
#include <string.h>
#include <stdlib.h>
#include <fcntl.h>
#include <sys/wait.h>
#define MAX(100)
#define LEN(100)
char *arglist[MAX] //shell指令参数表
int num //shell指令参数个数
int execute(char* arglist[])//执行外部命令
{
int error
error=execvp(arglist[0],arglist)
if (error==-1) printf("failed\n")
exit(1)
}
char* make(char *buf)//将字符串传入参数表内
{
char *cp
cp=malloc(strlen(buf)+1)
if (cp==NULL)
{
fprintf(stderr,"no memory\n")
exit(1)
}
strcpy(cp,buf)
return cp
}
int my_system(char *buf,char *arglist[])//对于字符串进行分割
{
int num,j,i,last
char buffer[LEN]
num=0
i=0
while (num<MAX)
{
if (buf[i]=='\n')
{
arglist[num]=NULL
return num
}
if (buf[i]==' ') i++
last=i
while (buf[i]!=' ' && buf[i]!='\n') i++
for (j=lastj<ij++) buffer[j-last]=buf[j]
buffer[j-last]='\0'
arglist[num++]=make(buffer)
}
}
int inner(char *arglist[])//执行内置指令
{
if (strcmp(arglist[0],"exit\0")==0)//exit
{
exit(0)
return 1
}
else
if (strcmp(arglist[0],"pwd\0")==0)//pwd
{
char buf[LEN]
getcwd(buf,sizeof(buf))//获得当前目录
printf("Current dir is:%s\n",buf)
return 1
}
else
if (strcmp(arglist[0],"cd\0")==0)//cd
{
char buf[LEN]
if (chdir(arglist[1])>=0)
{
getcwd(buf,sizeof(buf))
printf("Current dir is:%s\n",buf)
}
return 1
}
else return 0
}
void cat_in(char *q)//输入重定向
{
char t[30]
int fd
if (q[0]=='<')
{
strcpy(t,q+1)
fd=open(t,O_RDONLY)
arglist[1]=NULL
if (fd==-1)
{
printf("file open failed\n")
return
塌锋 }
dup(fd,0)
close(fd)
}
}
void cat_out(char *q)//输出重定向
{
char t[30]
int fd
if (q[0]=='>')
{
团码晌 strcpy(t,q+1)
arglist[num-1]=NULL
num--
fd=open(t,O_CREAT|O_RDWR)
if (fd==-1)
{
printf("file open failed\n")
return
}
dup2(fd,1)
close(fd)
}
}
int main()
{
int i,pid
char buf[LEN]
while (1)
{
fgets(buf,LEN,stdin)//读入单行指令
num=my_system(buf,arglist)//指令分割
int inner_flag
inner_flag=inner(arglist)//内置指令判断
if (inner_flag==0)
{
pid=fork()//建立新的进程
if (pid==0)
{
if (arglist[1]!=NULL)
{
char q[LEN]
strcpy(q,arglist[1])
cat_in(q)//输入重定向
}
if (arglist[num-1]!=NULL)
{
char q[LEN]
模空 strcpy(q,arglist[num-1])
cat_out(q)//输出重定向
}
execute(arglist)//执行
}
waitpid(pid,NULL,0)
}
}
return 0
}
在c语言中调�.shellå½ä»¤çæ¹æ³å®ç°ãcç¨åºè°ç¨shellèæ¬å ±æ两ç§æ¹æ³
ï¼system()ãpopen()ï¼åå«å¦ä¸ï¼
system()
ä¸ç¨èªå·±å»å建è¿ç¨ï¼ç³»ç»å·²ç»å°è£ äºè¿ä¸æ¥ï¼ç´æ¥å å ¥èªå·±çå½ä»¤å³å¯
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å½ä»¤ä»¥å ¶ç®ç¥
é«æçä½ç¨å¾å°å¾å¾å¹¿æ³
çå©ç¨
ï¼ä¸é¢æ¯ä¸ä¸ªä¾å
ä¾ï¼å¨/tmp/testdir/ç®å½ä¸æshellèæ¬tsh.shï¼å 容为
#!/bin/sh
wget
$1
echo
"done!"
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
main
{
file
*
fp
charbuffer[80]
fp=popen(â~/myprogram/test.shâ,ârâ)
fgets(buffer,sizeof(buffer),fp)
printf(â%sâ,buffer)
pclose(fp)
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)