-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmytime.py
More file actions
55 lines (47 loc) · 1.47 KB
/
mytime.py
File metadata and controls
55 lines (47 loc) · 1.47 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import os, sys
from time import time
if __name__ == "__main__":
tab_temps = []
if len(sys.argv) < 2:
print("Trop peu d'arguments", file=sys.stderr)
sys.exit(1)
pos = 1
try:
sys.argv.index("-n")
pos += 2
k = int(sys.argv[2])
if k < 1:
k = 1
except ValueError:
k = 1
try:
sys.argv.index("-s")
pos += 1
s = True
except ValueError:
s = False
for i in range (k):
temps_prec = time()
p = os.fork()
if p == 0: # fils
try:
os.execvp(sys.argv[pos], sys.argv[pos:])
except FileNotFoundError:
print("Erreur lors du chargement de %s" % sys.argv[pos], file=sys.stderr)
sys.exit(1)
#suite du père
pid, status = os.wait()
if os.WIFEXITED(status): #le fils est mort
if os.WEXITSTATUS(status) == 0:#réussi
if s:
print("code sortie de la commande:", status)
else:
print("Processus %d terminé: échec (code erreur: %d)" % (p, os.WEXITSTATUS(status)))
temps = time()-temps_prec
tab_temps.append(temps)
print("durée execution:",int(temps),"s")
print(" :",int(temps*10**6),"microsecondes")
print("temps moyen = ", sum(tab_temps)/len(tab_temps), "s")
sys.exit(0)