真是下头!!!linux之父子进程实现交替报数

任务:
       利用fork实现父子进程交替报数 
思路:
返回值小于0,错误
返回值等于0,相当于运行子进程 
返回值大于0,相当于运行父进程
父子进程里面的代码互不影响 

#include <stdlib.h> 
#include <sys/types.h>
#include <unistd.h>
#include <stdio.h>

int main(int argc, char *argv[])
{
	int ret;
	//调用fork函数
	ret = fork();//子进程 
	
	//先进入父进程完成对应的功能
	if(ret > 0)
	{
		while(1)
		{
			static int i = 1;
			printf("i = %d\r\n",i);
			i += 2;
			sleep(2);
		}	
	 } 
	else if(ret == 0)
	{
		//后子进程完成的函数 
		while(1)
		{
			static int i = 2;
			sleep(1);
			printf("i = %d\r\n",i);
			i += 2;
			sleep(1);
		}	
	}
	 return 0; 
}

养家糊口的小广告:

1.好好敲代码,来年当个小码农

2.《富豪赚钱秘籍》仅剩10份。如果想要购买,请先关注,然后私信博主。

3.《如何找女朋友》剩余32份。如果想要购买,请先关注,然后私信博主。

4.《MACD战法总结》剩余61份。如果想要购买,请先关注,然后私信博主。

  • 17
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Linux中,可以使用信号量子进程实现三个进程相互报数的功能。以下是一个基本的示例代码: ```c #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <sys/types.h> #include <sys/wait.h> #include <sys/sem.h> #define SEM_KEY 1234 union semun { int val; struct semid_ds *buf; unsigned short *array; }; void P(int sem_id) { struct sembuf buf; buf.sem_num = 0; buf.sem_op = -1; buf.sem_flg = SEM_UNDO; semop(sem_id, &buf, 1); } void V(int sem_id) { struct sembuf buf; buf.sem_num = 0; buf.sem_op = 1; buf.sem_flg = SEM_UNDO; semop(sem_id, &buf, 1); } int main() { int sem_id = semget(SEM_KEY, 1, IPC_CREAT | 0666); if (sem_id == -1) { perror("semget"); exit(1); } union semun arg; arg.val = 1; if (semctl(sem_id, 0, SETVAL, arg) == -1) { perror("semctl"); exit(1); } pid_t pid1, pid2; int count = 0; pid1 = fork(); if (pid1 == -1) { perror("fork"); exit(1); } else if (pid1 == 0) { // 子进程1 while (count < 10) { P(sem_id); printf("Child process 1: %d\n", ++count); V(sem_id); } exit(0); } pid2 = fork(); if (pid2 == -1) { perror("fork"); exit(1); } else if (pid2 == 0) { // 子进程2 while (count < 10) { P(sem_id); printf("Child process 2: %d\n", ++count); V(sem_id); } exit(0); } // 等待子进程执行完毕 waitpid(pid1, NULL, 0); waitpid(pid2, NULL, 0); // 删除信号量 if (semctl(sem_id, 0, IPC_RMID) == -1) { perror("semctl"); exit(1); } return 0; } ``` 上述代码中,使用了信号量实现进程间的互斥,保证每次只有一个进程能够执行打印操作。进程通过fork创建了两个子进程,每个子进程都会循环执行打印操作,并且在打印之前使用P操作锁定信号量,在打印之后使用V操作释放信号量。最后,进程通过waitpid等待子进程执行完毕,并且在程序结束前删除信号量。 运行以上代码,你将看到三个进程相互报数的输出。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值