সেমাফোর বনাম মুটেক্স

লেখক: Laura McKinney
সৃষ্টির তারিখ: 4 এপ্রিল 2021
আপডেটের তারিখ: 10 মে 2024
Anonim
Semaphore এবং Mutex মধ্যে পার্থক্য কি?
ভিডিও: Semaphore এবং Mutex মধ্যে পার্থক্য কি?

কন্টেন্ট

সেমফোর এবং মিটেক্সের মধ্যে পার্থক্য হ'ল সেমফোর একটি সিগন্যালিং মেকানিজম এবং মূটেক্স লকিং প্রক্রিয়া।


অপারেটিং সিস্টেমটি কম্পিউটার বিজ্ঞানের সর্বাধিক গুরুত্বপূর্ণ ধারণা, অপারেটিং সিস্টেমে দুটি প্রধান ধারণা হ'ল সেমফোর এবং মিউটেক্স। একটি semaphore এবং mutex মধ্যে অনেক পার্থক্য আছে। যদি আমরা মূল পার্থক্য সম্পর্কে কথা বলি, তবে সেমফোর এবং মিটেক্সের মধ্যে প্রধান পার্থক্যটি হ'ল সেম্যাফোর একটি সংকেত প্রক্রিয়া যেখানে মূটেক্স লকিং প্রক্রিয়া।

প্রক্রিয়াগুলিতে semaphore এবং mutex মধ্যে পার্থক্য আসে; সেম্যাফোর ওয়েট () এবং সিগন্যাল () অপারেশন করে, এই ফাংশনটি তারা অর্জন করেছে বা তারা উত্সটি প্রকাশ করেছে কিনা তা জানার জন্য দায়বদ্ধ। অন্যদিকে, আমরা যদি মিটেক্সের কথা বলি তবে মিউটেক্স হ'ল লকিং মেকানিজম।

সেমফোর একটি পূর্ণসংখ্যার ভেরিয়েবল এস; semaphore একটি সংকেত প্রক্রিয়া। একটি অপারেটিং সিস্টেমে একটি সিঙ্ক্রোনাইজেশন সরঞ্জামের প্রয়োজন হয় এবং অপারেটিং সিস্টেমের সেই সরঞ্জামটি একটি সেমফোর হিসাবে পরিচিত। সেম্যাফোরের দুটি প্রধান ফাংশন রয়েছে যা (), সংকেত () অপেক্ষা করছে। () এবং সিগন্যাল () অপেক্ষা করা দুটি ফাংশন সহ সেমফোরের মান পরিবর্তন করা হয়েছে। যখন কোনও প্রক্রিয়া কোনও সংস্থান ব্যবহার করে, সেমফোরটি অপেক্ষা করে (), এবং যখন প্রক্রিয়াটি রিসোর্সটি ব্যবহার করে, এবং সেই সংস্থানটি মুক্ত হয়, তখন সেমফোর সংকেত দেয় ()। এই ফাংশনগুলি যা অপেক্ষা () এবং সিগন্যাল (), সেগুলি ব্যবহৃত হয় কারণ কেবলমাত্র একটি প্রক্রিয়া একবারে সংস্থান ব্যবহার করতে পারে। একটি সংস্থান দুটি প্রক্রিয়া দেওয়া যাবে না। অপারেটিং সিস্টেমে দুটি ধরণের সেমফোর রয়েছে যা বাইনারি সেম্যাফোর এবং গণ্য সেমফোর। সেমফোর গণনায়, প্রারম্ভিক মানটি উপলব্ধ সংখ্যার সংস্থান। যখন কোনও প্রক্রিয়া কোনও সংস্থান ব্যবহার করে, তখন এটি অপেক্ষা করতে হয় () এবং সেই সংস্থানটির জন্য অপেক্ষা করতে হয়। একের পর এক সেমফোর মান গণনা করা হয়। যখন কোনও প্রক্রিয়া কোনও সংস্থান ব্যবহার করে, তখন সেই সংস্থানটি প্রকাশ করে এবং সিগন্যালটি প্রকাশ করে) যাতে এটি অন্য প্রক্রিয়ার জন্য অবশ্যই মুক্ত হয়। যখন সংস্থানগুলির গণনা 0 হয়, তার অর্থ হ'ল আগত প্রক্রিয়ার জন্য কোনও সংস্থান উপলব্ধ নেই। বাইনারি সেম্যাফোরে দুটি মান রয়েছে যা 0 এবং 1 হয়। প্রক্রিয়াটি যখন বাইনারি সেমফোরের একটি রিসোর্স মান ব্যবহার করে 1 থেকে 0 হয় এবং যখন কোনও উত্স রিসোর্স ব্যবহার করে তখন বাইনারি সেম্যাফোরের মান 1 থেকে 0 হয়।


