Can I treat consecutive data members of the same type as a range? For example:
struct X
{
int a, b, c, d, e;
};
X x = {42, 13, 97, 11, 31};
std::sort(&x.a, &x.a + 5); // kosher?
Can I treat consecutive data members of the same type as a range? For example:
struct X
{
int a, b, c, d, e;
};
X x = {42, 13, 97, 11, 31};
std::sort(&x.a, &x.a + 5); // kosher?
No, this is undefined behaviour. You are treating x.a
like the first element of an array, which it isn't. May work on some implementations, may raid your fridge too ;)
For the purposes of these operators, a pointer to a nonarray object behaves the same as a pointer to the first element of an array of length one with the type of the object as its element type.
So you can treat it as a pointer to the first element of an array, just the length is one. –
Adjuvant X* p = &x; ++p;
to get a pointer past the end, but not what's in OP. –
Roobbie Don't do that. Compiler is free to add paddings between structure members(and at the end).
If this is really something you want to do, make it an array, vector or similar.
As others have said, the standard makes no guarantees about the members being stored without gaps or otherwise things that cause problems. (And to make matters worse, it will appear to work, until you compile it with a different (version of) compiler, or for another architecture some months or years later, and of course, it won't be easy to figure out what went wrong).
No, this is not possible in C++. It would be rather difficult to standarize; in this case the semantic is simple enough, but what if the struct was heterogenous?
Generally, it's a bad idea. If you want to treat some variables as array, you should declare them as array :)
Nevertheless you can use some compiler-specific instruction to ensure that there is no padding between elements, f.i.:
#pragma pack(push, 1)
struct X
{
int a, b, c, d, e;
};
#pragma pack(pop)
or
struct __attribute__((__packed__)) X
{
int a, b, c, d, e;
};
© 2022 - 2024 — McMap. All rights reserved.
static_assert(sizeof(X) == 5*sizeof(int), "I've been a really bad girl")
. – Ataraxiasizeof(X)
does not have to be exactly the size of 5int
s. If there is padding bytes at the end of the struct, the code could still do what it is expected to do. – Thermoscopesizeof(X)
does not have to be 5int
s for this trick to work. – Thermoscope