caml-list - the Caml user's mailing list
 help / color / mirror / Atom feed
From: brogoff <brogoff@speakeasy.net>
To: caml-list <caml-list@inria.fr>
Subject: Re: Ant:  [Caml-list] The "Objective" part of Objective Caml
Date: Tue, 8 Nov 2005 10:16:52 -0800 (PST)	[thread overview]
Message-ID: <Pine.LNX.4.58.0511080953550.22345@shell3.speakeasy.net> (raw)
In-Reply-To: <Pine.LNX.4.63.0511072006270.20621@localhost.localdomain>

On Mon, 7 Nov 2005, Brian Hurt wrote:
> On Tue, 8 Nov 2005, skaller wrote:
>
> >>> The object oriented part of OCaml is roughly speaking
> >>> just as capable as that of Python, C++, Java, C# etc.
> >>
> >> Sure, I don't doubt that.
> >
> > I do. The Python system is much more 'capable' and much less 'robust'.
> > This is typical for dynamic typing vs static typing.
>
> I think I'm with Skaller here- Objects in Ocaml are much less powerfull
> than they are in (for example) Java or Python.

They're not "much less powerful" than they are in Java. They certainly lack
some features of the Java object system, but they posses many others. If
"powerful" means "supports multiple inheritance", Java is far less powerful.
If it means "supports" downcasting, ...

As far as static vs dynamic, dynamic type systems are inherently more
capable. There is no "slack" in a dynamically typed language. But the
possibility of a runtime exception is of course there.

>  For example, objects in
> Ocaml can not have non-virtual (non-overloadable) methods, or static
> (global) methods.  So patterns like singletons are hard to implement with
> Ocaml objects.
>
> But that's OK- because Ocaml provides other ways to provide those
> capabilities.  The problem I have with a lot of pure-OO languages is the
> need to make objects do everything.

The flip side of this is that OCaml is like Perl, with lots of ways to do
things, and many overlapping features. The fact that OCaml has classes and
modules is good, and that's how I think OO languages should be, but I would
expect that protection and hiding be done only by modules and not objects.

So, while I agree that a truly pure OO language is excessive, having a language
with tuples/records/variants/exceptions/... subsumed by the object system,
and a separate module system for namespace control is a reasonable approach.

> Ocaml is to use modules, not objects.  If you're not using the true power
> of objects- inheritance, virtual functions,

> and overloading-

Overloading is not an OO feature. Algol-68 and Ada 83, amongst others, had
overloading. While Java supports static overloading, languages like
CLOS and Dylan support generic functions with multiple dispatch, which
is far more powerful.

I do use classes when I want to reuse "record" field names, but that's
hardly OO. I suppose it is a kind of overloading though.

-- Brian


  parent reply	other threads:[~2005-11-08 18:16 UTC|newest]

Thread overview: 15+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2005-11-04 22:45 Florian Weimer
2005-11-07 21:41 ` Ant: [Caml-list] " Martin Chabr
2005-11-07 21:55   ` Florian Weimer
2005-11-08  1:47     ` skaller
2005-11-08  2:15       ` Brian Hurt
2005-11-08  7:15         ` Daniel Bünzli
2005-11-08 15:02           ` Brian Hurt
2005-11-08 15:39             ` Alexander Fuchs
2005-11-08 15:42             ` Matt Gushee
2005-11-08 15:56               ` Michael Wohlwend
2005-11-08 18:16         ` brogoff [this message]
2005-11-08 22:04           ` Brian Hurt
2005-11-08 23:40             ` brogoff
2005-11-09  9:00             ` skaller
2005-11-11 15:28       ` Florian Weimer

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=Pine.LNX.4.58.0511080953550.22345@shell3.speakeasy.net \
    --to=brogoff@speakeasy.net \
    --cc=caml-list@inria.fr \
    /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;
as well as URLs for NNTP newsgroup(s).