Difference between revisions of "Python"
From Tech
Jump to navigationJump to search (Created page with " <nowiki> import ctypes import os import sys IPC_CREAT=00001000 # man shm_overview # for f in `find /lib/lib* -type f `; do nm -D $f|grep sem_open && echo found in library: $f…") |
|||
(4 intermediate revisions by one other user not shown) | |||
Line 1: | Line 1: | ||
+ | * [[multiprocess.Lock replacement using SYSV]] |
||
− | <nowiki> |
||
+ | * [[Converting Gregorian dates to day numbers]] |
||
− | import ctypes |
||
− | import os |
||
− | import sys |
||
− | |||
− | IPC_CREAT=00001000 |
||
− | # man shm_overview |
||
− | # for f in `find /lib/lib* -type f `; do nm -D $f|grep sem_open && echo found in library: $f; done |
||
− | locksUsed=0 |
||
− | class Lock: |
||
− | def __init__(self): |
||
− | #http://www.dailyfreecode.com/code/create-shared-memory-print-id-shared-2183.aspx |
||
− | global locksUsed |
||
− | self.fname="/tmp/Py-Lock%4i"%locksUsed |
||
− | |||
− | self.libc = ctypes.cdll.LoadLibrary("/lib/libc.so.6") |
||
− | self.librt = ctypes.cdll.LoadLibrary("/lib/librt.so.1") |
||
− | |||
− | f=open(self.fname,"w") |
||
− | f.write("0") |
||
− | f.close() |
||
− | self.key=self.libc.ftok(fname, 0x55) |
||
− | print "ftok returned:", self.key |
||
− | r=self.libc.semget(self.key, 1, IPC_CREAT|0666) |
||
− | print "semget returned: ",r |
||
− | |||
− | si=self.librt.sem_init(self.mem, 1, 1) |
||
− | print "sem_init returned:", si |
||
− | locksUsed+=1 |
||
− | |||
− | def acquire(self): |
||
− | self.librt.sem_wait(self.sm) |
||
− | |||
− | def release(self): |
||
− | self.librt.sem_post(self.sm) |
||
− | |||
− | #class Lock_POSIX: |
||
− | # def __init__(self): |
||
− | # global locksUsed |
||
− | # self.librt = ctypes.cdll.LoadLibrary("/lib/libpthread.so.0") |
||
− | # |
||
− | # try: |
||
− | # self.librt.sem_unlink("/PyLock%4i"%locksUsed) |
||
− | # except: |
||
− | # pass |
||
− | # self.sm=self.librt.sem_open("/PyLock%4i"%locksUsed, os.O_RDWR|os.O_CREAT, 0x1ff, 1) |
||
− | # if sm==0: |
||
− | # print "sem_open returned:", self.sm |
||
− | # sys.exit() |
||
− | # #si=self.librt.sem_init(self.sm, 1, 1) |
||
− | # print "sem_init returned:", si |
||
− | # if self.sm>=0: |
||
− | # locksUsed+=1 |
||
− | # |
||
− | # def acquire(self): |
||
− | # self.librt.sem_wait(self.sm) |
||
− | # |
||
− | # def release(self): |
||
− | # self.librt.sem_post(self.sm) |
||
− | |||
− | if __name__== "__main__": |
||
− | import time |
||
− | import random |
||
− | from multiprocessing import Process |
||
− | l=Lock() |
||
− | def fight(i): |
||
− | for j in range(10): |
||
− | l.acquire() |
||
− | for k in range(10): |
||
− | print i |
||
− | time.sleep(random.random()/30.) |
||
− | print |
||
− | l.release() |
||
− | |||
− | Process(target=fight, args=(1,)).start() |
||
− | Process(target=fight, args=(2,)).start() |
||
− | Process(target=fight, args=(3,)).start() |
||
− | Process(target=fight, args=(4,)).start() |
||
− | |||
− | </nowiki> |