ºÝºÝߣ

ºÝºÝߣShare a Scribd company logo
İşlem Yönetimi (İşlem, Semafor ve Kilitlenme)<br />İşlem (process) belli bir komut dizisini yerine getiren program parçasıdır. Ancak bir<br />program parçasında sadece kodlar vardır oysa bir işlem çalışma sırasında gerekli olan<br />tüm bilgileri bünyesinde barındırmaktadır. Bir işlemin yapısında; işlemin yazılı olduğu<br />metin bölümü, bir sonraki işletilecek olan komutu gösteren sayaç ve işlemci<br />kaydedicilerinin içeriği olan program sayacı (program counter) bölümü, yerel<br />değişkenler, dönüş adresleri gibi geçici bilgileri tutan yığın (stack) bölümü, genel<br />değişken vb. bilgileri tutan veri bölümü bulunmaktadır. Bazı işlemlerde işlemin çalıştığı<br />sürece kullandığı bir alan (heap) de bulunmaktadır.<br />İşlem Kontrol Bloğu (Process Control Block): <br />Her işlem işletim sistemi tarafından işlem kontrol bloğu tarafından gösterilir, yer alan öğeler ise şunlardır;<br />İşlem durumu<br />İşlem numarası<br />Program sayacı<br />Kaydediciler<br />Bellek sınırları<br />Açılan dosyaların sayısı<br />• İşlem durumu: İşlem yeni, çalışıyor, bekliyor, hazır veya bitti şeklinde<br />olabilir.<br />• Program sayacı: İşlemde çalıştırılacak bir sonraki komutu gösterir.<br />• MİB kaydedicileri: İşlemci mimarisini göre kaydedicilerin sayısı ve türü<br />değişmektedir. İşlemde kullanılan kaydediciler (AX, BX vb.) içerisindeki<br />bilgiler bir kesme geldiğinde mutlaka saklanmalıdır.<br />• MİB zamanlanma bilgisi: Burada işlemin önceliğini, zamanlama kuyruğundaki<br />işaretçisi ve diğer zamanlama parametreleri ile ilgili bilgiler bulunmaktadır.<br />• Bellek yönetimi bilgisi: İşletim sistemi tarafından kullanılan bellek<br />sistemleri; taban ve limit (tavan) kaydedicileri, sayfa tablosu veya bölüm<br />tablosu gibi bilgileri içermektedir.<br />• Hesap bilgileri: İşlem tarafından kullanılan MİB ve diğer parametrelerin<br />kulanım zamanlarını içermektedir.<br />• G/Ç durum bilgisi: İşlem tarafından kullanılan G/Ç aygıtlarının listesi, açılan<br />dosyaların listesi vb. bilgileri içermektedir.<br />İşlem durumu (Process state):<br />Bir işlemin hangi durumda olduğunu gösteren ve işlemin ömrü boyunca değişken<br />bir durumu bulunmaktadır. Bunlar;<br />• Yeni: İşlemin oluşturulduğunu gösterir.<br />• Çalışıyor: İşlemin komutları yürütülmektedir.<br />• Bekliyor: İşlem bir olayın gerçekleşmesini beklemektedir. Örneğin bir<br />G/Ç işlemi.<br />• Hazır: İşlem bir işlemciye atanmak için beklemektedir.<br />• Bitti: İşlem çalışmasını bitirdi.<br />İş Parçacıkları (Threads)<br />İş parçacığı, işlemin bir parçasıdır. Örneğin bir işlemin bir kelime işlemci<br />programının çalışmasını yürüttüğünü düşünelim. Burada kullanıcı örneğin bir satırdaki<br />yazıları seçerek kalın yapmak istediğinde bu faaliyete iş parçacığı denilmektedir.<br />Modern işletim sistemleri aynı işlem içerisinde birden fazla iş parçacığının<br />yürütülmesine izin vermektedir.<br />İşlemlerin Zamanlanması (Process Schedulers)<br />Tüm işlemler iş kuyruğuna (Job queue) alınmaktadır. Çalıştırılmaya hazır olan<br />veya bekleyen işlemler hazır kuyruğana (ready queue) alınarak MİB’ne gönderilir.<br />‘Dağıtıcı (Dispatcher)’ çalıştırılacak olan bir işlemi seçerek MİB’ne gönderdikten sonra<br />aşağıdaki olaylar meydana gelebilir;<br />• İşlem bir G/Ç isteğinde bulunabilir ve böylece G/Ç kuyruğuna<br />yerleştirilir.<br />• İşlem alt işlemler oluşturabilir ve bunların bitmesini bekleyebilir.<br />• İşlem bir kesme oluştuğu için MİB’de çalışması durdurularak kesmenin<br />bitiminin ardından kuyruğa alınarak MİB’ne gönderilebilir.<br />İlk iki durumda işlem hazır durumdan bekliyor durumuna getirilir ardından<br />işlemler gerçekleştikten sonra hazır durumuna getirilerek kuyruğa tekrar girer. Bu<br />döngüde bir işlem bitirilinceye, tüm kuyruklardan çıkıncaya ve kullandığı kaynakları<br />bırakıncaya kadar kalır.<br />Kilitlenme (Deadlock)<br />Sonsuz döngü anlamına da gelmektedir. Değişik işlemlerin/iş parçacıklarının<br />birbirlerinin alanlarını kullanmalarından ortaya çıkar. Windows’da sıklıkla karşınıza<br />çıkan mavi ekranın sebebi! Örneğin bir işlem bir kaynağı (örneğin A dosyasını)<br />kullanırken diğer bir kaynağı (örneğin B dosyasını) kullanmak istemektedir. Ancak aynı<br />zamanda başka bir işlem B dosyasını kullanırken A dosyasını kullanmak istemektedir.<br />Bu durumda her iki işlem de istedikleri dosyaları alamayacakları için bu işlemler<br />bloklanacaklardır.<br />Semafor (Semaphore):<br />Latincede ‘deniz feneri’ anlamına gelen Semafor, negatif olmayan bir tamsayı<br />olup işlemin başlangıç deyiminden itibaren wait ve signal işlemleri ile değeri<br />değiştirilebilen bir değişkendir.<br />Signal (S) : S = S + 1 (1 arttırma)<br />Wait (W) : W = W – 1 (1 azaltma)<br />Vol (sem) = C(sem) + ns(sem) - nw(sem)<br />Vol (sem): Semafor’un değeri. Bu değer 0’a eşit veya büyük olmalıdır.<br />C(sem) : Semafor’un başlangıç değeri<br />ns(sem): Semafor üzerindeki signal operasyon sayısı<br />nw(sem): Semafor üzerindeki wait operasyon sayısı<br />Vol(sem) ≤ 0<br />Nw(sem) ≤ ns(sem) + C(sem)<br />İki ayrı işlem aynı anda bellekte yürütülürken kaynaklara aynı anda erişmeye<br />çalışabilirler. Bu durumda kullanılan semafor, sistem kilitlenmelerine engel olur. Bir<br />semafor’un paylaşılabilmesi onun başlangıç değerine bağlıdır. Başlangıç değeri ‘n’ olan<br />bir semafor ‘n’ işlem tarafından kullanılır.<br />Wait ve signal işlemleri yanlış yerleştirilirse sistem hemen kilitlenir. Semaforlar<br />işlemler arası iletişimi sağlayarak sonsuz döngülere ve sistem kilitlenmelerine engel<br />olurlar. Örneğin; X ve Y başlangıç değerleri 1 olan iki semafor olsun. P0 ve P1 ise bu iki<br />semaforu kullanan işlemler olsun.<br />P0 P1<br />. .<br />wait (S) wait (Q)<br />wait (Q) wait (S)<br />. . Deadlock<br />. . (işlemler bloklanır)<br />. .<br />signal (S) signal (Q)<br />signal (Q) signal (S)<br />Bloklama ve bloğu açma (Blocking and Unblocking): Bir wait işlemi eğer ilgili<br />semaphore değeri 0 ise o işlemin bloke edilmesine neden olur. Semaphore’un değeri<br />signal ile 1 olunca bloke kaldırılarak işlem çalışabilir hale getirilir.<br />Örnek: İki işlemden bir tanesinin bir buffer’a çeşitli değerler aktardığını, diğerinin ise<br />buradan bu bilgileri aldığını farz edelim. Buna verilecek bir örnek bir satır<br />uzunluğundaki bir karakter dizisini her seferinde buffer’a atan bir işlem (process) ile<br />her seferinde buffer’dan bir satır alıp bunu ekrana yazan bir işlem olabilir. Burada bir<br />başka farz ediş ise tampon (buffer) büyüklüğünün kısıtlı olmasıdır (n satır<br />tutulabildiği). Bu durumda bu iki işlem arasında senkronizasyon gereklidir:<br />1. Eğer buffer dolu ise buraya bilgi aktarılmayacaktır.<br />2. Eğer buffer boş ise buradan bilgi alınmayacaktır.<br />0 ≤ d – e ≤ N<br />d: Buffer’a atılan satır sayısı<br />e: Buffer’dan alınan satır sayısı<br />N: Space avaible (Boş alan sayısı)<br />Q: Item avaible (dolu alan sayısı yani eleman sayısı)<br />Program for Producers<br />Repeat indefinitely<br />Begin<br />Produce item;<br />Wait (space avaible);<br />Wait (buffer maniplation);<br />Deposit item in buffer ;<br />Signal (buffer maniplation);<br />Signal (item avaible);<br />End.<br />Yukarıdaki program bir üretici programdır. Buffer’a eleman ekler. Elemanı<br />üretir, boş alan oluncaya kadar bekler, bufferı kullanıp kullanamayacağını sorgular<br /> (Buffer = 0), üretilen satırı buffer’a yerleştirir, buffer’ı serbest bırakır ve eleman<br />sayısını 1 arttır.<br />Program for consumers;<br />Repeat indefinitely<br />Begin<br />Wait (item avaible);<br />Wait (buffer maniplation);<br />Extract item in buffer ;<br />Signal (buffer maniplation);<br />Signal (space avaible);<br />End.<br />Yukarıdaki program bir tüketici programdır. Eleman sayısı 0’dan büyük olana<br />kadar- bufferda eleman oluncaya kadar bekler, bufferı kullanıp kullanamayacağını<br />sorgular (Buffer = 0), elemanı alır, buffera ulaşımı sağlar (Buffer maniplation’ı bir<br />arttırır), boş yer sayısını bir artırır.<br />Bu iki işlem bellekte aynı anda çalışmalarına rağmen buffer maniplation ile<br />aralarındaki iletişim sağlanmış ve kilitlenmeler önlenmiştir. Bir anda ancak bir işlem<br />buffera erişmektedir.<br />Monitör Programları<br />Monitör programları paylaşılan nesneye ulaşmada meydana gelebilecek problemleri<br />ortadan kaldırmaya yönelik olarak geliştirilmiştir. Yani izleyici programlardır.<br />1. Paylaşılan nesneyi oluşturan veri<br />2. Bu nesneye ulaşmak için kullanılan bir grup procedure<br />3. Nesneyi başlangıç durumuna getiren bir program parçasından oluşmaktadır.<br />Daha önceki buffer örneği için;<br />1. Buffer alanı ve buraya işaret eden pointerler<br />2. Depolama ve çıkarma işlemleri için kullanılan iki procedure<br />3. Buffer işaretçilerini eski haline getiren bir program parçası<br />Monitör programları, wait ve signal işlemleri yanlış gerçekleştirildiğinde oluşan<br />sistem kilitlenmeleri engeller. Semaforlarla işlemler arası kombinasyonu sağlarlar ve<br />wait ve signal işlemleri arasındaki senkronizasyonu sağlarlar.<br />
İşletim sistemleri
İşletim sistemleri
İşletim sistemleri
İşletim sistemleri

