Search code examples
c++standardsendiannessunions

Is using an union in place of a cast well defined?


I had a discussion this morning with a colleague regarding the correctness of a "coding trick" to detect endianness.

The trick was:

bool is_big_endian()
{
  union
  {
    int i;
    char c[sizeof(int)];
  } foo;


  foo.i = 1;
  return (foo.c[0] == 1);
}

To me, it seems that this usage of an union is incorrect because setting one member of the union and reading another is not well-defined. But I have to admit that this is just a feeling and I lack actual proofs to strengthen my point.

Is this trick correct ? Who is right here ?


Solution

  • Your code is not portable. It might work on some compilers or it might not.

    You are right about the behaviour being undefined when you try to access the inactive member of the union [as it is in the case of the code given]

    $9.5/1

    In a union, at most one of the data members can be active at any time, that is, the value of at most one of the data members can be stored in a union at any time.

    So foo.c[0] == 1 is incorrect because c is not active at that moment. Feel free to correct me if you think I am wrong.