基本数据类型:

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 基本类型、封装类型、常量池、基本运算的更多相关文章

  1. Java堆、栈和常量池以及相关String的详细讲解(经典中的经典) (转)

    原文链接 : http://www.cnblogs.com/xiohao/p/4296088.html 一:在JAVA中,有六个不同的地方可以存储数据: 1. 寄存器(register). 这是最快的 ...

  2. Java堆、栈和常量池以及相关String的详细讲解

    一:在JAVA中,有六个不同的地方可以存储数据: 1. 寄存器(register). 这是最快的存储区,因为它位于不同于其他存储区的地方——处理器内部.但是寄存器的数量极其有限,所以寄存器由编译器根据 ...

  3. Java堆、栈和常量池以及相关String详解

    一:在JAVA中,有六个不同的地方可以存储数据: 1. 寄存器(register). 这是最快的存储区,因为它位于不同于其他存储区的地方——处理器内部.但是寄存器的数量极其有限,所以寄存器由编译器根据 ...

  4. Java堆、栈和常量池以及相关String的详细讲解(转)

    一:在JAVA中,有六个不同的地方可以存储数据: 1. 寄存器(register). 这是最快的存储区,因为它位于不同于其他存储区的地方——处理器内部.但是寄存器的数量极其有限,所以寄存器由编译器根据 ...

  5. JAVA字节码文件之常量池

    一.常量池的内容 一个java类中定义的很多信息都是由常量池来维护和描述的,可以将常量池看作是class文件的资源仓库,比如java类中定义的方法与变量信息.常量池中主要存储两类常量:字面量(文本字符 ...

  6. Java中的String与常量池[转帖]

    string是java中的字符串.String类是不可变的,对String类的任何改变,都是返回一个新的String类对象.下面介绍java中的String与常量池. 1. 首先String不属于8种 ...

  7. Java中的String与常量池

    string是java中的字符串.String类是不可变的,对String类的任何改变,都是返回一个新的String类对象.下面介绍java中的String与常量池. 1. 首先String不属于8种 ...

  8. 转载:Java中的String与常量池

    转载自http://developer.51cto.com/art/201106/266454.htm.感觉总结的不错,自己收藏一下. string是java中的字符串.String类是不可变的,对S ...

  9. (转)Java中的String与常量池

    Java中的String与常量池 转自:http://developer.51cto.com/art/201106/266454.htm string是java中的字符串.String类是不可变的,对 ...

  10. java基本类型和封装类型区别及应用

    1.基本类型只能按值传递,而每个基本类型对应的封装类是按引用传递的. 2.从性能上说java中的基本类型是在堆栈上创建的,而所有的对象类型都是在堆上创建的,(对象的引用在堆栈上创建).比如 Integ ...

随机推荐

  1. 第31课 std::atomic原子变量

    一. std::atomic_flag和std::atomic (一)std::atomic_flag 1. std::atomic_flag是一个bool类型的原子变量,它有两个状态set和clea ...

  2. EventBus原理解析

    前言 EventBus的核心思想是观察者模式 (生产/消费者编程模型) . SpringBoot+EventBus使用教程(一) SpringBoot+EventBus使用教程(二) 通过前面的文章我 ...

  3. Maven中的依赖相关总结

    一.Maven的依赖作用域scope compile:编译.测试.运行都会依赖,会打进包中. rumtime:不存于编译,后期运行和测试都会参与,会打进包中. test:只在test classpat ...

  4. react的模型:react是如何工作的?

    1.jsx:语法模型,语句构建模型: 2.组件:集合模型,组件管理: 3.vdom:分层模型.渲染管理模型: 4.flux:管道模型.数据模型,状态管理模型: 整体上是一个UI系统从上到下的构建: f ...

  5. com.fasterxml.jackson.core.JsonGenerationException: Can not write a field name, expecting a value异常

    springboot对象返回,一直报生成json异常,经过检查,发现是自己在做xss防护时对出参进行了json的处理(copy代码不可取,囧) 异常信息 这里进行了出参处理了,但实际上只要对入参处理就 ...

  6. 【linux】【windows】查看你想访问的电脑Ip 和 端口是否 通畅

    常用查看IP是否通畅: 使用ping命令 ping 117.173.218.23 既想看IP又想看端口:使用telnet命令 telnet 117.173.218.23 9000 注意格式!!!

  7. Caused by: java.lang.ClassCastException: org.springframework.web.SpringServletContainerInitializer cannot be cast to javax.servlet.ServletContainerInitializer。。。。。检查一下servlet-api是否冲突了?

    原因:jar包发生冲突.在我的pom.xml文件中 <dependency>      <groupId>javax.servlet</groupId>       ...

  8. java 动态代理 Proxy.newProxyInstance 使用心法

    使用JDk的Proxy类的静态方法newProxyInstance ,让JVM自动生成一个新的类,类中包含了inerfaces参数中的所有方法,每个方法都调用h.invoke 方法       AOP ...

  9. element admin中使用nprogress实现页面加载进度条

    主要是知道是nprogress这个组件实现的就可以了,组件的使用方法可参考:https://blog.csdn.net/ltr15036900300/article/details/47321217 ...

  10. 如何才能通俗易懂的解释js里面的‘闭包’?

    1. "闭包就是跨作用域访问变量." [示例一] var name = 'wangxi' function user () { // var name = 'wangxi' fun ...