More Related Content

İşletim sistemleri

  • 1. Ä°ÅŸlem Yönetimi (Ä°ÅŸlem, Semafor ve Kilitlenme)<br />Ä°ÅŸlem (process) belli bir komut dizisini yerine getiren program parçasıdır. Ancak bir<br />program parçasında sadece kodlar vardır oysa bir iÅŸlem çalışma sırasında gerekli olan<br />tüm bilgileri bünyesinde barındırmaktadır. Bir iÅŸlemin yapısında; iÅŸlemin yazılı olduÄŸu<br />metin bölümü, bir sonraki iÅŸletilecek olan komutu gösteren sayaç ve iÅŸlemci<br />kaydedicilerinin içeriÄŸi olan program sayacı (program counter) bölümü, yerel<br />deÄŸiÅŸkenler, dönüş adresleri gibi geçici bilgileri tutan yığın (stack) bölümü, genel<br />deÄŸiÅŸken vb. bilgileri tutan veri bölümü bulunmaktadır. Bazı iÅŸlemlerde iÅŸlemin çalıştığı<br />sürece kullandığı bir alan (heap) de bulunmaktadır.<br />Ä°ÅŸlem Kontrol BloÄŸu (Process Control Block): <br />Her iÅŸlem iÅŸletim sistemi tarafından iÅŸlem kontrol bloÄŸu tarafından gösterilir, yer alan öğeler ise ÅŸunlardır;<br />Ä°ÅŸlem durumu<br />Ä°ÅŸlem numarası<br />Program sayacı<br />Kaydediciler<br />Bellek sınırları<br />Açılan dosyaların sayısı<br />• Ä°ÅŸlem durumu: Ä°ÅŸlem yeni, çalışıyor, bekliyor, hazır veya bitti ÅŸeklinde<br />olabilir.<br />• Program sayacı: Ä°ÅŸlemde çalıştırılacak bir sonraki komutu gösterir.<br />• MÄ°B kaydedicileri: Ä°ÅŸlemci mimarisini göre kaydedicilerin sayısı ve türü<br />deÄŸiÅŸmektedir. Ä°ÅŸlemde kullanılan kaydediciler (AX, BX vb.) içerisindeki<br />bilgiler bir kesme geldiÄŸinde mutlaka saklanmalıdır.<br />• MÄ°B zamanlanma bilgisi: Burada iÅŸlemin önceliÄŸini, zamanlama kuyruÄŸundaki<br />iÅŸaretçisi ve diÄŸer zamanlama parametreleri ile ilgili bilgiler bulunmaktadır.<br />• Bellek yönetimi bilgisi: Ä°ÅŸletim sistemi tarafından kullanılan bellek<br />sistemleri; taban ve limit (tavan) kaydedicileri, sayfa tablosu veya bölüm<br />tablosu gibi bilgileri içermektedir.<br />• Hesap bilgileri: Ä°ÅŸlem tarafından kullanılan MÄ°B ve diÄŸer parametrelerin<br />kulanım zamanlarını içermektedir.<br />• G/Ç durum bilgisi: Ä°ÅŸlem tarafından kullanılan G/Ç aygıtlarının listesi, açılan<br />dosyaların listesi vb. bilgileri içermektedir.<br />Ä°ÅŸlem durumu (Process state):<br />Bir iÅŸlemin hangi durumda olduÄŸunu gösteren ve iÅŸlemin ömrü boyunca deÄŸiÅŸken<br />bir durumu bulunmaktadır. Bunlar;<br />• Yeni: Ä°ÅŸlemin oluÅŸturulduÄŸunu gösterir.<br />• Çalışıyor: Ä°ÅŸlemin komutları yürütülmektedir.<br />• Bekliyor: Ä°ÅŸlem bir olayın gerçekleÅŸmesini beklemektedir. ÖrneÄŸin bir<br />G/Ç iÅŸlemi.<br />• Hazır: Ä°ÅŸlem bir iÅŸlemciye atanmak için beklemektedir.<br />• Bitti: Ä°ÅŸlem çalışmasını bitirdi.<br />Ä°ÅŸ Parçacıkları (Threads)<br />Ä°ÅŸ parçacığı, iÅŸlemin bir parçasıdır. ÖrneÄŸin bir iÅŸlemin bir kelime iÅŸlemci<br />programının çalışmasını yürüttüğünü düşünelim. Burada kullanıcı örneÄŸin bir satırdaki<br />yazıları seçerek kalın yapmak istediÄŸinde bu faaliyete iÅŸ parçacığı denilmektedir.<br />Modern iÅŸletim sistemleri aynı iÅŸlem içerisinde birden fazla iÅŸ parçacığının<br />yürütülmesine izin vermektedir.<br />Ä°ÅŸlemlerin Zamanlanması (Process Schedulers)<br />Tüm iÅŸlemler iÅŸ kuyruÄŸuna (Job queue) alınmaktadır. Çalıştırılmaya hazır olan<br />veya bekleyen iÅŸlemler hazır kuyruÄŸana (ready queue) alınarak MÄ°B’ne gönderilir.<br />‘Dağıtıcı (Dispatcher)’ çalıştırılacak olan bir iÅŸlemi seçerek MÄ°B’ne gönderdikten sonra<br />aÅŸağıdaki olaylar meydana gelebilir;<br />• Ä°ÅŸlem bir G/Ç isteÄŸinde bulunabilir ve böylece G/Ç kuyruÄŸuna<br />yerleÅŸtirilir.<br />• Ä°ÅŸlem alt iÅŸlemler oluÅŸturabilir ve bunların bitmesini bekleyebilir.<br />• Ä°ÅŸlem bir kesme oluÅŸtuÄŸu için MÄ°B’de çalışması durdurularak kesmenin<br />bitiminin ardından kuyruÄŸa alınarak MÄ°B’ne gönderilebilir.<br />Ä°lk iki durumda iÅŸlem hazır durumdan bekliyor durumuna getirilir ardından<br />iÅŸlemler gerçekleÅŸtikten sonra hazır durumuna getirilerek kuyruÄŸa tekrar girer. Bu<br />döngüde bir iÅŸlem bitirilinceye, tüm kuyruklardan çıkıncaya ve kullandığı kaynakları<br />bırakıncaya kadar kalır.<br />Kilitlenme (Deadlock)<br />Sonsuz döngü anlamına da gelmektedir. DeÄŸiÅŸik iÅŸlemlerin/iÅŸ parçacıklarının<br />birbirlerinin alanlarını kullanmalarından ortaya çıkar. Windows’da sıklıkla karşınıza<br />çıkan mavi ekranın sebebi! ÖrneÄŸin bir iÅŸlem bir kaynağı (örneÄŸin A dosyasını)<br />kullanırken diÄŸer bir kaynağı (örneÄŸin B dosyasını) kullanmak istemektedir. Ancak aynı<br />zamanda baÅŸka bir iÅŸlem B dosyasını kullanırken A dosyasını kullanmak istemektedir.<br />Bu durumda her iki iÅŸlem de istedikleri dosyaları alamayacakları için bu iÅŸlemler<br />bloklanacaklardır.<br />Semafor (Semaphore):<br />Latincede ‘deniz feneri’ anlamına gelen Semafor, negatif olmayan bir tamsayı<br />olup iÅŸlemin baÅŸlangıç deyiminden itibaren wait ve signal iÅŸlemleri ile deÄŸeri<br />deÄŸiÅŸtirilebilen bir deÄŸiÅŸkendir.<br />Signal (S) : S = S + 1 (1 arttırma)<br />Wait (W) : W = W – 1 (1 azaltma)<br />Vol (sem) = C(sem) + ns(sem) - nw(sem)<br />Vol (sem): Semafor’un deÄŸeri. Bu deÄŸer 0’a eÅŸit veya büyük olmalıdır.<br />C(sem) : Semafor’un baÅŸlangıç deÄŸeri<br />ns(sem): Semafor üzerindeki signal operasyon sayısı<br />nw(sem): Semafor üzerindeki wait operasyon sayısı<br />Vol(sem) ≤ 0<br />Nw(sem) ≤ ns(sem) + C(sem)<br />Ä°ki ayrı iÅŸlem aynı anda bellekte yürütülürken kaynaklara aynı anda eriÅŸmeye<br />çalışabilirler. Bu durumda kullanılan semafor, sistem kilitlenmelerine engel olur. Bir<br />semafor’un paylaşılabilmesi onun baÅŸlangıç deÄŸerine baÄŸlıdır. BaÅŸlangıç deÄŸeri ‘n’ olan<br />bir semafor ‘n’ iÅŸlem tarafından kullanılır.<br />Wait ve signal iÅŸlemleri yanlış yerleÅŸtirilirse sistem hemen kilitlenir. Semaforlar<br />iÅŸlemler arası iletiÅŸimi saÄŸlayarak sonsuz döngülere ve sistem kilitlenmelerine engel<br />olurlar. ÖrneÄŸin; X ve Y baÅŸlangıç deÄŸerleri 1 olan iki semafor olsun. P0 ve P1 ise bu iki<br />semaforu kullanan iÅŸlemler olsun.<br />P0 P1<br />. .<br />wait (S) wait (Q)<br />wait (Q) wait (S)<br />. . Deadlock<br />. . (iÅŸlemler bloklanır)<br />. .<br />signal (S) signal (Q)<br />signal (Q) signal (S)<br />Bloklama ve bloÄŸu açma (Blocking and Unblocking): Bir wait iÅŸlemi eÄŸer ilgili<br />semaphore deÄŸeri 0 ise o iÅŸlemin bloke edilmesine neden olur. Semaphore’un deÄŸeri<br />signal ile 1 olunca bloke kaldırılarak iÅŸlem çalışabilir hale getirilir.<br />Örnek: Ä°ki iÅŸlemden bir tanesinin bir buffer’a çeÅŸitli deÄŸerler aktardığını, diÄŸerinin ise<br />buradan bu bilgileri aldığını farz edelim. Buna verilecek bir örnek bir satır<br />uzunluÄŸundaki bir karakter dizisini her seferinde buffer’a atan bir iÅŸlem (process) ile<br />her seferinde buffer’dan bir satır alıp bunu ekrana yazan bir iÅŸlem olabilir. Burada bir<br />baÅŸka farz ediÅŸ ise tampon (buffer) büyüklüğünün kısıtlı olmasıdır (n satır<br />tutulabildiÄŸi). Bu durumda bu iki iÅŸlem arasında senkronizasyon gereklidir:<br />1. EÄŸer buffer dolu ise buraya bilgi aktarılmayacaktır.<br />2. EÄŸer buffer boÅŸ ise buradan bilgi alınmayacaktır.<br />0 ≤ d – e ≤ N<br />d: Buffer’a atılan satır sayısı<br />e: Buffer’dan alınan satır sayısı<br />N: Space avaible (BoÅŸ alan sayısı)<br />Q: Item avaible (dolu alan sayısı yani eleman sayısı)<br />Program for Producers<br />Repeat indefinitely<br />Begin<br />Produce item;<br />Wait (space avaible);<br />Wait (buffer maniplation);<br />Deposit item in buffer ;<br />Signal (buffer maniplation);<br />Signal (item avaible);<br />End.<br />Yukarıdaki program bir üretici programdır. Buffer’a eleman ekler. Elemanı<br />üretir, boÅŸ alan oluncaya kadar bekler, bufferı kullanıp kullanamayacağını sorgular<br /> (Buffer = 0), üretilen satırı buffer’a yerleÅŸtirir, buffer’ı serbest bırakır ve eleman<br />sayısını 1 arttır.<br />Program for consumers;<br />Repeat indefinitely<br />Begin<br />Wait (item avaible);<br />Wait (buffer maniplation);<br />Extract item in buffer ;<br />Signal (buffer maniplation);<br />Signal (space avaible);<br />End.<br />Yukarıdaki program bir tüketici programdır. Eleman sayısı 0’dan büyük olana<br />kadar- bufferda eleman oluncaya kadar bekler, bufferı kullanıp kullanamayacağını<br />sorgular (Buffer = 0), elemanı alır, buffera ulaşımı saÄŸlar (Buffer maniplation’ı bir<br />arttırır), boÅŸ yer sayısını bir artırır.<br />Bu iki iÅŸlem bellekte aynı anda çalışmalarına raÄŸmen buffer maniplation ile<br />aralarındaki iletiÅŸim saÄŸlanmış ve kilitlenmeler önlenmiÅŸtir. Bir anda ancak bir iÅŸlem<br />buffera eriÅŸmektedir.<br />Monitör Programları<br />Monitör programları paylaşılan nesneye ulaÅŸmada meydana gelebilecek problemleri<br />ortadan kaldırmaya yönelik olarak geliÅŸtirilmiÅŸtir. Yani izleyici programlardır.<br />1. Paylaşılan nesneyi oluÅŸturan veri<br />2. Bu nesneye ulaÅŸmak için kullanılan bir grup procedure<br />3. Nesneyi baÅŸlangıç durumuna getiren bir program parçasından oluÅŸmaktadır.<br />Daha önceki buffer örneÄŸi için;<br />1. Buffer alanı ve buraya iÅŸaret eden pointerler<br />2. Depolama ve çıkarma iÅŸlemleri için kullanılan iki procedure<br />3. Buffer iÅŸaretçilerini eski haline getiren bir program parçası<br />Monitör programları, wait ve signal iÅŸlemleri yanlış gerçekleÅŸtirildiÄŸinde oluÅŸan<br />sistem kilitlenmeleri engeller. Semaforlarla iÅŸlemler arası kombinasyonu saÄŸlarlar ve<br />wait ve signal iÅŸlemleri arasındaki senkronizasyonu saÄŸlarlar.<br />