The Readers Writers Problem

แชร์
ฝัง
  • เผยแพร่เมื่อ 27 ม.ค. 2025

ความคิดเห็น • 92

  • @miloradowicz
    @miloradowicz 3 ปีที่แล้ว +283

    I think the
    if (readcount == 1) wait(wrt);
    part would be best explained like this: when we are reading, no one should be allowed to write, thus the wrt semaphore should be acquired; so if we are the _first_ reader, we acquire it (and wait till it's released if someone's still writing); but if someone's already reading, it means they have already acquired wrt, so we just skip this part.
    Similarly, in the
    if (readcount == 0) signal(wrt);
    line, we check if we are the last reader, and if we are, it's our responsibility to release wrt, thus allowing others to write.

    • @chadj1797
      @chadj1797 3 ปีที่แล้ว +1

      Yep, this works too!

    • @napoleon3242
      @napoleon3242 2 ปีที่แล้ว +32

      @@chadj1797 it's not "this works too!", it's how it's supposed to work

    • @eylulmood4830
      @eylulmood4830 2 ปีที่แล้ว +4

      you're absolutly right

    • @ScopedKilz
      @ScopedKilz 2 ปีที่แล้ว +7

      You are the GOAT

    • @surajr4757
      @surajr4757 2 ปีที่แล้ว +3

      Thank you so much, my doubt cleared from your comment, are you from Russia?

  • @shaneyaw4542
    @shaneyaw4542 3 ปีที่แล้ว +40

    This was a good explanation of something that is not explained well in the textbooks. Good job.

  • @elconnero
    @elconnero 10 หลายเดือนก่อน +5

    Dude you are amazing, I am learning more in one video than a full lecture my professor gives.

  • @aniketdas3406
    @aniketdas3406 ปีที่แล้ว +24

    If someone like me who's struggling to understand how multiple processes can read without allowing any other process to write, it can be explained in this way:
    When the first reader process enters it decrements the wrt and makes it 0 so that no writer process can execute untill the last reader has done its job and signals wrt.
    Therefore, after the first reader process, other readers which will try to read concurrently will skip the if(readcount ==1) part since wrt is already decremented by the first read process and write() operations are halted.
    I hope it helped you :)

    • @AnotherMe-w1i
      @AnotherMe-w1i 27 วันที่ผ่านมา

      thank you so much

  • @-shultz
    @-shultz ปีที่แล้ว +8

    12:18 readcnt >= 1 cuz if it is updated to more than 1 writer process can start updating .

    • @filterandframes
      @filterandframes หลายเดือนก่อน

      I think they’ve used binary mutex.

  • @shahinsheikh6964
    @shahinsheikh6964 2 ปีที่แล้ว +5

    I am studying in the morning and today is my exam belive me i wasnt able to understand and was very tensed and frustrated bcoz of this topic but when i visited this channel i felt its soo easy.. thanku so much ❤️

  • @SumeraBanu-p7r
    @SumeraBanu-p7r ปีที่แล้ว +3

    Thanks a lot... It was soo confusing before and this was soo helpful❤

  • @pranavbakare8922
    @pranavbakare8922 3 ปีที่แล้ว +4

    This is one of the Best explanations!!!!!

  • @jajnyaseniswain8472
    @jajnyaseniswain8472 ปีที่แล้ว +1

    Well explained,... Got every bit of this problem

  • @darshil-oh2le
    @darshil-oh2le ปีที่แล้ว +1

    Such a nice explaination , make topic very easy 📌📌

  • @anjalisoni2371
    @anjalisoni2371 ปีที่แล้ว

    Nice explanation thanks for supporting us!

  • @rishujain0721
    @rishujain0721 ปีที่แล้ว +2

    Best explanation ❤
    Our teacher taught this wrong in the class..dumb

  • @user-ytuser
    @user-ytuser ปีที่แล้ว

    thanks, it was very nice explanation, crisp and clear

  • @PrasanthDadi
    @PrasanthDadi ปีที่แล้ว +3

    i have one doubt imagine 2 reader and default mutex is 1 . if 1st reader comes in wait he makes mutex to 0 .Inside if condition reader1 will restrict writer .After restricting writer he is allowing one more reader by signal(mutex) so mutex is 1 .reader 2 uses this and now mutex is 0 and reader 2 again increases to 1 . if user 1 has to level. before leaving wait(mutex) he will perform so it will 0 now if reader 2 has to leave he has to perform wait(mutex) now its a dead lock for reader2 any body can explain

    • @syedrafath2062
      @syedrafath2062 3 หลายเดือนก่อน

      Reader 1 ensures to signal (mutex) before exiting, making it available for Reader 2 to use wait (mutex), thus eliminating the possibility of a deadlock.

  • @DevC-g9c
    @DevC-g9c 6 หลายเดือนก่อน +1

    Good Explanation , but how wrt decide that whether the requested process is for reading or writing

  • @shyngysbek6907
    @shyngysbek6907 2 หลายเดือนก่อน +3

    I think that all "signal(mutex)" operations have to be outside the "if{...}" blocks. I assume Neso Academy did the indentations wrong and it is poorly managed in the first half of the code because why is the fist signal(mutex) is in the middle of the line?

  • @shyngysbek6907
    @shyngysbek6907 2 หลายเดือนก่อน +1

    Overall good explanation

  • @cyberssam654
    @cyberssam654 2 ปีที่แล้ว

    Very nice explanation sir 👍👍

  • @ayahamad5931
    @ayahamad5931 ปีที่แล้ว +2

    May god bless you with the Health ❤❤

  • @ABHISEKBISWASB
    @ABHISEKBISWASB 2 ปีที่แล้ว +3

    I think the signal(mutex) should come before : if(readcnt==0) so that after decrementing the readcnt the other readers can enter before releasing the wrt

    • @30benasabu65
      @30benasabu65 2 ปีที่แล้ว +1

      I think you have missed something the control goes to readcnt==0 if there are no readers left so in such a case the wrt lock must be released and mutex must also be released,
      The mutex lock held by a reader is released after it enters the critical section (given as signal mutex), so this ensures other readers can enter the critical section. here indentations are used to separate the code you may have missed it.

    • @reverbism
      @reverbism 2 ปีที่แล้ว

      @@30benasabu65
      can Signal(mutex) come before the signal(wrt)?

  • @luciec1889
    @luciec1889 2 ปีที่แล้ว +1

    Very well explained! Thank you so much!!

  • @camuflagehugo5137
    @camuflagehugo5137 3 ปีที่แล้ว +2

    It would be nice if there was an implementation in C.

  • @bryanshi3774
    @bryanshi3774 3 ปีที่แล้ว +2

    Great video!
    Why do we need mutex semaphore to ensure the mutual exclusion of readcnt?

    • @bhaskarmishra8479
      @bhaskarmishra8479 3 ปีที่แล้ว

      well, you may know about the race condition. To avoid it we need a mutex

    • @MeabuOP
      @MeabuOP ปีที่แล้ว

      @@bhaskarmishra8479 can you tell more about it ?

  • @marvolo6092
    @marvolo6092 3 ปีที่แล้ว +2

    this program seems to give more priority to the read operations. So going by the code, once a read operation acquires the wrt semaphore, it will only release it if readcount is 0 - thus if read processes keep coming in, I believe it will cause starvation for the write process, isn't it? So bounded waiting for effective process synchronization is not satisfied. How to improve this to implement bounded waiting?

    • @Delta0001-y
      @Delta0001-y 2 ปีที่แล้ว

      Any suggestions?

    • @simon8284
      @simon8284 2 ปีที่แล้ว

      Do we have to learn these codes for theory exams or its just to learn the basic theory?

    • @dhyansai6186
      @dhyansai6186 2 ปีที่แล้ว

      I guess we need to create an other semaphore to maintain a queue that involves both readers as well as writers.

  • @NisargaChowdaiah
    @NisargaChowdaiah 10 หลายเดือนก่อน

    Thank you so much 😊

  • @JonathanSteadman2003
    @JonathanSteadman2003 2 ปีที่แล้ว +2

    Great video :)

  • @humm123-t4l
    @humm123-t4l 2 ปีที่แล้ว

    Well explained

  • @adityarajsinghgour3113
    @adityarajsinghgour3113 3 ปีที่แล้ว +4

    @Neso Academy signal(mutex) is outside the if block or inside the if block ?

  • @manojkumarn468
    @manojkumarn468 3 ปีที่แล้ว +1

    Thanks

  • @ictcloudhelper
    @ictcloudhelper 3 หลายเดือนก่อน

    Thnks a lot ❤️

  • @nainaparmar4105
    @nainaparmar4105 2 ปีที่แล้ว

    mutex is a binary semaphore , then wrt is counting semaphore?

  • @nikhil78980
    @nikhil78980 11 หลายเดือนก่อน +1

    now signal(wrt) means both readers and writers can access it right?

    • @dakshshukla123
      @dakshshukla123 4 หลายเดือนก่อน +1

      signal(wrt)allows a writer waiting to write. If a process wants to read it can. wrt is only to prevent writer from writing. wrt is the mutual exclusion semaphore to prevent from writing. mutex here is to lock readcount variable.

  • @khomo12
    @khomo12 2 ปีที่แล้ว

    Very good explanation!

  • @debarghyaadhikari5558
    @debarghyaadhikari5558 2 ปีที่แล้ว +1

    Good one

  • @walidslimani
    @walidslimani 8 หลายเดือนก่อน

    i mean if you think about it . a reader is like a consumer and a writer is like a productor . so why not same logic

    • @avnarayana2414
      @avnarayana2414 8 หลายเดือนก่อน +1

      In readers writers problem we are used bounded buffer with fixed size and at there our main goal is to prevent overflow and underflow.
      But at readers writers problem the process is accessing shared resources like database or files. Here our goal is to allow concurrent reads and exclusive writes.
      Like this there are various key differences between those two problems bro

  • @samarthtandale9121
    @samarthtandale9121 ปีที่แล้ว

    Awesome !!!

  • @hayden4127
    @hayden4127 3 ปีที่แล้ว +3

    that indenting is so confusing in reader process

    • @andrewbabilonia77
      @andrewbabilonia77 3 ปีที่แล้ว +5

      I believe this is the proper indentation.
      do {
      wait(mutex);
      readcount++;
      if(readcount == 1)
      wait(wrt);
      signal(mutex);
      /*current reader performs reading*/
      wait(mutex);
      readcount--;
      if(readcount == 0)
      signal(wrt);
      signal(mutex);
      }while(TRUE);
      please correct if I'm wrong.

    • @danishsharma496
      @danishsharma496 2 ปีที่แล้ว

      @@andrewbabilonia77 ya true I checked on Internet loll

  • @hecticgamings
    @hecticgamings 10 หลายเดือนก่อน +2

    Chota packet bada dhamka😂
    Writers process 😊 readers process😮😢

  • @dfged9654
    @dfged9654 3 ปีที่แล้ว +4

    Is the last signal(mutex) inside reader process having a wrong indentation?

    • @fritz6600
      @fritz6600 3 ปีที่แล้ว

      They're following c style syntax for writing their pseudocode, in C
      if (...) statement1; is same as doing
      if (...) {statement1; statement 2; ....}
      Which is to say, immediately execute whatever that comes after "if", if "if's" condition is true, that "whatever" can be a block of statements or a single statement.
      Edit: Indentation does not matter in C, all that matters is, semicolon and curly braces.
      Edit2: int main() needs a curly-brace because int main is a function definition. Function definition needs curly braces. (Why? I do not know)

    • @nitpal9958
      @nitpal9958 3 ปีที่แล้ว

      I think so too. Doesn't make sense to wait till the last reader to release mutex. Correct me if I'm wrong.

  • @mohamedredha9586
    @mohamedredha9586 3 ปีที่แล้ว

    if readcoun==0 signal wrt / why should we wait all the readers to execute so we allow the writer to enter , perhaps the writer was there before some numbers of writers came , isnt this a sort of privilege that shouldn't happen in mutual exclusion ? (sorry for this broken English lol)

    • @danishsharma496
      @danishsharma496 2 ปีที่แล้ว

      more readers can be there , but writer can only come when readers become 0 so its signalling

  • @MeabuOP
    @MeabuOP ปีที่แล้ว

    I think the mutex for read count is no need

  • @arfatbagwan48
    @arfatbagwan48 ปีที่แล้ว

    Salute to you

  • @Dhineshx1
    @Dhineshx1 5 หลายเดือนก่อน

    this solution has a starvation problem. am I right?

  • @azadr
    @azadr 3 ปีที่แล้ว

    Pls upload in neso website and app also simultaneously

    • @rajeshprajapati4863
      @rajeshprajapati4863 3 ปีที่แล้ว

      I think it's already there.

    • @azadr
      @azadr 3 ปีที่แล้ว +1

      @@rajeshprajapati4863 no not all the video available

    • @rajeshprajapati4863
      @rajeshprajapati4863 3 ปีที่แล้ว

      @@azadr OS Subject is complete on app and website too. Check Again.

    • @azadr
      @azadr 3 ปีที่แล้ว +1

      @@rajeshprajapati4863not only with respective to os I was talking about all other subjects which were upload in youtube but not on neso

  • @pamp3657
    @pamp3657 2 ปีที่แล้ว

    good video

  • @rohitpol1109
    @rohitpol1109 8 วันที่ผ่านมา

    Graduating from Youttube Institute of Technology seems fun

  • @mosheklein5090
    @mosheklein5090 ปีที่แล้ว +8

    I see a problem with this solution : while reader 1 is currently reading, reader 2 can enter, readcnt is now =2, reader 1 finishes reading, he can’t continue to next line because the condition of readcnt ==0 isnt met. Now that readcnt is ==1 again, reader 2 continues. Now At this same time reader 2 can’t continue either because she cant get past the wait(wrt) condition since the lock is still held by reader 1. Reader 1 is waiting for reader 2 and vice versa. A traffic jam indeed!

    • @AmpangNation
      @AmpangNation ปีที่แล้ว +17

      last line signal(mutex) shouldn't be in the indentation (if statement), should be outside of the if statement, so that it won't have this problem I guess

    • @williamhogrider4136
      @williamhogrider4136 8 หลายเดือนก่อน +2

      ​@@AmpangNation Yes I think you're right

  • @modemharikumar9232
    @modemharikumar9232 3 ปีที่แล้ว +6

    1st comment

  • @edanuryardm8252
    @edanuryardm8252 ปีที่แล้ว +1

    adamsin

  • @saurabhojha2832
    @saurabhojha2832 2 ปีที่แล้ว

    🙏🙏🙏❤️❤️❤️❤️

  • @lydiaarabi4811
    @lydiaarabi4811 ปีที่แล้ว