|
Posted by Arne Vajhøj on 09/30/07 21:03
Erik Wikström wrote:
>> their reference (alias) mechanism. And C, Python, and Ruby probably
>> won't let you do that. What about Java and Perl?
>
> C will let you do it with pointers (it is just a syntactical difference
> from references in this case) and Java's references allows it.
Neither C or Java has call by reference.
C pointers and Java references may work similarly in most cases
but it is still call by value.
> I do not
> know about Ruby, Python and Perl, but (AFAIK) the all have OO support so
> I would be surprised if they used purely value semantics.
I can not see why OO should indicate anything about call by reference
support.
>> isn't "what i pass in, the function can modify it" not a desireable
>> behavior if i am NOT passing in the address of my argument? For one
>
> Being able to pass the actual object instead of a copy is highly
> desirable for two reasons. In most languages only one return value is
> allowed for a function so the ability to change parameters allows you to
> artificially return more without having to wrap them in constructs. The
> second reason is that for large objects the performance hit of having to
> create a copy each time you call a function can be forbidding.
Usually it is not a good thing, because it makes the code much
more difficult to read.
But sometimes it is handy.
I think C# got it right.
It allows it but require an explicit marking of it in both formal
argument list and actual argument list.
>> Java, Python, and Ruby, and we pass in a reference to object (not C+
>> +'s meaning of alias reference)
>
> In what way does the C++ reference differ from those in Java, Python,
> and Ruby in this situation?
C++ and Java are very different in this aspect.
Arne
Navigation:
[Reply to this message]
|