Converting Little Endian to Big Endian
Solution 1
The thing you need to realize is that endian swaps deal with the bytes that represent the integer. So the 4 byte number 27 looks like 0x0000001B
. To convert that number, it needs to go to 0x1B000000
... With your example, the hex representation of 123456789 is 0x075BCD15
which needs to go to 0x15CD5B07
or in decimal form 365779719.
The function Stacker posted is moving those bytes around by bit shifting them; more specifically, the statement i&0xff
takes the lowest byte from i
, the << 24
then moves it up 24 bits, so from positions 1-8 to 25-32. So on through each part of the expression.
For example code, take a look at this utility.
Solution 2
Since a great part of writing software is about reusing existing solutions, the first thing should always be a look into the documentation for your language/library.
reverse = Integer.reverseBytes(x);
I don't know how efficient this function is, but for toggling lots of numbers, a ByteBuffer
should offer decent performance.
import java.nio.ByteBuffer;
import java.nio.ByteOrder;
...
int[] myArray = aFountOfIntegers();
ByteBuffer buffer = ByteBuffer.allocate(myArray.length*Integer.BYTES);
buffer.order(ByteOrder.LITTLE_ENDIAN);
for (int x:myArray) buffer.putInt(x);
buffer.order(ByteOrder.BIG_ENDIAN);
buffer.rewind();
int i=0;
for (int x:myArray) myArray[i++] = buffer.getInt(x);
As eversor pointed out in the comments, ByteBuffer.putInt()
is an optional method, and may not be available on all Java implementations.
The DIY Approach
Stacker's answer is pretty neat, but it is possible to improve upon it.
reversed = (i&0xff)<<24 | (i&0xff00)<<8 | (i&0xff0000)>>8 | (i>>24)&0xff;
We can get rid of the parentheses by adapting the bitmasks. E. g., (a & 0xFF)<<8
is equivalent to a<<8 & 0xFF00
. The rightmost parentheses were not necessary anyway.
reversed = i<<24 & 0xff000000 | i<<8 & 0xff0000 | i>>8 & 0xff00 | i>>24 & 0xff;
Since the left shift shifts in zero bits, the first mask is redundant. We can get rid of the rightmost mask by using the logical shift operator, which shifts in only zero bits.
reversed = i<<24 | i>>8 & 0xff00 | i<<8 & 0xff0000 | i>>>24;
Operator precedence here, the gritty details on shift operators are in the Java Language Specification
Solution 3
Check this out
int little2big(int i) {
return (i&0xff)<<24 | (i&0xff00)<<8 | (i&0xff0000)>>8 | (i>>24)&0xff;
}
Solution 4
Java primitive wrapper classes support byte reversing since 1.5 using reverseBytes
method.
Short.reverseBytes(short i)
Integer.reverseBytes(int i)
Long.reverseBytes(long i)
Just a contribution for those who are looking for this answer in 2018.
Solution 5
I think this can also help:
int littleToBig(int i)
{
int b0,b1,b2,b3;
b0 = (i&0x000000ff)>>0;
b1 = (i&0x0000ff00)>>8;
b2 = (i&0x00ff0000)>>16;
b3 = (i&0xff000000)>>24;
return ((b0<<24)|(b1<<16)|(b2<<8)|(b3<<0));
}
Related videos on Youtube

name_masked
Primary programming languages: Java, C Inclined on learning: Python, Android app Development
Updated on January 26, 2021Comments
-
name_masked almost 2 years
All,
I have been practicing coding problems online. Currently I am working on a problem statement Problems where we need to convert Big Endian <-> little endian. But I am not able to jot down the steps considering the example given as:
123456789 converts to 365779719
The logic I am considering is :
1 > Get the integer value (Since I am on Windows x86, the input is Little endian)
2 > Generate the hex representation of the same.
3 > Reverse the representation and generate the big endian integer valueBut I am obviously missing something here.
Can anyone please guide me. I am coding in Java 1.5
-
Lawrence Dol about 12 yearsPerhaps clearer:
return((i<<24)+((i<<8)&0x00FF0000))+((i>>8)&0x0000FF00))+(i>>>24))
-
Lawrence Dol about 12 yearsAlso, this will switch little to big and big to little, so the method name is not broad enough. Perhaps swapEndian?
-
Lawrence Dol about 12 yearsAlso, I would use | instead of +, on the assumption that the use of bitwise or's is likely to be faster, and easier for the compiler/runtime to optimize.
-
Guido Tarsia over 11 yearsThat's more like a 4 byte number 27... 8 byte would be:
0x000000000000001B
-
Rinke over 10 yearsCaution: this is not correct! The 4th assignment should be
b3 = (i & 0xff000000) >>> 24
to fix it. Otherwise, if the most significant bit ofi
is 1 it will be copied into the most significant 24 bits of the returned result. -
Raúl Salinas-Monteagudo over 9 yearsI called it "int swapInt(int)"
-
Lisa almost 9 yearsBytes themselves are not endian except in nibble based machines/software, like the old IBM mainframes from an eternity ago. In that case one swaps the lower and upper 4-bits as if they were a hi-word and a lo-word.
-
eversor over 7 yearsNOTICE that ByteBuffer.putInt() is an optional method. You might run into trouble is some systems.
-
BullyWiiPlaza about 7 yearsThe definition of the library function
reverseBytes
is very similar:return ((i >>> 24) ) | ((i >> 8) & 0xFF00) | ((i << 8) & 0xFF0000) | ((i << 24));
-
Wolfram Schmied about 7 yearsGreat minds think alike. ;) All the more reason to use the library function, in case a compiler knows an even better way of implementing it. Specialized hardware might be available on some architecture, for example.
-
tjwrona1992 about 4 yearsI would upvote this a thousand times if I could... WAYYY too many people on the internet are trying to reinvent the wheel and I spent way too much time looking at bogus answers that do things much more complicated than necessary.