Linux——进程
来源:互联网 发布:淘宝怎么录制短视频 编辑:程序博客网 时间:2024/05/16 10:20
以前在百度上写,现在换在博客上,虽然知识内容很简单,记录下来或许可以帮到别人。这是一次上机题目,内容是创建3个子进程,在3个子进程中分别实现如下功能:乘法口诀表,10的阶乘,1-20的加法。
这个是主函数:
#include<stdio.h>
#include<stdlib.h>
#include<sys/types.h>
#include<unistd.h>
int main(int argc,char *argv[])
{
pid_t pid1,pid2,pid3;
char ch;
printf("Input :");
scanf("%c",&ch);
if((ch=='a')||(ch=='b')||(ch=='c'))
{
pid1=fork();
if(pid1<0)
{
perror("error");
exit(EXIT_FAILURE);
}
else if(pid1==0)
{
if(ch=='a')
execl("./multiply","multiply",argv[1],NULL); //the last parameter(canshu) is NULL
pid2=fork();
if(pid2<0)
{
perror("error");
exit(EXIT_FAILURE);
}
else if(pid2==0)
{
if(ch=='b')
execl("./jiechen","jiechen",argv[1],(char *)0); //(char *)0 = NULL =(int *)0
pid3=fork();
if(pid3<0)
{
perror("error");
exit(EXIT_FAILURE);
}
else if(pid3==0)
{
if(ch=='c')
execl("./add","add",argv[1],(char *)0);
}
}
}
}
else if(ch=='q')
{
printf("EXIT!\n");
exit(0);
}
else
printf("error input\n");
wait(2);
return 0;
}
乘法口诀函数:
#include<stdio.h>
#include<stdlib.h>
int main()
{
int i,j;
for(i=1;i<=9;i++)
{
for(j=1;j<=i;j++)
printf("%d*%d=%d\t",j,i,i*j);
printf("\n");
}
return 0;
}
阶乘函数:
#include<stdio.h>
#include<stdlib.h>
#define N 10
int main()
{
int i,flag=1;
for(i=1;i<=N;i++)
flag*=i;
printf("%d!=%d\n",N,flag);
return 0;
}
加法函数:
#include<stdio.h>
#include<stdlib.h>
#define N 20
int main()
{
int i,sum;
for(i=1;i<=N;i++)
sum+=i;
printf("1+2+...+%d=%d\n",N,sum);
return 0;
}
写这个的目的是:在创建子进程时会复制父进程代码,在程序运行时始终因为子进程或父进程的结束使程序产生异常,因此采用类似分层的方法创建子进程,在子进程1创建后在父进程(pid1>0)的情况下创建子进程2,依次再创建子进程3. 但原理还不是很懂
execX类函数的作用是执行新代码
- Linux——进程
- Linux——进程
- Linux——进程
- Linux进程—task_struct
- Linux编程—进程
- Linux—进程控制
- Linux — 守护进程
- Linux 进程控制——进程调度
- Linux——僵尸进程&孤儿进程
- Linux进程管理—进程管理
- Linux — 孤儿进程和僵尸进程
- linux之C编程学习——进程,进程,进程!
- linux之C编程学习——进程,进程,进程!
- linux——fork(进程)
- [Linux]进程——备忘
- Linux——进程管理
- Linux——杀掉进程
- linux——进程管理
- Android中的一些小知识
- 从K近邻算法、距离度量谈到KD树、SIFT+BBF算法
- Bootstrap3学习笔记(3)--表格
- 你想对现在的你说点什么?
- 咀擅交追乇驯馗尘兄泌
- Linux——进程
- rock c语言实现的带通配符匹配算法
- 在jsp页面中响应速度提高的7种方法
- Reverse Integer
- LinuxMint(ubuntu) 杂记[exfat][user][ssh]
- 题目1078:二叉树遍历
- 我的ACM-ICPC资源整理
- JAVA JDBC 连接Mysql 更新数据 双表查询更新
- 【剑指Offer面试编程题】题目1509:树中两个结点的最低公共祖先--九度OJ