Java面试八股文详解

一、数据类型

1、Java的八种基本数据类型及其占用的字节数。

public class DataType {
    public static void main(String[] args) {
        System.out.println("byte占用字节数:" + Byte.BYTES);
        System.out.println("short占用字节数:" + Short.BYTES);
        System.out.println("int占用字节数:" + Integer.BYTES);
        System.out.println("long占用字节数:" + Long.BYTES);
        System.out.println("float占用字节数:" + Float.BYTES);
        System.out.println("double占用字节数:" + Double.BYTES);
        System.out.println("char占用字节数:" + Character.BYTES);
        System.out.println("boolean占用字节数:不固定");
    }
}

2、Java中的自动装箱、拆箱。

public class AutoBoxing {
    public static void main(String[] args) {
        Integer a = 1; // 自动装箱
        int b = a; // 自动拆箱
        System.out.println(a + b);
    }
}

3、字符串的不可变性以及String、StringBuilder、StringBuffer的区别。

public class StringDemo {
    public static void main(String[] args) {
        String a = "str";
        // String不可变性示例
        a = a + "ing";
        System.out.println(a);
        // StringBuilder、StringBuffer示例
        StringBuilder sb = new StringBuilder("str");
        sb.append("ing");
        System.out.println(sb.toString());
    }
}

二、集合

1、ArrayList、LinkedList、Vector的区别。

import java.util.ArrayList;
import java.util.LinkedList;
import java.util.Vector;

public class ListDemo {
    public static void main(String[] args) {
        ArrayList arrayList = new ArrayList();
        LinkedList linkedList = new LinkedList();
        Vector vector = new Vector();
        for (int i = 0; i < 1000000; i++) {
            arrayList.add(i);
            linkedList.add(i);
            vector.add(i);
        }
        long start = System.nanoTime();
        for (int i = 0; i < arrayList.size(); i++) {
            arrayList.get(i);
        }
        System.out.println("ArrayList遍历时间:" + (System.nanoTime() - start) + "ns");
        start = System.nanoTime();
        for (int i = 0; i < linkedList.size(); i++) {
            linkedList.get(i);
        }
        System.out.println("LinkedList遍历时间:" + (System.nanoTime() - start) + "ns");
        start = System.nanoTime();
        for (int i = 0; i < vector.size(); i++) {
            vector.get(i);
        }
        System.out.println("Vector遍历时间:" + (System.nanoTime() - start) + "ns");
    }
}

2、HashMap、ConcurrentHashMap的区别。

import java.util.HashMap;
import java.util.concurrent.ConcurrentHashMap;

public class MapDemo {
    public static void main(String[] args) {
        HashMap hashMap = new HashMap();
        ConcurrentHashMap concurrentHashMap = new ConcurrentHashMap();
        for (int i = 0; i < 1000000; i++) {
            hashMap.put(i, i);
            concurrentHashMap.put(i, i);
        }
        long start = System.nanoTime();
        for (int i = 0; i < 1000000; i++) {
            hashMap.get(i);
        }
        System.out.println("HashMap遍历时间:" + (System.nanoTime() - start) + "ns");
        start = System.nanoTime();
        for (int i = 0; i < 1000000; i++) {
            concurrentHashMap.get(i);
        }
        System.out.println("ConcurrentHashMap遍历时间:" + (System.nanoTime() - start) + "ns");
    }
}

3、集合的容器底层原理。

由于不同容器底层实现方式不同,这里就不一一列举了。

三、并发与多线程

1、Thread和Runnable的区别。

public class ThreadDemo extends Thread {
    @Override
    public void run() {
        System.out.println("继承Thread类创建线程");
    }
}
public class RunnableDemo implements Runnable {
    @Override
    public void run() {
        System.out.println("实现Runnable接口创建线程");
    }
}
public class Main {
    public static void main(String[] args) {
        ThreadDemo thread = new ThreadDemo();
        thread.start();
        RunnableDemo runnable = new RunnableDemo();
        new Thread(runnable).start();
    }
}

2、wait和sleep的区别。

public class WaitSleepDemo {
    private static final Object lock = new Object();

