zoukankan      html  css  js  c++  java
  • [ZZ]byte[]到short、int、long的相互转换

    public final static byte[] getBytes(short s, boolean asc) 
    {
    	byte[] buf = new byte[2];
    	if (asc)
    		for (int i = buf.length - 1; i >= 0; i--) 
    		{
    			buf[i] = (byte) (s & 0x00ff);
    		  s >>= 8;
    		}
    	else
    		for (int i = 0; i < buf.length; i++) 
    		{
    			buf[i] = (byte) (s & 0x00ff);
    		  s >>= 8;
    		}
    	return buf;
    }
    
    public final static byte[] getBytes(int s, boolean asc) 
    {
    	byte[] buf = new byte[4];
    	if (asc)
    	  for (int i = buf.length - 1; i >= 0; i--) 
    	  {
    	    buf[i] = (byte) (s & 0x000000ff);
    	    s >>= 8;
    	  }
    	else
    	  for (int i = 0; i < buf.length; i++)
    	  {
    	    buf[i] = (byte) (s & 0x000000ff);
    	    s >>= 8;
    	  }
    	return buf;
    }
    
    public final static byte[] getBytes(long s, boolean asc) 
    {
    	byte[] buf = new byte[8];
    	if (asc)
    	  for (int i = buf.length - 1; i >= 0; i--) 
    		{
    	    buf[i] = (byte) (s & 0x00000000000000ff);
    	    s >>= 8;
    	  }
    	else
    	  for (int i = 0; i < buf.length; i++) 
    		{
    	    buf[i] = (byte) (s & 0x00000000000000ff);
    	    s >>= 8;
    	  }
    	return buf;
    }
    
    public final static short getShort(byte[] buf, boolean asc) 
    {
    	if (buf == null) 
    	{
    	  throw new IllegalArgumentException("byte array is null!");
    	}
    	if (buf.length > 2) 
    	{
    	  throw new IllegalArgumentException("byte array size > 2 !");
    	}
    	short r = 0;
    	if (asc)
    	  for (int i = buf.length - 1; i >= 0; i--) 
    		{
    	    r <<= 8;
    	    r |= (buf[i] & 0x00ff);
    	  }
    	else
    	  for (int i = 0; i < buf.length; i++) 
    		{
    	    r <<= 8;
    	    r |= (buf[i] & 0x00ff);
    	  }
    	return r;
    }
    
    public final static int getInt(byte[] buf, boolean asc) 
    {
    	if (buf == null) 
    	{
    	  throw new IllegalArgumentException("byte array is null!");
    	}
    	if (buf.length > 4) 
    	{
    	  throw new IllegalArgumentException("byte array size > 4 !");
    	}
    	int r = 0;
    	if (asc)
    	  for (int i = buf.length - 1; i >= 0; i--) 
    		{
    	    r <<= 8;
    	    r |= (buf[i] & 0x000000ff);
    	  }
    	else
    	  for (int i = 0; i < buf.length; i++) 
    		{
    	    r <<= 8;
    	    r |= (buf[i] & 0x000000ff);
    	  }
    	return r;
    }
    
    public final static long getLong(byte[] buf, boolean asc) 
    {
    	if (buf == null) 
    	{
    	  throw new IllegalArgumentException("byte array is null!");
    	}
    	if (buf.length > 8) 
    	{
    	  throw new IllegalArgumentException("byte array size > 8 !");
    	}
    	long r = 0;
    	if (asc)
    	  for (int i = buf.length - 1; i >= 0; i--) 
    		{
    	    r <<= 8;
    	    r |= (buf[i] & 0x00000000000000ff);
    	  }
    	else
    	  for (int i = 0; i < buf.length; i++) 
    		{
    	    r <<= 8;
    	    r |= (buf[i] & 0x00000000000000ff);
    	  }
    	return r;
    }
    

  • 相关阅读:
    LinkedHashMap、HashMap和TreeMap的比较使用
    RocketMQ之Namesrv
    mysql创建、删除、查看索引
    java8 JVM堆内存(heap) 新生代 老年代 元空间垃圾回收详解
    Java中GCRoots包括哪些
    单例模式双重校验锁
    内存屏障
    LockSupport的用法及原理
    HashSet,TreeSet和LinkedHashSet的区别
    Windows常用网络命令技巧汇总
  • 原文地址:https://www.cnblogs.com/pegasus923/p/1845866.html
Copyright © 2011-2022 走看看