Yığınsız Python - Stackless Python

Yığınsız Python
Orijinal yazar (lar)Christian Tismer
Geliştirici (ler)Anselm Kruis
İlk sürüm1998; 22 yıl önce (1998)
Kararlı sürüm
3.7.4-slp, 3.6.9-slp, 2.7.16-slp / 4 Ağustos 2019; 16 ay önce (2019-08-04)
Önizleme sürümü
3.8.0b3[1]
Depo Bunu Vikiveri'de düzenleyin
YazılmışC, Python
İşletim sistemiLinux, pencereler
TürÇevirmen
LisansPython Yazılım Vakfı Lisansı
İnternet sitesihttp://www.stackless.com

Yığınsız Pythonveya Yığınsız, bir Python programlama dili tercüman, bu şekilde adlandırılmıştır çünkü C çağrı yığını kendi yığını için. Pratikte, Stackless Python C yığınını kullanır, ancak fonksiyon çağrıları arasında yığın temizlenir.[2] Stackless'ın en belirgin özelliği, mikro iplikler, normal işletim sistemiyle ilişkili ek yüklerin çoğunu önleyen İş Parçacığı. Python özelliklerine ek olarak, Stackless ayrıca aşağıdakiler için destek ekler: Coroutines, iletişim kanallar ve görev serileştirme.

Tasarım

Stackless Python ile çalışan bir program, işletim sistemi tarafından değil, dil yorumlayıcısının kendisi tarafından yönetilen mikro iş parçacıkları olarak bölünür. çekirdekbağlam değiştirme ve görev planlaması tamamen tercüman tarafından yapılır (bu nedenle bunlar da bir tür yeşil iplik ). Microthreads, aynı CPU çekirdeği üzerindeki bir programdaki farklı alt görevlerin yürütülmesini yönetir. Bu nedenle, olay tabanlı eşzamansız programlamaya bir alternatiftirler ve ayrıca tek çekirdekli programlar için ayrı iş parçacıkları kullanmanın yükünü de önlerler (çünkü kullanıcı modu ile çekirdek modu arasında hiçbir mod geçişi yapılması gerekmediğinden CPU kullanımı azaltılabilir).

Mikro iş parçacıkları, tek bir çekirdekte alt görevleri çalıştırmayı kolaylaştırsa da, Stackless Python, Python'u kaldırmaz. Global Tercüman Kilidi veya birden çok iş parçacığı ve / veya işlem kullanmaz. Bu yüzden sadece kooperatif çoklu görev paylaşılan bir CPU'da değil paralellik (ön ödeme başlangıçta mevcut değildi, ancak şimdi bir şekilde var[3]). Birden çok CPU çekirdeği kullanmak için, Stackless Python işlemlerinin üzerine bir süreçler arası iletişim sistemi kurmanız gerekir.

Kaynakta önemli sayıda değişiklik olması nedeniyle, Stackless Python önceden var olan bir Python kurulumuna bir uzantı veya kütüphane. Bunun yerine kendi içinde eksiksiz bir Python dağıtımıdır. Stackless'ın özelliklerinin çoğu, aynı zamanda PyPy, bir kendi kendine barındırma Python yorumlayıcısı ve JIT derleyicisi.[4]

Kullanım

Stackless'in tamamı ayrı bir dağıtım olmasına rağmen, anahtarlama işlevselliği bir CPython Greenlet adlı uzantı.[5] Bir dizi kütüphane tarafından kullanılır (örneğin, gevent[6]) sağlamak için yeşil iplik CPython için çözüm. Python, yeşil iş parçacıkları için yerel bir çözüm aldı: beklemek / async.

Stackless, yaygın olarak Eve Online çok oyunculu çevrimiçi oyunun yanı sıra IronPort posta platformu.

Ayrıca bakınız

Referanslar

  1. ^ Stackless Python programlama dili, Yığınsız Python, 2019-11-14, alındı 2019-11-14
  2. ^ https://www.youtube.com/watch?v=pDkrkP0yf70
  3. ^ "Stackless Hakkında". Alındı 26 Ağustos 2016. bir round robin zamanlayıcı yerleşiktir. İşbirlikçi olarak veya öncelikli olarak görev uygulamalarını planlamak için kullanılabilir.
  4. ^ "Uygulama düzeyinde Yığınsız özellikler - PyPy belgeleri". pypy.readthedocs.org.
  5. ^ "greenlet: Hafif eşzamanlı programlama - greenlet 0.4.0 belgeleri". greenlet.readthedocs.org.
  6. ^ "Gevent nedir? - gevent 1.3.0.dev0 belgeleri". www.gevent.org.

Dış bağlantılar