    public static void main(String[] args) {
        new Thread(() -> {
            synchronized (lock) {
                System.out.println(Thread.currentThread().getName() + "获取到锁");
                try {
                    lock.wait();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                System.out.println(Thread.currentThread().getName() + "获取到了锁,执行结束");
            }
        }, "wait").start();
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        new Thread(() -> {
            synchronized (lock) {
                System.out.println(Thread.currentThread().getName() + "获取到锁");
                try {
                    Thread.sleep(2000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                lock.notifyAll();
                System.out.println(Thread.currentThread().getName() + "执行notify操作");
            }
        }, "sleep").start();
    }
}

3、线程死锁及解决方案。

关于线程死锁的问题,一般可以采用如下策略进行解决:
1、避免一个线程同时获得多个锁。
2、避免一个线程在等待另外一个线程持有的锁时,自身抱持有的锁不释放。
3、使用定时锁,使用Lock.tryLock(timeout)来替代使用内部锁机制。
4、对于数据库锁,加锁和解锁要在同一个连接中完成。

四、JVM

1、JVM的内存结构及垃圾回收算法。

由于JVM内存结构较为复杂,这里只列举常见的垃圾回收算法:标记-清除算法、复制算法、标记-整理算法、分代收集算法。

2、Java内存模型及synchronized的实现原理。

public class SynchronizedDemo {
    public synchronized void method() {
        System.out.println("synchronized方法");
    }

    public void block() {
        synchronized (this) {
            System.out.println("synchronized代码块");
        }
    }
}

3、性能调优相关选项和工具,比如jconsole、jstack等。

在开发中,经常会遇到一些性能问题,这时可以使用jconsole、jstack等工具进行诊断。其中,jconsole主要用于监控和管理JVM,jstack主要用于查看Java虚拟机进程中的线程堆栈信息。

五、设计模式

1、常见的23种设计模式及应用场景。

这里不一一展开,可以参考《Head First设计模式》和《GOF设计模式》。

2、单例模式的实现。

public class Singleton {
    private static Singleton instance = null;

    private Singleton() {
    }

    public static synchronized Singleton getInstance() {
        if (instance == null) {
            instance = new Singleton();
        }
        return instance;
    }
}

3、工厂模式、抽象工厂模式的区别及应用场景。

工厂模式是最常用的设计模式之一,它提供了一种创建对象的方式,并且可以灵活地根据需要来选择实现类,同时也可以解决依赖关系。抽象工厂模式则是在工厂模式的基础上增加了一层抽象,通过接口的方式来解决实现类的迭代问题。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/300376.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-12-29 12:51
下一篇 2024-12-29 12:51

相关推荐

  • java client.getacsresponse 编译报错解决方法

    java client.getacsresponse 编译报错是Java编程过程中常见的错误,常见的原因是代码的语法错误、类库依赖问题和编译环境的配置问题。下面将从多个方面进行分析…

    编程 2025-04-29
  • Java JsonPath 效率优化指南

    本篇文章将深入探讨Java JsonPath的效率问题,并提供一些优化方案。 一、JsonPath 简介 JsonPath是一个可用于从JSON数据中获取信息的库。它提供了一种DS…

    编程 2025-04-29
  • Java腾讯云音视频对接

    本文旨在从多个方面详细阐述Java腾讯云音视频对接,提供完整的代码示例。 一、腾讯云音视频介绍 腾讯云音视频服务(Cloud Tencent Real-Time Communica…

    编程 2025-04-29
  • Java Bean加载过程

    Java Bean加载过程涉及到类加载器、反射机制和Java虚拟机的执行过程。在本文中,将从这三个方面详细阐述Java Bean加载的过程。 一、类加载器 类加载器是Java虚拟机…

    编程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介绍

    本文将详细介绍Java Milvus SearchParam withoutFields的相关知识和用法。 一、什么是Java Milvus SearchParam without…

    编程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java语言中的一个版本,于2014年3月18日发布。本文将从多个方面对Java 8中某一周的周一进行详细的阐述。 一、数组处理 Java 8新特性之一是Stream…

    编程 2025-04-29
  • Java判断字符串是否存在多个

    本文将从以下几个方面详细阐述如何使用Java判断一个字符串中是否存在多个指定字符: 一、字符串遍历 字符串是Java编程中非常重要的一种数据类型。要判断字符串中是否存在多个指定字符…

    编程 2025-04-29
  • VSCode为什么无法运行Java

    解答:VSCode无法运行Java是因为默认情况下,VSCode并没有集成Java运行环境,需要手动添加Java运行环境或安装相关插件才能实现Java代码的编写、调试和运行。 一、…

    编程 2025-04-29
  • Java任务下发回滚系统的设计与实现

    本文将介绍一个Java任务下发回滚系统的设计与实现。该系统可以用于执行复杂的任务,包括可回滚的任务,及时恢复任务失败前的状态。系统使用Java语言进行开发,可以支持多种类型的任务。…

    编程 2025-04-29
  • Java 8 Group By 会影响排序吗?

    是的,Java 8中的Group By会对排序产生影响。本文将从多个方面探讨Group By对排序的影响。 一、Group By的概述 Group By是SQL中的一种常见操作,它…

    编程 2025-04-29

发表回复

登录后才能评论