6f95124bcd
Don't be deceived by its size: this commit is mostly a bunch of sed replacements to move thread state out of "vm" and introduce a thread-local "KrkThreadState" object to hold stack pointers and call frames for individual threads. Threading support is incomplete and there's almost definitely a bunch of really easy ways to break everything just by allocating objects, but really simple stuff like carefully modifying a a list of ints should work okay. The README has been rewritten to remove code samples, which have moved to the Wiki (as has the section on integrating with C). Some other stuff has also moved around because the threading changes necessitated a major API break anyway, so I also took the time to fix some ABI issues.
49 lines
1.2 KiB
Plaintext
49 lines
1.2 KiB
Plaintext
import os
|
|
if 'KUROKO_TEST_ENV' in os.environ:
|
|
return 0
|
|
|
|
let Thread
|
|
try:
|
|
from threading import Thread as _Thread
|
|
Thread = _Thread
|
|
except:
|
|
print("Threading is not available.")
|
|
return 0
|
|
|
|
class Summer(Thread):
|
|
def __init__(self, lst, min, max):
|
|
self.lst = lst
|
|
self.min = min
|
|
self.max = max
|
|
self.result = None
|
|
def run(self):
|
|
self.result = 0
|
|
for i = self.min; i < self.max; i++:
|
|
self.result += self.lst[i]
|
|
|
|
if __name__ == '__main__':
|
|
import kuroko
|
|
let numThreads = 10
|
|
if len(kuroko.argv) > 1:
|
|
numThreads = int(kuroko.argv[1])
|
|
print("Starting {} threads.".format(numThreads))
|
|
let threads = []
|
|
let totalCount = 5000000
|
|
let chunkSize = totalCount / numThreads
|
|
let numbers = list(range(totalCount))
|
|
let cnt = 0
|
|
if totalCount > chunkSize * numThreads:
|
|
chunkSize += 1
|
|
for i in range(numThreads):
|
|
let newThread = Summer(numbers, cnt, (cnt + chunkSize) if (cnt + chunkSize < totalCount) else totalCount)
|
|
threads.append(newThread)
|
|
newThread.start()
|
|
cnt += chunkSize
|
|
|
|
let total = 0
|
|
for thread in threads:
|
|
thread.join()
|
|
total += thread.result
|
|
|
|
print("Got",total)
|