Ebooks, Audobooks and Classical Music from Liber Liber
a b c d e f g h i j k l m n o p q r s t u v w x y z





Web - Amazon

We provide Linux to the World


We support WINRAR [What is this] - [Download .exe file(s) for Windows]

CLASSICISTRANIERI HOME PAGE - YOUTUBE CHANNEL
SITEMAP
Audiobooks by Valerio Di Stefano: Single Download - Complete Download [TAR] [WIM] [ZIP] [RAR] - Alphabetical Download  [TAR] [WIM] [ZIP] [RAR] - Download Instructions

Make a donation: IBAN: IT36M0708677020000000008016 - BIC/SWIFT:  ICRAITRRU60 - VALERIO DI STEFANO or
Privacy Policy Cookie Policy Terms and Conditions
Inferencja typów - Wikipedia, wolna encyklopedia

Inferencja typów

Z Wikipedii

Inferencja typów to technika używana w językach statycznie typizowanych, która zwalnia programistę z obowiązku pisania typów i przerzuca obowiązek zgadnięcia typów na kompilator.

Weźmy przykład wyjątkowo prostego języka w który został już przerobiony na drzewo składniowe z jednoargumentowymi (rozwiniętymi) funkcjami (przykładowy kod w Ocamlu).

Nasz język ma tylko dwie konstrukcje - atomy i aplikacje funkcji. Podobnie typy dzielą się na atomowe i funkcyjne:

type utype = Basic of string | Fun of utype * utype;;

type expr = Atom of utype | Fapp of expr * expr;;

Kompilator musi sprawdzić trzy wyrażenia: (+), (+ 2) i ((+ 2) 2), oblicza więc typy atomów: (int->int->int), ((int->int->int) int), (((int->int->int) int) int) i podaje je do naszego inferatora:

let plus = Atom (Fun (Basic "int", Fun (Basic "int", Basic "int")));;
let two_plus = Fapp (plus, Atom (Basic "int"));;


let two_plus_two = Fapp (two_plus, Atom (Basic "int"));;

Procedura inferencji jest prosta: wylicza się typ ciała funkcji oraz jej argumentu, po czym jeśli:

  • typ funkcja nie jest funkcyjny - oznacza to błąd "not a function"
  • funkcja jest typu funkcyjnego, ale typ jej argumentu nie zgadza się z typem podanego argumentu - oznacza to błąd "argument type mismatch"
  • jeśli funkcja jest typu funkcyjnego i typy argumentów się zgadzają wyrażenie ma wartość taką jaką zwraca funkcja

Przy czym w językach polimorficznych nie sprawdza się równości tylko unifikuje typy argumentu spodziewanego i rzeczywistego.

let rec utype_infere = function
    Atom a -> a
  | Fapp (f,arg) ->
      let f_type = utype_infere f
      in let arg_type = utype_infere arg
      in match (f_type,arg_type) with
          (Basic _,_) -> failwith "not a function"
        | (Fun(fat,rt),aat) ->
            if fat = aat
            then rt
            else failwith "argument type mismatch"
;;

I podanie wyrażeń do inferatora:

utype_infere plus;;
utype_infere two_plus;;
utype_infere two_plus_two;;

W rzeczywistych językach należało by też zająć się inferencją typów funkcji, krotek, pętli, konstrukcji warunkowych i innych zwykle spotykanych konstrukcji. Większość z nich można przedstawić jako funkcje polimorficzne.

Zobacz też: system typów ML

Our "Network":

Project Gutenberg
https://gutenberg.classicistranieri.com

Encyclopaedia Britannica 1911
https://encyclopaediabritannica.classicistranieri.com

Librivox Audiobooks
https://librivox.classicistranieri.com

Linux Distributions
https://old.classicistranieri.com

Magnatune (MP3 Music)
https://magnatune.classicistranieri.com

Static Wikipedia (June 2008)
https://wikipedia.classicistranieri.com

Static Wikipedia (March 2008)
https://wikipedia2007.classicistranieri.com/mar2008/

Static Wikipedia (2007)
https://wikipedia2007.classicistranieri.com

Static Wikipedia (2006)
https://wikipedia2006.classicistranieri.com

Liber Liber
https://liberliber.classicistranieri.com

ZIM Files for Kiwix
https://zim.classicistranieri.com


Other Websites:

Bach - Goldberg Variations
https://www.goldbergvariations.org

Lazarillo de Tormes
https://www.lazarillodetormes.org

Madame Bovary
https://www.madamebovary.org

Il Fu Mattia Pascal
https://www.mattiapascal.it

The Voice in the Desert
https://www.thevoiceinthedesert.org

Confessione d'un amore fascista
https://www.amorefascista.it

Malinverno
https://www.malinverno.org

Debito formativo
https://www.debitoformativo.it

Adina Spire
https://www.adinaspire.com