Java基础八股文

https://zhuanlan.zhihu.com/p/516271873

1.java八大基本数据类型

  • 6 种数字类型:
    • 4 种整数型:byte、short、int、long
    • 2 种浮点型:float、double
  • 1 种字符类型:char
  • 1 种布尔型:boolean。

2.基本类型和包装类型的区别

  • 成员变量包装类型不赋值就是 null ,而基本类型有默认值且不是 null。
  • 包装类型可用于泛型,而基本类型不可以。
  • 基本数据类型的局部变量存放在 Java 虚拟机栈中的局部变量表中,基本数据类型的成员变量(未被 static 修饰 )存放在 Java 虚拟机的堆中。包装类型属于对象类型,我们知道几乎所有对象实例都存在于堆中。
  • 相比于对象类型, 基本数据类型占用的空间非常小。

3.hashmap和treemap有什么区别

TreeMap 和HashMap 都继承自AbstractMap ,但是需要注意的是TreeMap它还实现了NavigableMap接口和SortedMap 接口。
实现 NavigableMap 接口让 TreeMap 有了对集合内元素的搜索的能力。
实现SortedMap接口让 TreeMap 有了对集合中的元素根据键排序的能力。默认是按 key 的升序排序,不过我们也可以指定排序的比较器。
综上,相比于HashMap来说 TreeMap 主要多了对集合中的元素根据键排序的能力以及对集合内元素的搜索的能力。

4.treemap底层数据结构是什么

treemap 底层的实现是基于红黑树的,它通过红黑树的自平衡性来保证 treemap 中的元素有序,并且支持高效的查找、插入和删除操作。
红黑树是一种自平衡二叉查找树,它具有以下性质:

  1. 每个节点要么是黑色,要么是红色。
  2. 根节点是黑色。
  3. 每个叶子节点都是黑色的空节点(NIL)。
  4. 如果一个节点是红色的,则它的子节点必须是黑色的。
  5. 对于每个节点,从该节点到其子孙节点的所有路径上包含相同数目的黑色节点。

红黑树通过维护这些性质来保证查找、插入和删除操作的时间复杂度都是 O(log n)。

5.ArrayList遍历的几种方式

  • 方法一:for (int i = 0; i < j; i++)
  • 方法二:Iterator
for (Iterator iterator = list.iterator(); iterator.hasNext(); ) {
            iterator.next();
        }
  • 方法三:增强for循环
  • 方法四:forEach

image.png

  • 方法五:stream().forEach

image.png

6.把list转换为树状结构

import java.util.ArrayList;
import java.util.List;

public class TreeNode {
    private String id;
    private String parentId;
    private String name;
    private List<TreeNode> children = new ArrayList<>();

    public TreeNode(String id, String parentId, String name) {
        this.id = id;
        this.parentId = parentId;
        this.name = name;
    }

    public void addChild(TreeNode child) {
        children.add(child);
    }

    public String getId() {
        return id;
    }

    public String getParentId() {
        return parentId;
    }

    public String getName
  • 1
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Java基础八股文面试题 1. Java的特点是什么? Java语言具有面向对象、跨平台、安全性、可靠性、可移植性、多线程等特点。 2. Java的基本数据类型有哪些? Java的基本数据类型包括整型、浮点型、字符型、布尔型。 3. Java中的变量命名规则是什么? Java中的变量命名规则是遵循驼峰命名法,即第一个单词小写,后面的每个单词首字母大写。 4. Java中的四种访问权限分别是什么? Java中的四种访问权限分别是public、private、protected、default。 5. Java中的final关键字有什么作用? Java中的final关键字用来修饰一个变量、一个方法或一个类,分别表示不可变、不可重写和不可继承。 6. Java中的抽象类和接口有什么区别? Java中的抽象类和接口都是用来实现多态性的机制,但是抽象类可以包含非抽象方法和属性,而接口只能包含抽象方法和常量。另外,一个类只能继承一个抽象类,但是可以实现多个接口。 7. Java中的异常处理机制是什么? Java中的异常处理机制是通过try-catch-finally代码块实现的,当程序发生异常时,会抛出一个异常对象,可以通过try-catch语句捕获并处理异常。 8. Java中的线程有哪些状态? Java中的线程有五种状态,分别是新建状态、就绪状态、运行状态、阻塞状态和死亡状态。 以上是Java基础八股文面试题的答案,希望能够帮助到您。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

想进阿里的小菜鸡

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值