মিউটেক্স পারস্পরিক বর্জনকারী বস্তু হিসাবেও পরিচিত। আমরা জানি যে কেবলমাত্র একটি প্রক্রিয়া একবারে একটি সংস্থান ব্যবহার করতে পারে। এই কারণেই লক করার ব্যবস্থা রয়েছে এবং লকটির সেই সিস্টেমটি মিউটেক্স হিসাবে পরিচিত। যখন প্রক্রিয়াটি কোনও সংস্থান ব্যবহার করে তখন কোনও প্রক্রিয়াতে মুটেক্স লক দেওয়া হয়। মুটেক্স অবজেক্টটির একটি স্বতন্ত্র নাম এবং আইডি রয়েছে। একটি প্রোগ্রামে যখনই মুটেেক্স লকের প্রয়োজন হয়, তার নাম এবং আইডি দিয়ে মুটেক্স লক কল করা হয়। আমরা যদি মিটেক্সের কোডটি দেখতে পাই তবে আমাদের কাছে মিউটেক্স লক প্রয়োগ এবং ব্যবহারের স্পষ্ট ধারণা থাকবে।

বিষয়বস্তু: সেমাফোর এবং মিটেক্সের মধ্যে পার্থক্য

  • তুলনা রেখাচিত্র
  • সেমফোর্
  • mutex
  • উপসংহার
  • ব্যাখ্যামূলক ভিডিও

তুলনা রেখাচিত্র

ভিত্তিসেমফোর্mutex
অর্থSemaphore একটি সংকেত প্রক্রিয়ামিউটেক্স একটি লকিং মেকানিজম।
মানসেমফোর একটি পূর্ণসংখ্যা।একটি মিউটেক্স একটি বস্তু।
অপারেশনSemaphore অপারেশন () এবং সংকেত ()।মুটেক্সের অপারেশনগুলি লক এবং আনলক
প্রকারভেদদুটি ধরণের সেমফোর হ'ল সেম্যাফোর এবং বাইনারি সেম্যাফোর গণনা করা।কোনও ধরণের মিটেক্স লক নেই।

সেমফোর্

সেমফোর একটি পূর্ণসংখ্যার ভেরিয়েবল এস; semaphore একটি সংকেত প্রক্রিয়া। একটি অপারেটিং সিস্টেমে একটি সিঙ্ক্রোনাইজেশন সরঞ্জামের প্রয়োজন হয় এবং অপারেটিং সিস্টেমের সেই সরঞ্জামটি একটি সেমফোর হিসাবে পরিচিত। সেম্যাফোরের দুটি প্রধান ফাংশন রয়েছে যা (), সংকেত () অপেক্ষা করছে। () এবং সিগন্যাল () অপেক্ষা করা দুটি ফাংশন সহ সেমফোরের মান পরিবর্তন করা হয়েছে। যখন কোনও প্রক্রিয়া কোনও সংস্থান ব্যবহার করে, সেমফোরটি অপেক্ষা করে (), এবং যখন প্রক্রিয়াটি রিসোর্সটি ব্যবহার করে, এবং সেই সংস্থানটি মুক্ত হয়, তখন সেমফোর সংকেত দেয় ()। এই ফাংশনগুলি যা একটি অপেক্ষা () এবং সিগন্যাল (), সেগুলি ব্যবহৃত হয় কারণ কেবলমাত্র একটি প্রক্রিয়া একবারে সংস্থান ব্যবহার করতে পারে।


