पाइथन में कंसीडर
समरूपता को अक्सर समानता के रूप में गलत समझा जाता है। कंसीमेन्ट का तात्पर्य शेड्यूलिंग इंडिपेंडेंट कोड को व्यवस्थित तरीके से निष्पादित करना है। यह अध्याय पायथन का उपयोग कर एक ऑपरेटिंग सिस्टम के लिए संगामिति के निष्पादन पर केंद्रित है।
निम्नलिखित कार्यक्रम एक ऑपरेटिंग सिस्टम के लिए संगामिति के निष्पादन में मदद करता है -
import os
import time
import threading
import multiprocessing
NUM_WORKERS = 4
def only_sleep():
print("PID: %s, Process Name: %s, Thread Name: %s" % (
os.getpid(),
multiprocessing.current_process().name,
threading.current_thread().name)
)
time.sleep(1)
def crunch_numbers():
print("PID: %s, Process Name: %s, Thread Name: %s" % (
os.getpid(),
multiprocessing.current_process().name,
threading.current_thread().name)
)
x = 0
while x < 10000000:
x += 1
for _ in range(NUM_WORKERS):
only_sleep()
end_time = time.time()
print("Serial time=", end_time - start_time)
# Run tasks using threads
start_time = time.time()
threads = [threading.Thread(target=only_sleep) for _ in range(NUM_WORKERS)]
[thread.start() for thread in threads]
[thread.join() for thread in threads]
end_time = time.time()
print("Threads time=", end_time - start_time)
# Run tasks using processes
start_time = time.time()
processes = [multiprocessing.Process(target=only_sleep()) for _ in range(NUM_WORKERS)]
[process.start() for process in processes]
[process.join() for process in processes]
end_time = time.time()
print("Parallel time=", end_time - start_time)
उत्पादन
उपरोक्त कार्यक्रम निम्नलिखित आउटपुट उत्पन्न करता है -
व्याख्या
"मल्टीप्रोसेसिंग" थ्रेडिंग मॉड्यूल के समान एक पैकेज है। यह पैकेज लोकल और रिमोट कंसेप्ट का समर्थन करता है। इस मॉड्यूल के कारण, प्रोग्रामर को दिए गए सिस्टम पर कई प्रक्रियाओं का उपयोग करने का लाभ मिलता है।