Java 基本类型、封装类型、常量池、基本运算
基本数据类型:
byte:Java中最小的数据类型,在内存中占8位(bit),即1个字节,取值范围-128~127,默认值0
short:短整型,在内存中占16位,即2个字节,取值范围-32768~32717,默认值0
int:整型,用于存储整数,在内在中占32位,即4个字节,取值范围-2147483648~2147483647,默认值0
long:长整型,在内存中占64位,即8个字节-2^63~2^63-1,默认值0L
float:浮点型,在内存中占32位,即4个字节,用于存储带小数点的数字(与double的区别在于float类型有效小数点只有6~7位),默认值0
double:双精度浮点型,用于存储带有小数点的数字,在内存中占64位,即8个字节,默认值0
char:字符型,用于存储单个字符,占16位,即2个字节,取值范围0~65535,默认值为空
boolean:布尔类型,占1个字节,用于判断真或假(仅有两个值,即true、false),默认值false
封装类型:Byte、Short、Integer、Long、Float、Double、Character、Boolean
1.基本类型定义出来是普通变量,在栈中开辟内存,值是多少栈中就是多少。
2.除了单个基本数据类型,其他都是引用类型,数组(包括基本类型数组)、类等。
定义的时候,执行到“=”号都是在栈中;new之后就在堆中,栈里的内容类似指针但不是地址,指向堆,堆中的内容才是数值,堆自己也有一个地址。
3.封装类型在定义的时候需要赋值
int a;//基本类型可以不初始化
Integer b=new Integer(15);//封装类型需要初始化
double c1;
Double c2=new Double(11);
常量池:在堆中,可以理解成缓存数据,以后有需要的时候直接拿,不需要重新开内存。有缓存池的类是String,全开的。基本类型的封装类中,除了Double、Long、Float没有实现这个技术,其他都有缓存池,但是缓存池容纳的数据只有一个字节,即-128 - 127,超过这个范围就需要创建对象。
整型:为了避免多次创建对象,我们事先就创建好一个大小为256的Integer数组SMALL_VALUES,所以如果值在这个范围内,就可以直接返回我们事先创建好的对象就可以了。
浮点型:因为在范围内有很多小数,所以没有常量池。
装箱就是自动将基本数据类型转换为封装类型;拆箱就是自动将封装类型转换为基本数据类型。
基本运算
1.一条表达式混有多种类型,最后取最高的级别的类型
2.char类型的数据转换为高级类型(int,long等),会转换为其对应的ASCII码
3.使用+=时,不会产生类型转换
char x='A';
int p=3,z=x;
System.out.println(x+" "+p+" "+z);//A 3 65
x+=p;
System.out.println(x+" "+p+" "+z);//D 3 65
char和+=
4.强制转化,高精度变为低精度,会损失精度
5.“==”比较的是内存地址,“equals”比较的内容,两个内容相同的对象用“==”比较是不同的,因为内存地址不同;用“equals”比较则是相同的。对于封装类型,还要考虑是否有常量池数据,如果内容在常量池有,则没有创建新的对象,如果有new则明确创建了新的对象。
6.如果基本类型和封装类型进行+、-、×、÷、==的基本运算,是自动拆箱,对基础数据类型进行运算。
7.如果基本类型和封装类型用equals比较,是自动装箱,比较值。
String是实现常量池技术的类,用“==”测试比较
package my_acm;
import java.util.ArrayList;
public class MyTest6 {
public static void main(String []args) {
String s0="ab";
String s1="ab";
String s2="cd";
String s3="a"+"b";
String s4=new String("ab");
String s5=new String("cd");
String s6="abcd";
String s7=s1+s2;
String s8=s4+s5;
String s9=s6.intern();
//这个方法首先在常量池中查找是否存在一份equal相等的字符串如果有的话就返回该字符串的引用,没有的话就将它加入到字符串常量池中
String s10=new String("abcd");
System.out.println("s0 "+s0.hashCode()+" "+System.identityHashCode(s0));//3015 366712642
System.out.println("s1 "+s1.hashCode()+" "+System.identityHashCode(s1));//3105 366712642
System.out.println("s2 "+s2.hashCode()+" "+System.identityHashCode(s2));//3169 1829164700
System.out.println("s3 "+s3.hashCode()+" "+System.identityHashCode(s3));//3105 366712642
System.out.println("s4 "+s4.hashCode()+" "+System.identityHashCode(s4));//3105 2018699554
System.out.println("s5 "+s5.hashCode()+" "+System.identityHashCode(s5));//3169 1311053135
System.out.println("s6 "+s6.hashCode()+" "+System.identityHashCode(s6));//2987074 118352462
System.out.println("s7 "+s7.hashCode()+" "+System.identityHashCode(s7));//2987074 1550089733
System.out.println("s8 "+s8.hashCode()+" "+System.identityHashCode(s8));//2987074 865113938
System.out.println("s9 "+s9.hashCode()+" "+System.identityHashCode(s9));//2987074 118352462
System.out.println("s10 "+s10.hashCode()+" "+System.identityHashCode(s10));//2987074 1442407170
//理解成:System.identityHashCode(s0)方法返回的是内存地址,用于下面的==比较
System.out.println(s0 == s1);//t
System.out.println(s1 == s3);//t 常量池里自动拼接,相当于常量池里有ab、cd、abcd这3个常量
System.out.println(s1 == s4);//f
System.out.println(s6 == s7);//f
//在JAVA9中,因为用的是动态调用,所以返回的是一个新的String对象。所以s6和s7,s8,s10 不是同一块堆内存
System.out.println(s6 == s10);//f
System.out.println(s7 == s8);//f
System.out.println(s6 == s9);//t intern()方法使得s9的引用和s6一样
System.out.println(s8 == s10);//f
}
}
牛客刷题:
1.%取余运算
y=-12;x=-5;y%x=-2;
被除数=商*除数+余数 -12=2*(-5)+(-2);
减法 -12-(-5)-(-5)=-2;
2.无变量混合运算
小数都默认为double型
System.out.println(100%3);//1
System.out.println(100%3.0);//1.0 虚拟机对100转型为100.0的double类型,结果自然是1.0
Java 基本类型、封装类型、常量池、基本运算的更多相关文章
- Java堆、栈和常量池以及相关String的详细讲解(经典中的经典) (转)
原文链接 : http://www.cnblogs.com/xiohao/p/4296088.html 一:在JAVA中,有六个不同的地方可以存储数据: 1. 寄存器(register). 这是最快的 ...
- Java堆、栈和常量池以及相关String的详细讲解
一:在JAVA中,有六个不同的地方可以存储数据: 1. 寄存器(register). 这是最快的存储区,因为它位于不同于其他存储区的地方——处理器内部.但是寄存器的数量极其有限,所以寄存器由编译器根据 ...
- Java堆、栈和常量池以及相关String详解
一:在JAVA中,有六个不同的地方可以存储数据: 1. 寄存器(register). 这是最快的存储区,因为它位于不同于其他存储区的地方——处理器内部.但是寄存器的数量极其有限,所以寄存器由编译器根据 ...
- Java堆、栈和常量池以及相关String的详细讲解(转)
一:在JAVA中,有六个不同的地方可以存储数据: 1. 寄存器(register). 这是最快的存储区,因为它位于不同于其他存储区的地方——处理器内部.但是寄存器的数量极其有限,所以寄存器由编译器根据 ...
- JAVA字节码文件之常量池
一.常量池的内容 一个java类中定义的很多信息都是由常量池来维护和描述的,可以将常量池看作是class文件的资源仓库,比如java类中定义的方法与变量信息.常量池中主要存储两类常量:字面量(文本字符 ...
- Java中的String与常量池[转帖]
string是java中的字符串.String类是不可变的,对String类的任何改变,都是返回一个新的String类对象.下面介绍java中的String与常量池. 1. 首先String不属于8种 ...
- Java中的String与常量池
string是java中的字符串.String类是不可变的,对String类的任何改变,都是返回一个新的String类对象.下面介绍java中的String与常量池. 1. 首先String不属于8种 ...
- 转载:Java中的String与常量池
转载自http://developer.51cto.com/art/201106/266454.htm.感觉总结的不错,自己收藏一下. string是java中的字符串.String类是不可变的,对S ...
- (转)Java中的String与常量池
Java中的String与常量池 转自:http://developer.51cto.com/art/201106/266454.htm string是java中的字符串.String类是不可变的,对 ...
- java基本类型和封装类型区别及应用
1.基本类型只能按值传递,而每个基本类型对应的封装类是按引用传递的. 2.从性能上说java中的基本类型是在堆栈上创建的,而所有的对象类型都是在堆上创建的,(对象的引用在堆栈上创建).比如 Integ ...
随机推荐
- C# HTTP系列9 GET与POST示例
系列目录 [已更新最新开发文章,点击查看详细] 学习本篇之前,对 HttpWebRequest 与 HttpWebResponse 不太熟悉的同学,请先学习<C# HTTP系列>. ...
- .NET Core EF框架使用SQL server 2008数据库分页问题:Incorrect syntax near 'OFFSET'. Invalid usage of the option NEXT in the FETCH statement
一. 问题 最近.Net Core程序部署到服务器,采用EF6.本地数据库是SQL server 2016,服务器数据库安装的是SQL server 2008 R2,在用到分页查询时报错如下: { & ...
- docker搭建php环境
前言 本文根据参考文章,自己动手试了搭建PHP环境,对里面的Dockerfile的编写 做了最新的修改,以此记录,完整代码查看传送门 说明: 镜像下载过慢,可使用国内镜像加速,具体可自行查询 根据此方 ...
- (九)golang--标识符的命名规则
标识符的概念: (1)各种变量.方法等命名时使用的字符序列被称为标识符: (2)凡是可以自己起名字的都可以叫标识符: 标识符的命名规则: (1)由26个英文字母大小写,0-9,_组成 (2)数字不可以 ...
- Loj #3102. 「JSOI2019」神经网络
Loj #3102. 「JSOI2019」神经网络 题目背景 火星探险队发现,火星人的思维方式与人类非常不同,是因为他们拥有与人类很不一样的神经网络结构.为了更好地理解火星人的行为模式,JYY 对小镇 ...
- Windows环境安装PyQt5
目录 1. 安装Python 2. 安装Pycharm 3. 安装PyQt5 4. 安装PyQt5-tools 5. 可能出现的问题 1. Qt Designer 程序位置 2. Qt Designe ...
- UWP 使用Launcher 启动迅雷
不得不说UWP有些地方真的不方便! 另外也要夸一下迅雷,还是蛮不错的! 代码 await Launcher.LaunchUriAsync(new Uri("magnet:?xt") ...
- 【05】Kubernets:资源清单(控制器 - ReplicaSet)
写在前面的话 从上一章节开始,我们一直在学习关于自主式 Pod 的资源清单编写, 但是自主式 Pod 存在着一个问题,就是和我们直接 docker run 运行 docker 容器一样.如果我们想以集 ...
- java 精彩文章收集
hashCode() 和equals() 区别和作用 字符串常量池 Java集合之LinkedHashMap
- MSSQL 生成唯一自增数据的办法
我的应用场景是多进程并发获取这个计数,且要保证唯一且自增,我用的办法是锁表 计数表Counter,就一行数据 下面是存储过程 create procedure [dbo].[GetCount] AS ...