From: Walter Cazzola <cazzola@dico.unimi.it>
To: Christophe Papazian <christophe.papazian@gmail.com>
Cc: OCaML Mailing List <caml-list@inria.fr>
Subject: Re: [Caml-list] still silly issues on polymorphic types
Date: Tue, 27 Sep 2011 15:49:25 +0200 (CEST) [thread overview]
Message-ID: <alpine.LFD.2.00.1109271546540.8918@surtur.dico.unimi.it> (raw)
In-Reply-To: <E923C544-C166-46CC-B02B-B36CFBE79E39@gmail.com>
On Tue, 27 Sep 2011, Christophe Papazian wrote:
> Please remember how types can be subtypes of other types :
>
> consider
>
> val f : int -> int
> val g : int -> 'a
> val h : 'a -> int
> val i : 'a -> 'b
>
> then the most general type is the type of g
> and most specific type is type of h. In fact we have a diamond relation
> between types :
>
> h<f<g
> h<i<g
> and i and f are not related.
>
> Why ?
>
> because if you need a function of type like f (int -> int)
> you can give h (if h can eat anything, it can eat int), but not g
> (i don't now how to handle 'a if I only need a int).
>
> So int is a subtype of 'a,
> but int -> int is not a subtype of 'a -> 'b,
> and 'a -> 'a is a valid subtype of int-> int.
uhm, I have a couple of questions I don't understand on your
explanation:
- why the most general type is int->'a and not 'a -> 'b?
- does this mean that I can't have a general type that could be matched
by 'a -> 'a list -> 'a list and int -> int -> int ?
Walter
--
next prev parent reply other threads:[~2011-09-27 13:49 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-09-27 11:46 Walter Cazzola
2011-09-27 12:57 ` Christophe Papazian
2011-09-27 13:49 ` Walter Cazzola [this message]
2011-09-27 15:26 ` Christophe Papazian
2011-09-27 18:43 ` Walter Cazzola
2011-09-27 19:25 ` Thibault Suzanne
2011-09-27 13:16 ` Jacques Garrigue
2011-09-27 13:58 ` Walter Cazzola
2011-09-27 19:45 ` Pierre Chopin
2011-09-27 20:22 ` Walter Cazzola
2011-09-27 23:58 ` Jacques Garrigue
[not found] ` <266E7048-C3BB-4B9E-9760-9D52993A1C86@math.nagoya-u.ac.jp>
2011-09-29 10:27 ` Walter Cazzola
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=alpine.LFD.2.00.1109271546540.8918@surtur.dico.unimi.it \
--to=cazzola@dico.unimi.it \
--cc=caml-list@inria.fr \
--cc=christophe.papazian@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox