Python
From Tech
Revision as of 17:43, 8 February 2013 by 77.72.146.250 (talk)
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()
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/sem.h>
#include <stdlib.h>
#include <stdio.h>
int acquire(int semid){
struct sembuf sops[2];
sops[0].sem_num = 0;
sops[0].sem_op = -1;
sops[0].sem_flg = SEM_UNDO;
if (semop(semid, sops, 1) == -1) {
perror("acquire");
exit(1);
}
}
int release(int semid){
struct sembuf sops[2];
sops[0].sem_num = 0; /* Operate on semaphore 0 */
sops[0].sem_op = 1; /* Wait for value to equal 0 */
sops[0].sem_flg = SEM_UNDO;
if (semop(semid, sops, 1) == -1) {
perror("release");
exit(1);
}
}
void p(int semid, int i){
int j;
acquire(semid);
for(j=0; j<10; j++){
printf("%i\n",i);
sleep(1);
}
release(semid);
}
int main(int argc, char **argv){
key_t key;
int semid;
int wait_status;
key=ftok("l-.l", 0x55);
printf("key=%i\n",key);
semid=semget(key, 1, IPC_CREAT|0666);
printf("semid=%i\n",semid);
release(semid);
printf("after first release");
printf("semid=%i\n", semid);
if(fork()){
p(semid, 1);
wait(&wait_status);
} else {
p(semid, 2);
}
}