Deutsch   English   Français   Italiano  
<v6m03l$1tf05$1@dont-email.me>

View for Bookmarking (what is this?)
Look up another Usenet article

Path: ...!weretis.net!feeder8.news.weretis.net!eternal-september.org!feeder3.eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: bart <bc@freeuk.com>
Newsgroups: comp.lang.c
Subject: =?UTF-8?Q?Re=3A_technology_discussion_=E2=86=92_does_the_world_need?=
 =?UTF-8?B?IGEgIm5ldyIgQyA/?=
Date: Wed, 10 Jul 2024 13:51:02 +0100
Organization: A noiseless patient Spider
Lines: 85
Message-ID: <v6m03l$1tf05$1@dont-email.me>
References: <v66eci$2qeee$1@dont-email.me> <v687h2$36i6p$1@dont-email.me>
 <871q48w98e.fsf@nosuchdomain.example.com> <v68dsm$37sg2$1@dont-email.me>
 <87wmlzvfqp.fsf@nosuchdomain.example.com> <v6ard1$3ngh6$4@dont-email.me>
 <v6b0jv$3nnt6$1@dont-email.me> <87h6d2uox5.fsf@nosuchdomain.example.com>
 <v6d779$6rk5$2@dont-email.me> <v6e76u$c0i9$1@dont-email.me>
 <v6esqm$fian$2@dont-email.me> <v6f7vg$hgam$1@dont-email.me>
 <20240707164747.258@kylheku.com> <v6gl83$s72a$1@dont-email.me>
 <v6h8ao$ur1v$1@dont-email.me> <v6jhk3$1drd6$1@dont-email.me>
 <v6jiud$1dsjb$1@dont-email.me> <877cdur1z9.fsf@bsb.me.uk>
 <v6joi4$1epoj$1@dont-email.me> <871q42qy33.fsf@bsb.me.uk>
 <v6k6i0$1h4d3$1@dont-email.me> <87ed82p28y.fsf@bsb.me.uk>
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 7bit
Injection-Date: Wed, 10 Jul 2024 14:51:02 +0200 (CEST)
Injection-Info: dont-email.me; posting-host="ded9e1848a26cfa2c70264cde0490f0f";
	logging-data="2014213"; mail-complaints-to="abuse@eternal-september.org";	posting-account="U2FsdGVkX19Y2X3/R+G+emJfihLQ/yEE"
User-Agent: Mozilla Thunderbird
Cancel-Lock: sha1:2FoGDtuDZBJwsal3TfqzZRpvXTo=
In-Reply-To: <87ed82p28y.fsf@bsb.me.uk>
Content-Language: en-GB
Bytes: 4921

On 10/07/2024 00:35, Ben Bacarisse wrote:
> bart <bc@freeuk.com> writes:
> 
>> On 09/07/2024 18:22, Ben Bacarisse wrote:
>>> bart <bc@freeuk.com> writes:
>>>
>>>> On 09/07/2024 16:58, Ben Bacarisse wrote:
>>>>> bart <bc@freeuk.com> writes:
>>>>>
>>>>>> Arrays are passed by reference:
>>>>>>
>>>>>>      void F(int a[20]) {}
>>>>>>
>>>>>>      int main(void) {
>>>>>>        int x[20];
>>>>>>        F(x);
>>>>>>      }
>>>>> This is the sort of thing that bad tutors say to students so that they
>>>>> never learn C properly.  All parameter passing in C is by value.  All of
>>>>> it.  You just have to know (a) what the syntax means and (b) what values
>>>>> get passed.
>>>>
>>>> The end result is that a parameter declared with value-array syntax is
>>>> passed using a reference rather than by value.
>>>>
>>>> And it does so because the language says, not because the ABI requires
>>>> it. A 2-byte array is also passed by reference.
>>> An address value is passed by value.  C has only one parameter passing
>>> mechanism.  You can spin it as much as you like, but C's parameter
>>> passing is simple to understand, provided learner tune out voices like
>>> yours.
>>
>> Little about C's type system is simple.
> 
> Parameter passing is relatively simple though since there is only one
> mechanism -- pass by value.

Except when it comes to arrays. Obviously arrays aren't passed by value, 
but that's because of X and Y.

What would be genuinely simple is:

    void F(T x) {}
    void G(T* y) {}

where an object of type T is always passed by value, and that of type T* 
always passes a pointer to the value. Here, T represents exactly the 
same type as when it used outside a parameter list:

    T a;
    T* p;

but only in the context of C is it necessary to mention that, since it 
C, that may not be the case.

(The mechanisms of the underlying ABI do not affect this; they just make 
implementation harder.)

>> You're doing your students a
>> disservice if you try and hide all the quirks.
> 
> If.  Always with the if.  There are lots of things I don't do that would
> be doing my students a disservice were I to do them.  Beautiful spin!


Have a look at forums like the Reddit one on C programming, to see the 
kinds of things that people learning C get confused about. Lots of them 
are to do with the funny quirks of C, and a big proportion are due to 
how arrays and pointers are so intertwined in that language.

Well, C can't be fixed. But what would you do: explain the flaws in the 
language, the discontinuities, or brush them under the carpet?

Or maybe explain the quirks, but pretend they are by design?

What I find especially wonderful is that every time you see a pointer 
type like T*, C gives you an extra array dimension on top, whether or 
not T actually points to the first element of an array.

So you never know whether T* is intended to represent a 0- or 
1-dimensioned object, or a 1- or 2-dimensioned one.

And what I find frustrating is that people learning C get the idea that 
all this quirkiness goes hand-in-hand with lower-level programming.