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/zh-hk/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

發表回復

登錄後才能評論