Current Path: > > > usr > lib64 > python2.7 > Demo > threads
Operation : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64 Software : Apache Server IP : 162.0.232.56 | Your IP: 216.73.216.111 Domains : 1034 Domain(s) Permission : [ 0755 ]
Name | Type | Size | Last Modified | Actions |
---|---|---|---|---|
Coroutine.py | File | 5524 bytes | April 19 2020 21:13:39. | |
Coroutine.pyc | File | 4247 bytes | April 10 2024 04:58:47. | |
Coroutine.pyo | File | 4247 bytes | April 10 2024 04:58:47. | |
Generator.py | File | 2536 bytes | April 19 2020 21:13:39. | |
Generator.pyc | File | 3319 bytes | April 10 2024 04:58:47. | |
Generator.pyo | File | 3319 bytes | April 10 2024 04:58:47. | |
README | File | 440 bytes | April 19 2020 21:13:39. | |
fcmp.py | File | 1751 bytes | April 19 2020 21:13:39. | |
fcmp.pyc | File | 1693 bytes | April 10 2024 04:58:47. | |
fcmp.pyo | File | 1693 bytes | April 10 2024 04:58:47. | |
find.py | File | 4215 bytes | April 19 2020 21:13:39. | |
find.pyc | File | 3873 bytes | April 10 2024 04:58:47. | |
find.pyo | File | 3873 bytes | April 10 2024 04:58:47. | |
squasher.py | File | 3038 bytes | April 19 2020 21:13:39. | |
squasher.pyc | File | 2113 bytes | April 10 2024 04:58:47. | |
squasher.pyo | File | 2113 bytes | April 10 2024 04:58:47. | |
sync.py | File | 21655 bytes | April 19 2020 21:13:39. | |
sync.pyc | File | 11114 bytes | April 10 2024 04:58:47. | |
sync.pyo | File | 11114 bytes | April 10 2024 04:58:47. | |
telnet.py | File | 3077 bytes | April 19 2020 21:13:39. | |
telnet.pyc | File | 2531 bytes | April 10 2024 04:58:47. | |
telnet.pyo | File | 2531 bytes | April 10 2024 04:58:47. |
# Generator implementation using threads import sys import thread class Killed(Exception): pass class Generator: # Constructor def __init__(self, func, args): self.getlock = thread.allocate_lock() self.putlock = thread.allocate_lock() self.getlock.acquire() self.putlock.acquire() self.func = func self.args = args self.done = 0 self.killed = 0 thread.start_new_thread(self._start, ()) # Internal routine def _start(self): try: self.putlock.acquire() if not self.killed: try: apply(self.func, (self,) + self.args) except Killed: pass finally: if not self.killed: self.done = 1 self.getlock.release() # Called by producer for each value; raise Killed if no more needed def put(self, value): if self.killed: raise TypeError, 'put() called on killed generator' self.value = value self.getlock.release() # Resume consumer thread self.putlock.acquire() # Wait for next get() call if self.killed: raise Killed # Called by producer to get next value; raise EOFError if no more def get(self): if self.killed: raise TypeError, 'get() called on killed generator' self.putlock.release() # Resume producer thread self.getlock.acquire() # Wait for value to appear if self.done: raise EOFError # Say there are no more values return self.value # Called by consumer if no more values wanted def kill(self): if self.killed: raise TypeError, 'kill() called on killed generator' self.killed = 1 self.putlock.release() # Clone constructor def clone(self): return Generator(self.func, self.args) def pi(g): k, a, b, a1, b1 = 2L, 4L, 1L, 12L, 4L while 1: # Next approximation p, q, k = k*k, 2L*k+1L, k+1L a, b, a1, b1 = a1, b1, p*a+q*a1, p*b+q*b1 # Print common digits d, d1 = a//b, a1//b1 while d == d1: g.put(int(d)) a, a1 = 10L*(a%b), 10L*(a1%b1) d, d1 = a//b, a1//b1 def test(): g = Generator(pi, ()) g.kill() g = Generator(pi, ()) for i in range(10): print g.get(), print h = g.clone() g.kill() while 1: print h.get(), sys.stdout.flush() test()
SILENT KILLER Tool