Sujet : Re: relearning C: why does an in-place change to a char* segfault?
De : 643-408-1753 (at) *nospam* kylheku.com (Kaz Kylheku)
Groupes : comp.lang.cDate : 02. Aug 2024, 02:06:08
Autres entêtes
Organisation : A noiseless patient Spider
Message-ID : <20240801174256.890@kylheku.com>
References : 1 2 3 4 5
User-Agent : slrn/pre1.0.4-9 (Linux)
On 2024-08-01, Bart <
bc@freeuk.com> wrote:
It segfaults when the string is stored in a read-only part of the binary.
A string literal creates an array object with static storage duration.
Any attempt to modify that array object has undefined behavior.
>
What's the difference between such an object, and an array like one of
these:
Programming languages can have objects that have the same lifetime, yet some
of which are mutable and some of which are immutable.
If the compiler believes that the immutable objects are in fact
not mutated, it's a bad idea to modify them behind the compiler's
back.
There doesn't have to be any actual difference in the implementation of
these objects, like in what area they are stored, other than the rules
regarding their correct use, namely prohibiting modification.
The Racket language has both mutable and immutable cons cells.
The difference is that the immutable cons cells simply lack the
operations needed to mutate them. I'm not an expert on the Racket
internals but I don't see a reason why they couldn't be stored in the
same heap.
static char A[100];
static char B[100]={1};
>
Do these not also have static storage duration? Yet presumably these can
be legally modified.
That 1 which initializes B[0] cannot be modified.
There is no portable way to request that.
C++ implementations have late initialization for block scope statics.
A program which somehow gains access to the initialization data for those,
and modifies it, would be squarely in undefined behavior territory.
In mainstream C implementations there typically isn't a separate storage
for the initialization data for statics. They are set up before the
program runs.
-- TXR Programming Language: http://nongnu.org/txrCygnal: Cygwin Native Application Library: http://kylheku.com/cygnalMastodon: @Kazinator@mstdn.ca