একটি সংস্থান দুটি প্রক্রিয়া দেওয়া যাবে না। অপারেটিং সিস্টেমে দুটি ধরণের সেমফোর রয়েছে যা বাইনারি সেম্যাফোর এবং গণ্য সেমফোর। সেমফোর গণনায়, প্রারম্ভিক মানটি উপলব্ধ সংখ্যার সংস্থান। যখন কোনও প্রক্রিয়া কোনও সংস্থান ব্যবহার করে, তখন এটি অপেক্ষা করতে হয় () এবং সেই সংস্থানটির জন্য অপেক্ষা করতে হয়। একের পর এক সেমফোর মান গণনা করা হয়। যখন কোনও প্রক্রিয়া কোনও সংস্থান ব্যবহার করে, তখন সেই সংস্থানটি প্রকাশ করে এবং সিগন্যালটি প্রকাশ করে) যাতে এটি অন্য প্রক্রিয়ার জন্য অবশ্যই মুক্ত হয়। যখন সংস্থানগুলির গণনা 0 হয়, তার অর্থ হ'ল আগত প্রক্রিয়ার জন্য কোনও সংস্থান উপলব্ধ নেই। বাইনারি সেম্যাফোরে দুটি মান রয়েছে যা 0 এবং 1 হয়। প্রক্রিয়াটি যখন বাইনারি সেমফোরের একটি রিসোর্স মান ব্যবহার করে 1 থেকে 0 হয় এবং যখন কোনও উত্স রিসোর্স ব্যবহার করে তখন বাইনারি সেম্যাফোরের মান 1 থেকে 0 হয়।

mutex

মিউটেক্স পারস্পরিক বর্জনকারী বস্তু হিসাবেও পরিচিত। আমরা জানি যে কেবলমাত্র একটি প্রক্রিয়া একবারে একটি সংস্থান ব্যবহার করতে পারে। এই কারণেই লক করার ব্যবস্থা রয়েছে এবং লকটির সেই সিস্টেমটি মিউটেক্স হিসাবে পরিচিত। যখন প্রক্রিয়াটি কোনও সংস্থান ব্যবহার করে তখন কোনও প্রক্রিয়াতে মুটেক্স লক দেওয়া হয়। মুটেক্স অবজেক্টটির একটি স্বতন্ত্র নাম এবং আইডি রয়েছে। একটি প্রোগ্রামে যখনই মুটেেক্স লকের প্রয়োজন হয়, তার নাম এবং আইডি দিয়ে মুটেক্স লক কল করা হয়। আমরা যদি মিটেক্সের কোডটি দেখতে পাই তবে আমাদের কাছে মিউটেক্স লক প্রয়োগ এবং ব্যবহারের স্পষ্ট ধারণা থাকবে।

মূল পার্থক্য

  1. সেমফোর একটি সিগন্যালিং মেকানিজম যেখানে মুটেক্স লকিং
  2. Semaphore একটি পূর্ণসংখ্যা যেখানে Mutex একটি অবজেক্ট।
  3. সেমফোর ওয়েট () এবং সিগন্যাল () এর অপারেশনগুলি যেখানে মিটেক্সের অপারেশনগুলি লক এবং আনলক।
  4. দুটি ধরণের সেমফোর হ'ল সেম্যাফোর এবং বাইনারি সেম্যাফোর গণনা করছে তবে কোনও ধরণের মিউটেক্স নেই

উপসংহার

উপরের এই নিবন্ধে আমরা তাদের যথাযথ প্রয়োগের সাথে semaphore এবং mutex এর মধ্যে স্পষ্ট পার্থক্য দেখি।

ব্যাখ্যামূলক ভিডিও