Python
From Tech
Revision as of 16:12, 8 February 2013 by 77.72.146.250 (talk) (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…")
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()