İşlevsizleştirme - Defunctionalization

İçinde Programlama dilleri, işlevsizleştirme bir Derleme zamanı ortadan kaldıran dönüşüm üst düzey işlevler, bunların yerine tek bir birinci dereceden uygulamak işlevi. Teknik ilk olarak John C. Reynolds 1972 tarihli makalesi, "Yüksek Dereceli Programlama Dilleri için Tanımlayıcı Tercümanlar". Reynolds'un gözlemi, belirli bir programın yalnızca sonlu sayıda işlev soyutlaması içerdiğidir, böylece her biri benzersiz bir tanımlayıcı ile atanabilir ve değiştirilebilir. Program içindeki her işlev uygulaması daha sonra bir çağrı ile değiştirilir. uygulamak ilk bağımsız değişken olarak işlev tanımlayıcısı ile işlev. uygulamak işlevin tek görevi, bu ilk bağımsız değişkeni göndermek ve ardından işlev tanımlayıcısı tarafından belirtilen yönergeleri kalan bağımsız değişkenler üzerinde uygulamaktır.

Bu temel fikrin bir komplikasyonu, fonksiyon soyutlamaları referans olabilir serbest değişkenler. Bu tür durumlarda işlevsizleştirmeden önce kapatma dönüşümü (lambda kaldırma), böylece bir fonksiyon soyutlamasının herhangi bir serbest değişkeni ekstra argüman olarak aktarılır. uygulamak. Ek olarak, eğer kapanışlar şu şekilde desteklenmektedir: birinci sınıf değerler veri yapıları oluşturarak bu yakalanan bağlamaların temsil edilmesi gerekli hale gelir.

Tek bir uygulamak bir programdaki tüm işlev soyutlamalarında işlev gönderimi, çeşitli kontrol akışı analizi (aşağıdakilere dayalı basit ayrımlar dahil derece veya tip imzası ) her bir işlev uygulama sitesinde hangi işlevlerin çağrılabileceğini belirlemek için kullanılabilir ve özel bir uygulamak bunun yerine işlev referans verilebilir. Alternatif olarak, hedef dil, dolaylı çağrıları destekleyebilir. işlev işaretçileri, dağıtım tabanlı bir yaklaşımdan daha verimli ve genişletilebilir olabilir.

Üst düzey bir derleme tekniği olarak kullanımının yanı sıra işlevsel diller işlevsizleştirme çalışılmıştır (özellikle Olivier Danvy ve ortak çalışanlar) mekanik olarak dönüştürme yöntemi olarak tercümanlar içine soyut makineler. İşlevsizleştirme aynı zamanda teknikle de ilgilidir. nesne yönelimli programlama fonksiyonları ile temsil etme fonksiyon nesneleri (kapanışlara alternatif olarak).

Misal

Bu, tarafından verilen bir örnektir Olivier Danvy, Haskell'e çevrildi:

Ağaç veri türü verildiğinde:

veri Ağaç a = Yaprak a            | Düğüm (Ağaç a) (Ağaç a)

Aşağıdaki programı işlevsiz hale getireceğiz:

Eksileri :: a -> [a] -> [a]Eksileri x xs = x : xsÖ :: (b -> c) -> (a -> b) -> a -> cÖ f g x = f (g x)düzleştirmek :: Ağaç t -> [t]düzleştirmek t = yürümek t []yürümek :: Ağaç t -> [t] -> [t]yürümek (Yaprak x)     = Eksileri xyürümek (Düğüm t1 t2) = Ö (yürümek t1) (yürümek t2)

Tüm üst düzey işlevleri değiştirerek işlevsizleştiririz (bu durumda, Ö değeri olan tek üst düzey işlevdir) Lam veri türü ve bunları doğrudan aramak yerine, bir uygulamak veri türünü yorumlayan işlev:

veri Lam a = LamCons a           | LamO (Lam a) (Lam a)uygulamak :: Lam a -> [a] -> [a]uygulamak (LamCons x)  xs = x : xsuygulamak (LamO f1 f2) xs = uygulamak f1 (uygulamak f2 xs)cons_def :: a -> Lam acons_def x  = LamCons xo_def :: Lam a -> Lam a -> Lam ao_def f1 f2 = LamO f1 f2flatten_def :: Ağaç t -> [t]flatten_def t = uygulamak (walk_def t) []walk_def :: Ağaç t -> Lam twalk_def (Yaprak x)     = cons_def xwalk_def (Düğüm t1 t2) = o_def (walk_def t1) (walk_def t2)

Ayrıca bakınız

Referanslar

  • Reynolds, John (Ağustos 1972). "Yüksek Dereceli Programlama Dilleri için Tanımlayıcı Tercümanlar". ACM Yıllık Konferansı Bildirileri. Boston, Massachusetts. s. 717–740. doi:10.1145/800194.805852.
  • Danvy, Olivier; Nielsen, Lasse R. (2001). "İş Yerinde İşlevsizleştirme" (PDF). ACM SIGPLAN Bildirime Dayalı Programlama İlkeleri ve Uygulaması Konferansı Bildirileri. s. 162–174. doi:10.1145/773184.773202. (Daha kapsamlı versiyon: Teknik Rapor BRICS-RS-01-23 )
  • Danvy, Olivier; Millikin, Kevin R. (Haziran 2009). "İşyerinde Yeniden İşlevselleştirme". Bilgisayar Programlama Bilimi. 74 (8): 534–549. doi:10.1016 / j.scico.2007.10.007. (Ayrıca şu şekilde mevcuttur Teknik Rapor BRICS-RS-07-7 )

Dış bağlantılar