Named Semaphores এবং Posix Semaphores গাইড ও নোট

Computer Science - ইন্টার প্রসেস কমিউনিকেশন (Inter Process Communication) - Advanced IPC Techniques
388

Named Semaphores এবং POSIX Semaphores হল UNIX/Linux সিস্টেমে সিঙ্ক্রোনাইজেশন এবং সমন্বয়ের জন্য ব্যবহৃত সেমাফোর প্রকার। এদের মধ্যে কিছু মৌলিক পার্থক্য এবং ব্যবহারিক উদ্দেশ্য রয়েছে। নিচে প্রতিটি সম্পর্কে বিস্তারিত আলোচনা করা হলো:

১. Named Semaphores

সংজ্ঞা:

Named Semaphores হল সেমাফোরের একটি প্রকার যা একটি নাম (identifier) ব্যবহার করে তৈরি হয়। এই নামের মাধ্যমে বিভিন্ন প্রক্রিয়া একই সেমাফোরের সাথে যোগাযোগ করতে পারে।

বৈশিষ্ট্য:

  • নামকরণ: Named Semaphores সাধারণত একটি নির্দিষ্ট নামের মাধ্যমে শনাক্ত করা হয়, যা সাধারণ সেমাফোরের উপর ভিত্তি করে। এটি একাধিক প্রক্রিয়া দ্বারা অ্যাক্সেসযোগ্য।
  • গ্লোবাল অ্যাক্সেস: Named Semaphores সিস্টেমের বিভিন্ন প্রক্রিয়ার মধ্যে শেয়ার করা যায়। এটি একই নামের মাধ্যমে যে কোনো প্রক্রিয়া সেই সেমাফোরটি অ্যাক্সেস করতে পারে।
  • সফলতার জন্য ফাইল সিস্টেম: Named Semaphores সেমাফোরের নামের ভিত্তিতে তৈরি করা হয়, যা ফাইল সিস্টেমে সংরক্ষিত হয়।

উদাহরণ:

#include <stdio.h>
#include <stdlib.h>
#include <semaphore.h>
#include <fcntl.h>
#include <sys/stat.h>
#include <unistd.h>

int main() {
    // Create a named semaphore
    sem_t *sem = sem_open("/mysem", O_CREAT, 0644, 1);
    
    // Wait (decrement the semaphore)
    sem_wait(sem);
    
    // Critical section
    printf("In critical section\n");
    
    // Post (increment the semaphore)
    sem_post(sem);
    
    // Close the semaphore
    sem_close(sem);
    
    // Unlink the semaphore
    sem_unlink("/mysem");
    
    return 0;
}

২. POSIX Semaphores

সংজ্ঞা:

POSIX Semaphores হল সেমাফোরের একটি প্রকার যা POSIX (Portable Operating System Interface) মানদণ্ড অনুযায়ী কাজ করে। এটি Named Semaphores এবং Unnamed Semaphores উভয়েরই অন্তর্ভুক্ত।

বৈশিষ্ট্য:

  • Unnamed Semaphores: এটি একটি সেমাফোর তৈরি করে যা শুধুমাত্র সেই প্রক্রিয়ার মধ্যে ব্যবহার করা হয় যা সেমাফোর তৈরি করেছে। এটি সাধারণত মেমরির মধ্যে ব্যবহৃত হয় এবং একাধিক প্রক্রিয়ার মধ্যে শেয়ার করা হয় না।
  • নির্ভরযোগ্যতা: POSIX Semaphores মেমরির সঠিক নিয়ন্ত্রণ নিশ্চিত করে, যা ডেডলক বা প্রতিযোগিতার সমস্যাগুলি প্রতিরোধ করে।
  • ফাংশনালিটি: POSIX Semaphores বিভিন্ন অপারেশন যেমন wait (P), post (V), এবং initialization এর জন্য সহজ এবং সুসংহত ফাংশন সমর্থন করে।

উদাহরণ:

#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>
#include <semaphore.h>

sem_t sem;

void* thread_func(void* arg) {
    sem_wait(&sem); // Wait (decrement the semaphore)

    // Critical section
    printf("Thread in critical section\n");

    sem_post(&sem); // Post (increment the semaphore)
    return NULL;
}

int main() {
    pthread_t threads[5];

    // Initialize unnamed semaphore
    sem_init(&sem, 0, 1);

    for (int i = 0; i < 5; i++) {
        pthread_create(&threads[i], NULL, thread_func, NULL);
    }

    for (int i = 0; i < 5; i++) {
        pthread_join(threads[i], NULL);
    }

    // Destroy the semaphore
    sem_destroy(&sem);
    return 0;
}

৩. পার্থক্য

বৈশিষ্ট্যNamed SemaphoresPOSIX Semaphores
নামনাম দিয়ে চিহ্নিত হয়দুটি প্রকার: নামকৃত এবং নামহীন
ব্যবহারএকাধিক প্রক্রিয়ার মধ্যে শেয়ার করা হয়স্থানীয় প্রক্রিয়ার মধ্যে অথবা একাধিক প্রক্রিয়ার মধ্যে ব্যবহার করা যায়
নির্ভরযোগ্যতাসিস্টেমের মধ্যে গ্লোবাল অ্যাক্সেসনির্ভরযোগ্য, তবে স্থানীয় এবং গ্লোবাল উভয়েই কাজ করতে পারে
রিসোর্স পরিচালনাফাইল সিস্টেমে সংরক্ষিতমেমরির মধ্যে পরিচালনা করা হয়
ফাংশনালিটিsem_open(), sem_wait(), sem_post()sem_init(), sem_wait(), sem_post()

উপসংহার

Named Semaphores এবং POSIX Semaphores উভয়ই প্রক্রিয়া সমন্বয়ের জন্য গুরুত্বপূর্ণ সেমাফোর প্রযুক্তি। Named Semaphores একটি নামের মাধ্যমে গ্লোবাল অ্যাক্সেস প্রদান করে, যেখানে POSIX Semaphores স্থানীয়ভাবে বা গ্লোবালভাবে ব্যবহৃত হতে পারে। উভয় পদ্ধতিই তাদের নিজস্ব ব্যবহার এবং উপকারিতা রয়েছে, এবং সঠিক পদ্ধতি নির্বাচন আপনার অ্যাপ্লিকেশনের প্রয়োজনীয়তার উপর নির্ভর করে।

Promotion

Are you sure to start over?

Loading...