持续总结中!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利用docx4j+Freemarker生成word文档

《Java利用docx4j+Freemarker生成word文档》这篇文章主要为大家详细介绍了Java如何利用docx4j+Freemarker生成word文档,文中的示例代码讲解详细,感兴趣的小伙伴... 目录技术方案maven依赖创建模板文件实现代码技术方案Java 1.8 + docx4j + Fr

SpringBoot首笔交易慢问题排查与优化方案

《SpringBoot首笔交易慢问题排查与优化方案》在我们的微服务项目中,遇到这样的问题:应用启动后,第一笔交易响应耗时高达4、5秒,而后续请求均能在毫秒级完成,这不仅触发监控告警,也极大影响了用户体... 目录问题背景排查步骤1. 日志分析2. 性能工具定位优化方案:提前预热各种资源1. Flowable

Python基础文件操作方法超详细讲解(详解版)

《Python基础文件操作方法超详细讲解(详解版)》文件就是操作系统为用户或应用程序提供的一个读写硬盘的虚拟单位,文件的核心操作就是读和写,:本文主要介绍Python基础文件操作方法超详细讲解的相... 目录一、文件操作1. 文件打开与关闭1.1 打开文件1.2 关闭文件2. 访问模式及说明二、文件读写1.

基于SpringBoot+Mybatis实现Mysql分表

《基于SpringBoot+Mybatis实现Mysql分表》这篇文章主要为大家详细介绍了基于SpringBoot+Mybatis实现Mysql分表的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录基本思路定义注解创建ThreadLocal创建拦截器业务处理基本思路1.根据创建时间字段按年进

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

Springboot @Autowired和@Resource的区别解析

《Springboot@Autowired和@Resource的区别解析》@Resource是JDK提供的注解,只是Spring在实现上提供了这个注解的功能支持,本文给大家介绍Springboot@... 目录【一】定义【1】@Autowired【2】@Resource【二】区别【1】包含的属性不同【2】@

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J