兩個int型和一個long型的轉換:spa
long now=1368257088802L;
int low = (int) (0xFFFFFFFFL & now);
int heigh = (int) ((0xFFFFFFFF00000000L & now) >> 32);
System.out.println("long轉雙int:"+heigh+","+low);three
long lowL=low;
long heighL=heigh;
long now2= ((long)lowL & 0xFFFFFFFFl) + (((long)heighL << 32) & 0xFFFFFFFF00000000l);
System.out.println("雙int轉long:"+now2);
System.out.println("now:"+now);
ByteBuffer buffer= ByteBuffer.allocate(100);
buffer.putLong(now);
buffer.flip();
long three=buffer.getInt();
long four=buffer.getInt();
System.out.println(three+","+four);
long now3=(((three<<32)&0xFFFFFFFF00000000l)+(four& 0xFFFFFFFFl));
System.out.println("高位+低位:"+now3);ip
Byte aa='\n';
System.out.println(aa);
int value=61156;
ByteBuffer byte_buffer= ByteBuffer.allocate(4);
byte_buffer.putInt(value);
byte_buffer.flip();
byte aa1=byte_buffer.get();
byte aa2=byte_buffer.get();
byte aa3=byte_buffer.get();//大於128的byte的補碼爲負值,小於128的byte爲正值
byte aa4=byte_buffer.get();
System.out.println(aa1+","+aa2+","+aa3+","+aa4);
int test=0;
test+=( aa1<<24 &0xFF000000);
test+=(aa2<<16 &0xFF0000);
// test+=(aa3<<8 & 0xFF00);//一直是正確的
// test+=(aa3 & 0xFF)<<8;//一直是正確的
test+=( aa3 <<8 );//當爲負值時,是錯誤的;只有爲正值是纔是正確的
test+=( aa4&0xFF) ;
System.out.println(test);
//轉換成二進制
System.out.println( Integer.toBinaryString(aa4 ) +","+aa4 );
System.out.println( Integer.toBinaryString(aa4 & 0xFF)+","+(aa4 & 0xFF) );
System.out.println("<---------------------分割線-------------------------->");
int test_byte=129;
byte byte_test=(byte)(test_byte);
System.out.println( Integer.toBinaryString(byte_test ) +","+byte_test );
System.out.println( Integer.toBinaryString(byte_test & 0xFF)+","+(byte_test & 0xFF) );
int temp=1;
if((byte_test & temp)>0)
{
System.out.println("---");
}
System.out.println("<---------------------分割線-------------------------->");
int a_255=128;
byte test_1=(byte)(a_255);
System.out.println("a_255:"+(test_1 &0xFF) );
System.out.println("a_255:"+(test_1 ) );get
我的備註:轉換後的二進制的表示數值的有效位是同樣的,高位是補碼的填充。test