Java tutorial
//package com.java2s; /* * Copyright (c) 2003 Objectix Pty Ltd All rights reserved. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation. * * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL OBJECTIX PTY LTD BE LIABLE FOR ANY * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ public class Main { /** * Get a double from the first 8 bytes of a byte array, * in either Big Endian or Little Endian format. * @param b the byte array * @param bigEndian is the byte array Big Endian? * @return the double */ public static final double getDouble(byte[] b, boolean bigEndian) { int i = 0; int j = 0; if (bigEndian) { i = getIntBE(b, 0); j = getIntBE(b, 4); } else { i = getIntLE(b, 4); j = getIntLE(b, 0); } long l = ((long) i << 32) | (j & 0x00000000FFFFFFFFL); return Double.longBitsToDouble(l); } /** * Get a Big Endian int from four bytes of a byte array * @param b the byte array * @param i the index of the first data byte in the array * @return the int */ public static final int getIntBE(byte[] b, int i) { return (b[i++] << 24) | ((b[i++] << 16) & 0x00FF0000) | ((b[i++] << 8) & 0x0000FF00) | (b[i] & 0x000000FF); } /** * Get a Little Endian int from four bytes of a byte array * @param b the byte array * @param i the index of the first data byte in the array * @return the int */ public static final int getIntLE(byte[] b, int i) { return (b[i++] & 0x000000FF) | ((b[i++] << 8) & 0x0000FF00) | ((b[i++] << 16) & 0x00FF0000) | (b[i] << 24); } }