Java核心技术之基本数据类型
这篇文章。我们讨论一些java的最主要的东西。这些东西我们一般刚刚学java的时候就学过,可是不一定真正明确。
正好,我在做一个读取内存的值,涉及到bit位的值的读取和写。那就能够讨论一个java的基本数据类型的值在机器的具体情况:
Java基本数据类型共同拥有八种三类:字符类型char,布尔类型boolean以及数值类型byte、short、int、long、float、double。
数值类型又能够分为整数类型byte、short、int、long和浮点数类型float、double。
Java决定了每种简单类型的大小。这些大小并不随着机器结构的变化而变化。这样的大小的不可更改正是Java程序具有非常强移植能力的原因之中的一个。
以下,我们就是要分析java基本数据类型的取值范围和占多少字节多少bit(1字节 = 8 bit)。
代码例如以下:
public class BaseDataInfo{
public static void main(String[] args) {
System.out.println("Boolean.FALSE:"+Boolean.FALSE);
System.out.println("Boolean.TRUE:"+Boolean.TRUE);
int maxByte = Byte.MAX_VALUE;
int minByte = Byte.MIN_VALUE;
int sizeByte = Byte.SIZE;
System.out.println("Byte.MAX_VALUE:"+maxByte);
System.out.println("Byte.MIN_VALUE:"+minByte);
System.out.println("Byte.SIZE:"+sizeByte);
int maxChar = Character.MAX_VALUE;
int minChar = Character.MIN_VALUE;
int sizeChar = Character.SIZE;
System.out.println("Character.MAX_VALUE:"+maxChar);
System.out.println("Character.MIN_VALUE:"+minChar);
System.out.println("Character.SIZE:"+sizeChar);
int maxShort = Short.MAX_VALUE;
int minShort = Short.MIN_VALUE;
int sizeShort = Short.SIZE;
System.out.println("Short.MAX_VALUE:"+maxShort);
System.out.println("Short.MIN_VALUE:"+minShort);
System.out.println("Short.SIZE:"+sizeShort);
int maxInt = Integer.MAX_VALUE;
int minInt = Integer.MIN_VALUE;
int sizeInt = Integer.SIZE;
int bitCount = Integer.bitCount(10);
System.out.println("Integer.MAX_VALUE:"+maxInt);
System.out.println("Integer.MIN_VALUE:"+minInt);
System.out.println("Integer.SIZE:"+sizeInt);
System.out.println("Integer.bitCount(1):"+bitCount);
long maxLong = Long.MAX_VALUE;
long minLong = Long.MIN_VALUE;
int sizeLong = Long.SIZE;
System.out.println("Long.MAX_VALUE:"+maxLong);
System.out.println("Long.MIN_VALUE:"+minLong);
System.out.println("Long.SIZE:"+sizeLong);
float maxFloat = Float.MAX_VALUE;
float minFloat = Float.MIN_VALUE;
int sizeFloat = Float.SIZE;
System.out.println("Float.MAX_VALUE:"+maxFloat);
System.out.println("Float.MIN_VALUE:"+minFloat);
System.out.println("Float.SIZE:"+sizeFloat);
Double maxDouble = Double.MAX_VALUE;
Double minDouble = Double.MIN_VALUE;
int sizeDouble = Double.SIZE;
System.out.println("Double.MAX_VALUE:"+maxDouble);
System.out.println("Double.MIN_VALUE:"+minDouble);
System.out.println("Double.SIZE:"+sizeDouble);
}
}
输出结果:
Boolean.FALSE:false
Boolean.TRUE:true
Byte.MAX_VALUE:127
Byte.MIN_VALUE:-128
Byte.SIZE:8
Character.MAX_VALUE:65535
Character.MIN_VALUE:0
Character.SIZE:16
Short.MAX_VALUE:32767
Short.MIN_VALUE:-32768
Short.SIZE:16
Integer.MAX_VALUE:2147483647
Integer.MIN_VALUE:-2147483648
Integer.SIZE:32
Integer.bitCount(1):2
Long.MAX_VALUE:9223372036854775807
Long.MIN_VALUE:-9223372036854775808
Long.SIZE:64
Float.MAX_VALUE:3.4028235E38
Float.MIN_VALUE:1.4E-45
Float.SIZE:32
Double.MAX_VALUE:1.7976931348623157E308
Double.MIN_VALUE:4.9E-324
Double.SIZE:64
从输出结果能够看出:
|
boolean |
仅仅有true和false两个取值 |
|
byte |
8位,最大存储数据量是255,存放的数据范围是-128~127之间 |
|
short |
16位,最大数据存储量是65536,数据范围是-32768~32767之间 |
|
int |
32位,最大数据存储容量是2的32次方减1,数据范围是负的2的31次方到正的2的31次方减1(也就是-2147483648~2147483647)。从int取值范围能够看。int适合20亿级别的整形数据。 |
|
long |
64位,最大数据存储容量是2的64次方减1,数据范围为负的2的63次方到正的2 的63次方减1(也就是-9223372036854775808~9223372036854775807)。 从long的取值范围能够看出。long适合海量级(亿亿级)的整形数据。 |
|
float |
32位,数据范围在3.4e-45~1.4e38。直接赋值时必须在数字后加上f或F。从float的取值范围能够看出,float适合e38级的float数据。 |
|
double |
64位,数据范围在4.9e-324~1.8e308,赋值时能够加d或D也能够不加。从double的取值范围能够看出,double适合e308的double数据。 |
|
char |
16位。存储Unicode码,用单引號赋值 |
|
基本数据类型 |
boolean |
byte |
char |
short |
int |
long |
float |
double |
|
bit位数 |
1 |
8 |
16 |
16 |
32 |
64 |
32 |
64 |
|
字节位数 |
0.125 |
1 |
2 |
2 |
4 |
8 |
4 |
8 |
|
封装类 |
Boolean |
Byte |
Character |
Short |
Integer |
Long |
Float |
Double |
參考资料:
Java基本数据类型总结
http://www.cnblogs.com/doit8791/archive/2012/05/25/2517448.html
Java核心技术之基本数据类型的更多相关文章
- java中的数据类型,运算符,字符串,输入输出,控制流,大数值,数组; 《java核心技术卷i》 第三章:java基本程序结构;
<java核心技术卷i> 第三章:java基本程序结构: 每次看书,去总结的时候,总会发现一些新的东西,这次对于java的数组有了更深的了解: java中的数据类型,运算符,字符串,输入输 ...
- 读《java核心技术卷一》有感
过去一个多月了吧.才囫囵吞枣地把这书过了一遍.话说这书也够长的,一共706页.我从来不是个喜欢记录的人,一直以来看什么书都是看完了就扔一边去,可能有时候有那么一点想记录下来的冲动,但算算时间太紧,很多 ...
- java的优点和误解 《java核心技术卷i》第一章
<java核心技术卷i>第一章主要内容包括三点: 1:Java白皮书的关键术语:描述Java的十一个关键字: 2:Java applet 3 :关于Java的常见误解 1:第一章:Ja ...
- (6)java基础知识-基本数据类型、数据类型转换
一.基本数据类型 基本的数据类型一共有四类八种 1.整型 byte: 1字节 取值范围 -128~127 short: 2字节 取值范围 -32768~32767 int: 4字节 取 ...
- java核心技术卷一
java核心技术卷一 java基础类型 整型 数据类型 字节数 取值范围 int 4 +_2^4*8-1 short 2 +_2^2*8-1 long 8 +_2^8*8-1 byte 1 -128- ...
- Java核心技术第八章-泛型
摘要 本文根据<Java核心技术 卷一>一书的第八章总结而成,部分文章摘抄书内,作为个人笔记. 文章不会过于深入,望读者参考便好. 为什么要使用泛型程序设计 泛型程序设计(Generic ...
- java核心技术(第十版卷一)笔记(纯干货!)
这是我读过的第三本关于java基础的书.第一本<<java从入门到精通>>这本书让我灵识初开.第二本<<java敏捷开发>>这本书则是有一次被一位师傅批 ...
- 2019 最新 Java 核心技术教程,都在这了!
Java技术栈 www.javastack.cn 优秀的Java技术公众号 以下是Java技术栈微信公众号发布的所有关于 Java 的技术干货,会从以下几个方面汇总,本文会长期更新. Java 基础篇 ...
- 面试必备!Java核心技术100+面试题
一线互联网公司工作了几年,我作为求职者参加了不少面试,也作为面试官面试了很多同学,整理这份面试指南,一方面是帮助大家更好的准备面试,有的放矢,另一方面也是对自己知识框架做一个体系化的梳理. 这篇文章梳 ...
随机推荐
- Git升级迁移
1 原有机器进行升级和备份: https://about.gitlab.com/update/#centos-6 1. Make a backup (Optional) If you would li ...
- Scala基础知识[一]
摘要:在Scala 是 Scalable Language 的简写,是一门多范式(multi-paradigm)的编程语言.设计初衷是要集成面向对象编程和函数式编程的各种特性.Scala 运行在Jav ...
- 刷题总结——教主的魔法(bzoj3343)
题目: Description 教主最近学会了一种神奇的魔法,能够使人长高.于是他准备演示给XMYZ信息组每个英雄看.于是N个英雄们又一次聚集在了一起,这次他们排成了一列,被编号为1.2.…….N. ...
- 算法复习——splay+启发式合并(bzoj2733-永无乡)
题目: Description 永无乡包含 n 座岛,编号从 1 到 n,每座岛都有自己的独一无二的重要度,按照重要度可 以将这 n 座岛排名,名次用 1 到 n 来表示.某些岛之间由巨大的桥连接,通 ...
- P1651 塔 (动态规划)
题目描述 小明很喜欢摆积木,现在他正在玩的积木是由N个木块组成的,他想用这些木块搭出两座高度相同的塔,一座塔的高度是搭建它的所有木块的高度和,并且一座塔至少要用一个木块.每个木块只能用一次,也可以不用 ...
- FreeMarker常用语法学习
1.API网址 http://freemarker.sourceforge.net/docs/ 2.一个Table的例子 freemarker 对表格的控制 这里将所有需要在一个区域显示到数据全部ad ...
- 前端开发之html篇
一.什么是html? 1.我们说socket网络编程的时候,提到过一个cs模型,就是客户端—服务端模型,前端开发也是基于网络编程,但是这时就应该是bs模型了,是浏览器与服务端的通信. 我们可以模拟一个 ...
- gulp 环境搭建
wind+r弹出cmd命令窗口 要先安装node及npm,检查是否安装成功,node -v,npm -v可查看nod及npm的版本号. 安装gulp之前我们需要安装nodejs的环境,检测能够正常使用 ...
- AC日记——砝码称重 洛谷 P2347
题目描述 设有1g.2g.3g.5g.10g.20g的砝码各若干枚(其总重<=1000), 输入输出格式 输入格式: 输入方式:a1 a2 a3 a4 a5 a6 (表示1g砝码有a1个,2g砝 ...
- 2017 ACM/ICPC 广西邀请赛 题解
题目链接 Problems HDOJ上的题目顺序可能和现场比赛的题目顺序不一样, 我这里的是按照HDOJ的题目顺序来写的. Problem 1001 签到 #include <bits/std ...