Ajout Exo4 TP5
This commit is contained in:
parent
eb6adbb2b5
commit
5276b50139
33
README.md
33
README.md
@ -459,3 +459,36 @@ ls -i -l /tmp >> log
|
||||
```shell
|
||||
ls . | wc -l
|
||||
```
|
||||
|
||||
## Exercice 2
|
||||
|
||||
## Exercice 3
|
||||
|
||||
## Exercice 4
|
||||
|
||||
> Le but est de mettre en oeuvre le cribble d'Ératosthène à l'aide d'une chaîne de processus reliés entre eux par des pipes.
|
||||
- un premier processus `P` crée un fils avec qui il est relié par un tube, et qui génére l'ensemble des nombres entre 2 et `N` (passé à la ligne de commande.)
|
||||
- Lorsqu'un nombre n'a pas été cribblé par les différents filtres, et arrive jusqu'à `P`, il est premier, et `P` crée un nouveau filtre.
|
||||
|
||||
```
|
||||
┌────────┐
|
||||
│ P │
|
||||
└────────┘
|
||||
|
||||
┌────────┐ ────── ┌────────┐
|
||||
│seq 2 N ├───►() ()───►│ P │
|
||||
└────────┘ ────── └────────┘
|
||||
|
||||
┌────────┐ ────── ┌────────┐ ────── ┌────────┐
|
||||
│seq 2 N ├───►() ()───►│ F2 ├───►() ()───►│ P │
|
||||
└────────┘ ────── └────────┘ ────── └────────┘
|
||||
|
||||
┌────────┐ ────── ┌────────┐ ────── ┌────────┐ ────── ┌────────┐
|
||||
│seq 2 N ├───►() ()───►│ F2 ├───►() ()───►│ F3 ├───►() ()───►│ P │
|
||||
└────────┘ ────── └────────┘ ────── └────────┘ ────── └────────┘
|
||||
|
||||
┌────────┐ ────── ┌────────┐ ────── ┌────────┐ ────── ┌────────┐ ────── ┌────────┐
|
||||
│seq 2 N ├───►() ()───►│ F2 ├───►() ()───►│ F3 ├───►() ()───►│ F5 ├───►() ()───►│ P │
|
||||
└────────┘ ────── └────────┘ ────── └────────┘ ────── └────────┘ ────── └────────┘
|
||||
```
|
||||
> Écrire un programme correspondant à ce schéma.
|
91
TP5/Exo4/exo4.c
Normal file
91
TP5/Exo4/exo4.c
Normal file
@ -0,0 +1,91 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <unistd.h>
|
||||
#include <signal.h>
|
||||
#include <assert.h>
|
||||
|
||||
void filter(int p)
|
||||
{
|
||||
while (1)
|
||||
{
|
||||
int n;
|
||||
ssize_t nb_read = read(0, &n, sizeof(int));
|
||||
|
||||
if (nb_read <= 0)
|
||||
break;
|
||||
|
||||
if ((n % p) != 0)
|
||||
write(1, &n, sizeof(int));
|
||||
}
|
||||
}
|
||||
|
||||
void seq(int n)
|
||||
{
|
||||
for (int i = 2; i <= n; i++)
|
||||
write(1, &i, sizeof(int));
|
||||
}
|
||||
|
||||
void chef(void)
|
||||
{
|
||||
while (1)
|
||||
{
|
||||
int p;
|
||||
pid_t f;
|
||||
int t[2];
|
||||
ssize_t nb_read = read(0, &p, sizeof(int));
|
||||
|
||||
if (nb_read <= 0)
|
||||
break;
|
||||
|
||||
printf("new prime %d\n", p);
|
||||
pipe(t);
|
||||
f = fork();
|
||||
|
||||
if (f == 0)
|
||||
{
|
||||
close(t[0]);
|
||||
dup2(t[1], 1);
|
||||
close(t[1]);
|
||||
filter(p);
|
||||
exit(0);
|
||||
}
|
||||
|
||||
close(t[1]);
|
||||
dup2(t[0], 0);
|
||||
close(t[0]);
|
||||
}
|
||||
}
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
if (argc < 2)
|
||||
{
|
||||
printf("Usage: %s <N>\n", argv[0]);
|
||||
return EXIT_FAILURE;
|
||||
}
|
||||
|
||||
struct sigaction sa = {0};
|
||||
sigemptyset(&sa.sa_mask);
|
||||
sa.sa_flags = SA_NOCLDWAIT;
|
||||
sigaction(SIGCHLD, &sa, NULL);
|
||||
|
||||
int t[2];
|
||||
int N = strtol(argv[1], NULL, 0);
|
||||
pipe(t);
|
||||
pid_t p = fork();
|
||||
assert(p != -1);
|
||||
|
||||
if (p == 0)
|
||||
{
|
||||
close(t[0]);
|
||||
dup2(t[1], 1);
|
||||
close(t[1]);
|
||||
seq(N);
|
||||
exit(0);
|
||||
}
|
||||
|
||||
close(t[1]);
|
||||
dup2(t[0], 0);
|
||||
close(t[0]);
|
||||
chef();
|
||||
return 0;
|
||||
}
|
Loading…
Reference in New Issue
Block a user