Liste des Groupes | Revenir à cl c |
BGB <cr88192@gmail.com> writes:This implicit pointer need not exist at a location in memory...On 7/6/2024 2:23 AM, Lawrence D'Oliveiro wrote:No, there is no implicitly defined pointer.On Fri, 05 Jul 2024 11:46:38 -0700, Keith Thompson wrote:>
>No, arrays are not pointers.Except array indexing is designed to be indistinguishable from
pointer
arithmetic.
Yeah, and in the 1D case, an array can be seen as functionally an
implicitly defined pointer with an assigned size and preassigned
backing memory.
Consider:
int integer_object;
int array_object[10];
This create an object of integer type with size sizeof(int) and an
object of array type with size 10 * sizeof (int). There is no implicit
pointer object associated with it either of them.
If you evaluate the expression `array_object` in most contexts, it's
implicitly converted to a pointer *value*, pointing to the 0th element
of the array object. There is still no implicit pointer object.
Similarly, evaluating `&integer_object` yields a pointer value, but does
not allocate a pointer object (but the "&" operator has to be explicit).
In very early C, before K&R1, an array object declaration actually did
implicitly create a pointer object holding the address of its initial
element. This became unworkable for structs containing members of
struct type; copying a struct would copy the address of the array but
not the array itself, resulting in the two structs sharing the same
array data.
Well, unless it exists in the compiler and ABI (which, in my compiler, is actually the case).Granted, C generally allows one to see the backing memory, but not theIf you take the address of a struct object, you get a pointer *value*.
implicit pointer to said backing memory. I guess one could argue that
if one can't take the address of it, it doesn't exist, but yeah...
>
Kind of a similar feature with lvalue structs:
An implicit pointer exists...
But, C wont let you see it directly or take its address.
There is no implicit pointer *object*, so there's nothing whose address
can be taken.
If you assume that arrays are really pointers, it's difficult orWell, as noted, I am thinking some here more at the level of compiler implementation, not necessarily at the level of C language semantics.
impossible to build a consistent model of how C works. If instead you
realize that arrays are arrays and arrays are pointers, and that C has
some peculiar rules about their interaction, everything is peculiar but
consistent.
[...]
Les messages affichés proviennent d'usenet.