持续总结中!2024年面试必问 100 道 Java基础面试题(五十)

2024-05-16 13:52

本文主要是介绍持续总结中!2024年面试必问 100 道 Java基础面试题(五十),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

上一篇地址:持续总结中!2024年面试必问 100 道 Java基础面试题(四十九)-CSDN博客

九十九、请解释Java中的单例模式及其实现方式

单例模式(Singleton Pattern)是一种常用的软件设计模式,它确保一个类只有一个实例,并提供一个全局访问点来获取这个实例。单例模式在Java中的实现有多种方式,每种方式都有其特点和适用场景。

单例模式的特点:

  1. 单例类只能有一个实例:单例模式的核心是通过某种机制确保一个类只有一个实例被创建。
  2. 全局访问点:单例类提供了一个全局访问点,允许外部代码获取并使用这个唯一的实例。
  3. 线程安全:在多线程环境中,单例模式需要确保只有一个线程能够创建实例。

单例模式的实现方式:

  1. 懒汉式(线程不安全): 实现简单,但是线程不安全。只有当第一次调用getInstance()方法时,才会创建实例。

    public class Singleton {private static Singleton instance;private Singleton() {}public static Singleton getInstance() {if (instance == null) {instance = new Singleton();}return instance;}
    }
  2. 懒汉式(线程安全): 通过在getInstance()方法上加锁来保证线程安全。

    public class Singleton {private static Singleton instance;private Singleton() {}public static synchronized Singleton getInstance() {if (instance == null) {instance = new Singleton();}return instance;}
    }
  3. 饿汉式: 在类加载时就创建实例,简单且线程安全,但是可能导致资源浪费,因为不管需不需要,类加载时就完成实例化。

    public class Singleton {private static final Singleton instance = new Singleton();private Singleton() {}public static Singleton getInstance() {return instance;}
    }
  4. 双重检查锁定(Double-Checked Locking,DCL): 在第一次调用getInstance()方法时,先检查实例是否存在,如果不存在,则通过加锁来创建实例。这种方式既延迟了实例化,又避免了同步带来的性能影响。

    public class Singleton {private static volatile Singleton instance;private Singleton() {}public static Singleton getInstance() {if (instance == null) {synchronized (Singleton.class) {if (instance == null) {instance = new Singleton();}}}return instance;}
    }
  5. 静态内部类: 利用Java的类加载机制来实现线程安全的单例模式。

    public class Singleton {private Singleton() {}public static Singleton getInstance() {return SingletonHolder.INSTANCE;}static class SingletonHolder {private static final Singleton INSTANCE = new Singleton();}
    }
  6. 枚举单例: 使用Java枚举来实现单例,这是最简单的单例实现方式,也是线程安全的。

    public enum Singleton {INSTANCE;public void someMethod() {// 方法实现}
    }

注意事项:

  • 序列化:如果单例类实现了Serializable接口,需要提供readResolve()方法来保证反序列化时不会创建新的实例。
  • 反射:通过反射可以破坏单例的实例限制,因此在设计时需要考虑这一点。
  • 延迟加载:单例类通常使用延迟加载,即在第一次使用时才创建实例。

单例模式在实际应用中非常广泛,如配置管理器、连接池、线程池等。然而,单例模式也存在一些争议,如它可能使得单元测试变得困难,有时也会导致代码难以理解。因此,在决定使用单例模式时,需要权衡其优缺点。

一百、在Java中,如何使用正则表达式进行字符串匹配和处理?

在Java中,正则表达式(Regular Expression)用于描述字符串的模式,它可以用来检查一个字符串是否符合我们定义的模式、查找符合某个模式的字符串、替换或者分割字符串等。Java通过java.util.regex包提供了对正则表达式的全面支持。

正则表达式的基本概念:

  • 字符:正则表达式由普通字符(如字母、数字等)和特殊字符(如.*+等)组成。
  • 元字符:特殊字符在正则表达式中具有特殊含义,如.表示任意单个字符,*表示前面的字符可以出现零次或多次。

Java中使用正则表达式的主要类:

  1. Pattern:表示正则表达式的编译表示形式,是正则表达式编译后的结果。
  2. Matcher:用于将Pattern与输入字符串进行匹配的一个引擎,可以进行区域匹配。

字符串匹配和处理的基本步骤:

  1. 编译正则表达式:创建Pattern对象。
Pattern pattern = Pattern.compile("正则表达式字符串");
  1. 创建匹配器:使用Pattern对象的matcher()方法创建Matcher对象。
Matcher matcher = pattern.matcher("要匹配的字符串");
  1. 进行匹配:使用Matcher对象的find()方法进行查找,或者matches()方法进行整体匹配。
boolean found = matcher.find(); // 查找下一个匹配
boolean matches = matcher.matches(); // 整体匹配
  1. 替换文本:使用Matcher对象的replaceFirst()replaceAll()方法进行替换。
String replaced = matcher.replaceFirst("替换文本"); // 替换首次匹配的文本
String replacedAll = matcher.replaceAll("替换文本"); // 替换所有匹配的文本
  1. 分割文本:使用Pattern对象的split()方法进行分割。
String[] parts = pattern.split("要分割的字符串");

示例代码:

import java.util.regex.Pattern;
import java.util.regex.Matcher;public class RegexExample {public static void main(String[] args) {// 编译正则表达式Pattern pattern = Pattern.compile("\\d+"); // 匹配一个或多个数字// 创建匹配器并匹配字符串String text = "There are 123 apples and 456 oranges";Matcher matcher = pattern.matcher(text);// 查找并输出所有匹配的数字while (matcher.find()) {System.out.println(matcher.group()); // 输出匹配的子串}// 替换所有匹配的数字为"XXX"String replacedText = matcher.replaceAll("XXX");System.out.println(replacedText);// 使用正则表达式分割字符串String[] words = pattern.split(text);System.out.println(java.util.Arrays.toString(words));}
}

注意事项:

  • 性能:对于复杂的正则表达式或长字符串,性能可能是个问题。在可能的情况下,尽量使用简单的正则表达式。
  • 异常:错误的正则表达式格式会抛出PatternSyntaxException
  • 模式匹配:正则表达式匹配是区分大小写的,如果需要进行不区分大小写的匹配,可以使用Pattern.CASE_INSENSITIVE标志。
  • 分组:正则表达式中的括号()表示分组,可以用来捕获匹配的子串。

正则表达式是处理字符串的强大工具,通过Java的PatternMatcher类,我们可以方便地在程序中使用正则表达式进行复杂的字符串匹配和处理。

这篇关于持续总结中!2024年面试必问 100 道 Java基础面试题(五十)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/995092

相关文章

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

Java判断多个时间段是否重合的方法小结

《Java判断多个时间段是否重合的方法小结》这篇文章主要为大家详细介绍了Java中判断多个时间段是否重合的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录判断多个时间段是否有间隔判断时间段集合是否与某时间段重合判断多个时间段是否有间隔实体类内容public class D

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

Java中ArrayList和LinkedList有什么区别举例详解

《Java中ArrayList和LinkedList有什么区别举例详解》:本文主要介绍Java中ArrayList和LinkedList区别的相关资料,包括数据结构特性、核心操作性能、内存与GC影... 目录一、底层数据结构二、核心操作性能对比三、内存与 GC 影响四、扩容机制五、线程安全与并发方案六、工程

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

Spring AI集成DeepSeek的详细步骤

《SpringAI集成DeepSeek的详细步骤》DeepSeek作为一款卓越的国产AI模型,越来越多的公司考虑在自己的应用中集成,对于Java应用来说,我们可以借助SpringAI集成DeepSe... 目录DeepSeek 介绍Spring AI 是什么?1、环境准备2、构建项目2.1、pom依赖2.2