持续总结中!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

相关文章

springboot集成easypoi导出word换行处理过程

《springboot集成easypoi导出word换行处理过程》SpringBoot集成Easypoi导出Word时,换行符n失效显示为空格,解决方法包括生成段落或替换模板中n为回车,同时需确... 目录项目场景问题描述解决方案第一种:生成段落的方式第二种:替换模板的情况,换行符替换成回车总结项目场景s

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