Java中的数是用补码表示的检验

一、基本介绍(关于下列五个定义来自http://www.cnblogs.com/zhangziqiu/archive/2011/03/30/ComputerCode.html#!comments,谢原博主分享)

什么是机器数:一个数在计算机中的二进制表示形式,  叫做这个数的机器数。机器数是带符号的,在计算机用一个数的最高位存放符号, 正数为0, 负数为1.比如,十进制中的数 +3 ,计算机字长为8位,转换成二进制就是00000011。如果是 -3 ,就是 10000011 。

什么是真值:因为第一位是符号位,所以机器数的形式值就不等于真正的数值。例如上面的有符号数 10000011,其最高位1代表负,其真正数值是 -3 而不是形式值131(10000011转换成十进制等于131)。所以,为区别起见,将带符号位的机器数对应的真正数值称为机器数的真值。

什么是原码:原码就是符号位加上真值的绝对值, 即用第一位表示符号, 其余位表示值。[+1] = 0000 0001;[-1] = 1000 0001。

什么是反码:正数的反码是其本身;负数的反码是在其原码的基础上, 符号位不变,其余各个位取反。[+1] = [00000001] = [00000001]反;[-1] = [10000001] = [11111110]反。

      什么是补码:正数的补码就是其本身;负数的补码是在其原码的基础上, 符号位不变, 其余各位取反, 最后+1。(即在反码的基础上+1)

二、检验

有如下代码:

1 package demo;
2 public class Bit {
3     public static void main(String[] args) {
4     int a=-11;
5     System.out.println(a>>1);
6
7     }
8
9 }

运行结果截图如下:

在这个程序中,我们用右移位运算来检验我们的Java中的数字表示方式。

A:若用原码表示。-11的机器数表示为[10001011]原,右移后表示为[11000101],十进制为-69,与正解-6不一样。所以不是用原码表示。

B:若用反码表示。-11的机器数表示为[11110100]反,右移后表示为[11111010]反,转换成原码为[10000101]原,十进制为-5,与正解-6不一样。所以不是用反码表示。

C:若用补码表示。-11的机器数表示为[11110101]补,右移后表示为[11111010]补,转换成补码为[111111001]反,再转换成原码为[100000110],十进制为-6,与正解-6一致。所以Java中的数是用原码表示的。

综上,Java中的数是用补码表示的。

 

时间: 2024-11-05 10:51:35

Java中的数是用补码表示的检验的相关文章

Java中唯一数的生成

唯一数的生成很简单,基本上以时间为基础进行生成.在JDK里面已经有java.util.UUID类可以生成唯一的随机数.如果希望生成的唯一数为特定的格式,那么就需要自己来生成唯一数了.生成唯一数时有两个因素是必须在考虑的: 必须保证唯一,这个一般以时间为基础进行变化. 高效,当然越高效越好. 有时我们希望在生成的唯一数中包含特定的内容,如把当前时间,如20110609132641,作为前缀等.以下片段供参考: 1 import java.util.Date; 2 3 4 public class

java中二进制反码补码的理解

7句真言 1,二进制最高位是符号位 0正数 1负数 2,正数的原码,反码,补码都一样 3负数的原码反码 补码 (符号位不变,其他的位数取反 0->1 1->0) 4 0的反码补码都是0 5java中没有无符号数,换句话说,java中的数都是有符号的 6计算机运算的时候,都是以补码的方式来运算的 7,负数的补码 = 他的反码+1

一些JAVA中有趣的面试题

这几天的JAVA培训课上,不断的唤醒自己对JAVA的理解(时间太长,大学学的快忘干净了),其中有一些很有趣的面试题,都是在抠JAVA细节(唉,我是那种见坑就往下跳的人,一做就错),下面就来分享一下: 1)用JAVA程序写出当你在超市购物花费1.1元时,你给收银员2元钱,收银员找你0.9元的过程: 当时一看题目,好简单啊!迅速写出: public class Sell{ public static void main(String[] args){ double total = 2.0; doub

JAVA中int、String的类型转换

int -> String int i=12345;String s="";第一种方法:s=i+"";第二种方法:s=String.valueOf(i);这两种方法有什么区别呢?作用是不是一样的呢?是不是在任何下都能互换呢? String -> int s="12345";int i;第一种方法:i=Integer.parseInt(s);第二种方法:i=Integer.valueOf(s).intValue();这两种方法有什么区别

java中字符串String 转 int(转)

java中字符串String 转 int String -> int s="12345"; int i; 第一种方法:i=Integer.parseInt(s); 第二种方法:i=Integer.valueOf(s).intValue(); 这两种方法有什么区别呢?作用是不是一样的呢?是不是在任何下都能互换呢? int -> String int i=12345; String s=""; 第一种方法:s=i+""; 第二种方法:s=

Java中int与String间的类型转换

int -> String int i=12345;String s=""; 除了直接调用i.toString();还有以下两种方法第一种方法:s=i+"";第二种方法:s=String.valueOf(i);这两种方法有什么区别呢?作用是不是一样的呢?是不是在任何下都能互换呢? String -> int s="12345";int i;第一种方法:i=Integer.parseInt(s);第二种方法:i=Integer.valu

java中string和int互相转化

1 怎样将字串 String 转换成整数 int? A. 有两个方法: 1). int i = Integer.parseInt([String]); 或 i = Integer.parseInt([String],[int radix]); 2). int i = Integer.valueOf(my_str).intValue(); 注: 字串转成 Double, Float, Long 的方法大同小异. 2 怎样将整数 int 转换成字串 String ? A. 有叁种方法: 1.) St

CompressedOops: Java中compressed references介绍

原文地址:http://blog.csdn.net/seatalks/article/details/52981819 在这篇文章中,我们来聊聊Compressed oops(压缩了的普通对象指针).它是JVM的优化技术之一.为什么要提出compressed oops的概念呢?那是因为32位与64位的架构不同导致的.接下来,我们先简单回顾下64位的架构特征,然后再进一步深入地来讨论compressed oops.最后,我们通过 一个小例子来观察它的作用.由于这个小例子十分简单,所以我们不用任何I

2017.4.18 java中string和int互相转化

1 如何将字串 String 转换成整数 int? A. 有两个方法: 1). int i = Integer.parseInt([String]); 或 i = Integer.parseInt([String],[int radix]); 2). int i = Integer.valueOf(my_str).intValue(); 注: 字串转成 Double, Float, Long 的方法大同小异. 2 如何将整数 int 转换成字串 String ? A. 有叁种方法: 1.) St