八股面试3(自用)

news/2024/10/18 18:54:46/

基本数据类型和引用数据类型区别

java中数据类型分为基本数据类型和引用数据类型

8大基本数据类型

1.整数:int,long,short,byte

2.浮点类型:float,double

3.字符类型:char

4.布尔类型:boolean

引用数据类型(除了8大基本数据类型就是引用类型)

类,接口类型,数组类型,枚举类型,注解类型,字符串String型

区别:

1.存储位置

基本数据类型存在栈中,引用数据类型存在堆中。

2.值传递与引用传递

对于基本数据类型,传递的是值本身,即当函数参数传递时,实际上是值的一个副本。函数内部的修改不会影响到原始变量。

对于引用数据类型,传递的是引用(即内存地址)。这意味着函数内部对引用数据的修改会影响到原始数据。 

3.生命周期

基本数据类型的生命周期与它们所在的代码块或作用域相关。一旦超出其作用域,其值将被销毁。

引用数据类型的生命周期由垃圾回收器管理。即使引用变量超出了作用域,只要堆内存中的对象仍然被引用,它们就不会被销毁。

final修饰的引用数据类型,值可以在构造器中二次修改吗

在Java中,final关键字不能修饰一个类,只能修饰方法或变量。虽然类也是引用数据类型,final可以修饰引用数据类型,但是不能修饰类。

final修饰的引用数据类型,值可以在构造器中二次修改

例如,当final修饰的是引用数据类型(如对象或数组)时,它意味着这个引用本身不能被改变,也就是说你不能让final引用指向另一个对象。但是,这并不妨碍你修改这个对象的内容。

public class Test {private final User user;public Test(User user) {this.user = user;// 这里你不能让user指向另一个User对象// this.user = anotherUser; // 这行代码会导致编译错误// 但是你可以修改user的内容user.setName("New Name");}
}class User {private String name;public User(String name) {this.name = name;}public void setName(String name) {this.name = name;}public String getName() {return name;}
}

jvm内存结构

1.堆区:这是Java虚拟机所管理的最大一块内存区域,几乎所有的对象实例和数组都将在这里分配内存。堆是垃圾收集器管理的主要区域,因此很多时候也被称为“GC堆”。从Java 8开始,字符串常量池也移动到了堆中。

2.栈区:每个线程在创建时都会创建一个虚拟机栈,其生命周期与线程相同。每一个方法执行的时候都会创建一个栈帧,用于存储局部变量表、操作数栈、动态链接、方法出口等信息。每一个方法被调用直至执行完成的过程,就对应着一个栈帧在虚拟机栈中入栈到出栈的过程。

3.方法区:也被称为非堆(Non-Heap),用于存储已被加载的类信息常量、静态变量、即时编译器编译后的代码等数据。虽然Java虚拟机规范把方法区描述为堆的一个逻辑部分,但它有一个别名叫做Non-Heap,目的是与Java堆区分开来。

4.程序计数器(就是写代码旁边显示的多少行):当前线程所执行的字节码的行号指示器。

5.本地栈

jvm堆栈区别

堆(Heap)

  • 堆是JVM中最大的内存区域,主要用于存储对象实例和数组。
  • 堆是垃圾收集器(GC)的主要管理区域。当对象不再被引用时,垃圾收集器会回收这部分内存。
  • 堆中的内存分配是动态的,即程序在运行时可以动态地创建和销毁对象。

栈(Stack)

  • 栈是线程私有的,每个线程都有一个自己的栈。
  • 栈用于存储方法的执行信息,包括局部变量表、操作数栈、动态链接等。
  • 栈的大小是固定的,每个线程的栈深度由JVM决定。
  • 栈的生命周期与线程相同,当线程结束时,栈也会销毁。

set能不能存null

 首先先明确,hashSet是基于hashMap实现的,又要明确hashMap和hashTable的区别

hashMap线程不安全hashTable线程安全,其实现方法里面都添加了synchronized关键字来确保线程同步。

hashMap可以使用null作为key,hashTable不允许null作为key,因此结合上述hashSet是基于hashMap实现的,所以,hashSet可以使用null作为key

索引过多对操作有什么影响

索引:提高检索效率,降低排序成本,索引对应的字段有自动排序的功能,默认升序

缺点

1.创建和维护索引需要耗时,并且随着数据量的增加而增加

2.索引需要占用物理空间,随数据量增加而增加

3.降低表的增删改的效率,每次增删改索引都需要进行动态维护

索引的适用场景:较为频繁的作为查询条件的字段

不适用的场景:

1.字段值的唯一性太差不适合做索引,即该字段的数据太多重复就不适合做索引

2.更新非常频繁的字段

3.不会作为查询条件(不会出现在where语句)不适合做索引

concurrentmap


http://www.ppmy.cn/news/1540058.html

相关文章

【实战篇】用SkyWalking排查线上[xxl-job xxl-rpc remoting error]问题

一、组件简介和问题描述 SkyWalking 简介 Apache SkyWalking 是一个开源的 APM(应用性能管理)工具,专注于微服务、云原生和容器化环境。它提供了分布式追踪、性能监控和依赖分析等功能,帮助开发者快速定位和解决性能瓶颈和故障。…

RK3588设计指导的学习(一)

华秋的计算工具也可以计算阻抗: 这一点倒是挺重要的:

nodejs 实现docker 精简可视化控制

地址 https://github.com/xiaobaidadada/filecat 说明 使用react 和nodejs 实现的非常轻量的服务docker管理。

第05-02节:Redis的十大数据类型

我的后端学习大纲 我的Redis学习大纲 6、地理空间(GEO)类型简介: 6.1.什么是GEO: 1.GEO主要是用于地理位置信息,并对存储的信息进行操作,包括: 添加地理位置的坐标获取地理位置的坐标计算两个…

C语言 | Leetcode C语言题解之第476题数字的补数

题目&#xff1a; 题解&#xff1a; class Solution { public:int findComplement(int num) {int pos;for (int i 30; i > 0; i--) {if (num & (1 << i)) {pos i;break;}}return (((1LL << (pos 1)) - 1) ^ (num));} };

缓存常见问题:缓存穿透、雪崩、击穿及解决方案分析

1. 什么是缓存穿透&#xff0c;怎么解决&#xff1f; 缓存穿透是指用户请求的数据在缓存中不存在即没有命中&#xff0c;同时在数据库中也不存在&#xff0c;导致用户每次请求该数据都要去数据库中查询一遍。如果有恶意攻击者不断请求系统中不存在的数据&#xff0c;会导致短时…

docker+mysql创建用户名密码_docker里面的mysql 更换密码

进入mysql容器 操作vi etc/mysql/my.cnf 默认是不安装vi编辑器的&#xff0c;下面安装vi 更新安装包 apt-get update 安装vim 执行这条语句 apt-get install vim 到修改docker容器里面的mysql数据库密码了 启动mysql容器 docker exec -it mysql /bin/bash 编辑配置文件 我这里是…

设计模式03-装饰模式(Java)

4.4 装饰模式 1.模式定义 不改变现有对象结构的情况下&#xff0c;动态地给该对象增加一些职责&#xff08;即增加其额外功能&#xff09;的模式。 2.模式结构 抽象构件角色 &#xff1a;定义一个抽象接口以规范准备接收附加责任的对象。客户端可以方便调用装饰类和被装饰类…