当前位置: 首页 > news >正文

Java中的常用类 --String

学习目标

  1. 掌握String常用方法
  2. 掌握StringBuilder、StringBuffer
  3. 了解正则

1.String

● String是JDK中提前定义好的类型 其所在的包是java.lang ,String翻译过来表示字符串类型,也就是说String类中已经提前定义好了很多方法都是用来处理字符串的,所以String中常用的方法大家都要掌握;

先介绍下String 类的特点 :

  • String是不可变的类,也就是说String对象是不可变的对象,那么什么叫不可变的对象我们稍后给大家解释
  • 当给String引用重新赋值时, 执行的操作为: 在内存中创建一个新的字符串地址, 使引用指向新地址

1.1 层级

public final class String implements java.io.Serializable, Comparable<String>, CharSequence {}

1.2 创建方法和常用构造

两种创建方式

  1. 双引号直接赋值
  2. 利用构造创建
//双引号直接赋值
//String用法的一种特例String 引用名 = "值";

常用构造

String(byte[] bytes) //使用IDE里面默认的编码方式
String(byte[] bytes, Charset charset) 
String(byte[] bytes, String charsetName) 
String(byte[] bytes, int offset, int length)  
//将字节数组数据使用指定的编码方式转换(解码)一个字符串对象String(char[] value) 
String(char[] value, int offset, int count)         
//将字符数组数据转换成字符串对象String(StringBuffer buffer) String(StringBuilder builder)    

案例:字节数组转String

private static void demo1() {//乱码: 编码方法至少有2种存在  保证编码方式统一//创建String类对象String s = "hello";byte[] bytes = {-26, -120, -111, -28, -69, -84};//String str1 = new String(bytes,);//解码  将看不懂的字节的数据转换成字符串//String str1 = new String(bytes, StandardCharsets.UTF_8);//String str1 = new String(bytes, "UTF_8");String str1 = null;try {str1 = new String(bytes, "UTF-8");} catch (UnsupportedEncodingException e) {e.printStackTrace();}//使用的是哪一种编码格式?//获得当前ide里面默认的编码格式  Charset 维护所有编码格式的System.out.println(Charset.defaultCharset());System.out.println(str1);//鎴戜滑
}

案例:字符数组转String

private static void demo2() {//将字符数组转换成Stringchar[] chars = {97, 100, 'a', '1', '我'};String s = new String(chars);System.out.println(s);String s1 = new String(chars, 0, 3);System.out.println(s1);}

1.3 常用方法

1.3.1 与数组相关的方法

1.byte[] getBytes()  
2.byte[] getBytes(Charset charset)  
3.byte[] getBytes(String charsetName)  
//将字符串的数组转换成字节符数组  (与编码格式有关)----> 编码  4.char[] toCharArray()  //遍历字符数据
5.String[] split(String regex)  //分割  使用指定的字符串的数据对原字符串进行分割
6.String[] split(String regex, int limit)    //使用指定的正则模式分割字符串  

1.3.2 字符串搜索相关的方法

1. int	indexOf​(String str);//指定字符串第一次出现的索引位置  没有找到-1
2. int	indexOf​(String str, int fromIndex)//指定的索引开始  查询指定字符串第一次出现的索引位置  没有找到-13. int	lastIndexOf​(String str);// 指定字符串最后一次出现的索引位置  没有找到-1
4. int	lastIndexOf​(String str, int fromIndex);
// 指定的索引开始  查询指定字符串最后一次出现的索引位置  没有找到-1

1.3.3 提取字符串相关的方法

1.char charAt(int index)  //获得指定索引字符数据  index
private static void charatdemo() {String str = "hello";for (int index = 0; index < str.length(); index++) {System.out.println(str.charAt(index));}
}
2.String substring(int beginIndex)  //截取字符串   根据指定的索引截取原字符串部分数据
3.String substring(int beginIndex, int endIndex)  //包头不包尾
private static void substringdemo() {String filePath = "C:\\demo.\\a\\b\\a.txt";//查询最后一个\\的索引位置  lastIndexOf()String fileName = filePath.substring(filePath.lastIndexOf("\\")+1);System.out.println(fileName);//获得文件扩展名//文件上传  不同的用户传的文件名以及后缀都一样//A: C:\\a.jpg//B: D:\\a.jpg//上传到同一个目录---> 文件名重名的文件
//        System.currentTimeMillis()//System.out.println(UUID.randomUUID().toString());String extension = filePath.substring(filePath.lastIndexOf(".") + 1);System.out.println(extension);String str = "hello";System.out.println(str.substring(2, 4));//案例: 152****3456String phone = "15234567890";//长度固定的String begin = phone.substring(0,3);String end = phone.substring(7);String result = begin+"****"+end;System.out.println(result);
}
4.String toUpperCase()  //字母 转大写
5.String toLowerCase()  //字母 转小写
6.String trim() //去除空格String stripLeading()String stripTrailing()  
7.String concat(String str)  
8.static String join(CharSequence delimiter, CharSequence... elements) 
private static void demo12() {//模拟用户注册  将数据转换成:  id-name-pass-ageScanner input = new Scanner(System.in);int idIndex = 1001;System.out.println("录入name:");String name = input.next();System.out.println("录入pass:");String pass = input.next();System.out.println("录入age:");int age = input.nextInt();//将id name age pass 转换成指定格式//id-name-pass-age//String info = idIndex + "-" + name + "-" + pass + "-" + age;//System.out.println(info);//String concat(str)  类似+//String concat = String.valueOf(idIndex++).concat("-").concat(name).concat("+").concat(pass).concat("-").concat(String.valueOf(age));//String.join();String info = String.join("-", String.valueOf(idIndex), name, pass, String.valueOf(age));System.out.println(info);input.close();}
9.String repeat(int count)  

1.3.4 可变长参数

public static void main(String[] args) {//调用的时候 传递参数0个method();//调用的时候 传递多个参数method("aa", "bb");}/*** 如何定义可变长参数 任意数据类型...* 注意点:若方法中包含可变长参数,则必须出现在最后* 在方法内部,把可变长参数当成数组来进行使用* 调用的时候 可传值  0或多个都可以* @param a*/public static void method(String... a) {System.out.println(a);// 在方法内部,把可变长参数当成数组来进行使用System.out.println(a.length);System.out.println(Arrays.toString(a));}

1.3.5 比较判断方法相关的方法

1.int compareTo(String anotherString)  //比较2个字符串是否相等  返回值: 0 正整数 负整数2.int compareToIgnoreCase(String str) //不区分大小写比较2个字符串是否相等  返回值: 0 正整数 负整数 3.boolean contains(CharSequence s)  //判断字符串是否包含指定字符串
4.boolean equals(Object anObject)  //比较2个字符串是否相等
5.boolean equalsIgnoreCase(String anotherString)  //不区分大小写比较2个字符串是否相等6.boolean endsWith(String suffix)  //判断字符串是否以指定字符串结尾
7.boolean startsWith(String prefix)  //判断字符串是否以指定字符串开头8.boolean isEmpty()  //判断字符串是否是空 ""  length==09.boolean isBlank()  //判断字符串是否是空 ""  "   "  length==010.boolean matches(String regex)   

1.3.6 替换相关的方法

1.String replace(char oldChar, char newChar)  //使用指定的字符的数据替换原字符串里面指定的所有的字符
2.String replace(CharSequence target, CharSequence replacement)  //使用指定的字符串的数据替换原字符串里面指定的所有的字符串3.String replaceAll(String regex, String replacement)   
4.String replaceFirst(String regex, String replacement)     // 使用字符串替换满足正则语法模式要求的字符串的数据   

1.4 运行时常量池(串池)

● 字符串是使用的最频繁的类型,如果每次使用字符串对象,都用new关键字进行创建,那么堆内存中就会出现大量的字符串对象而占用大量堆空间;
● 为了提高JVM对字符串操作的内存使用率,JVM在方法区中提供了一块区域专门用于存储字符串字面量,这块区域位于方法区的运行时常量池;
● 当直接把字面量 赋值给字符串引用的时候, JVM会先去常量池中找这个字符串对象是否存在,如果存在直接返回此对象的地址 否则就会新建一个字符串对象 然后返回这个对象的内存地址;
● 如果+两边都是常量,查询规则还是先去常量池中找字符序列是否存在,如果存在直接返回地址 否则就新建对象;
● 如果+两边一旦有变量,拼接后的字符串对象是先存放在一个缓冲区中 并没有在常量池中

/*** 常量池 在方法区中 :里面放的是字符序列*/public static void method9() {String str1 = "java";// 如果存在字面量 直接返回地址String str2 = "java";String str3 = "javaSun";String str4 = "javaSun";String str5 = "java" + "Sun"; // 如果+两边都是常量,查询规则还是先去常量池中找字符序列是否存在,如果存在直接返回地址 否则就新建对象String str6 = str1 + "Sun"; //  如果+两边一旦有变量,拼接后的结果是存放在一个缓冲区中 没有在常量池中// new 都在堆空间/*String str3 = new String("java");String str4 = new String("java");*/System.out.println("equals1:" + (str1 == str2));
//        System.out.println("equals2 :" + (str1 == str3));System.out.println("+两边有常量了" + (str5 == str4));System.out.println("+两边有变量了" + (str6 == str4));}
  • intern(): 其功能可以做到 在运行期间 把字符对象放入常量池
private static void demo17() {//并发里面 充当锁对象String str1 = "hello";String intern1 = str1.intern();System.out.println(str1 == intern1);//trueString str2 = new String("hello");String intern2 = str2.intern();System.out.println(str1 == str2);//falseSystem.out.println(str2 == intern2);//falseSystem.out.println(str1 == intern2);//true
}

1.5 字符串不可变性

  • 对象内部的成员变量的值是不可变的因此是不可变的类型,使用final修饰了!

1.6 总结String两种创建方式的区别

  1. 双引号直接赋值: 直接使用串池. 先在串池中查找是否存在指定内容, 存在则直接指向, 不存在则先在串池中创建后指向
  2. 利用构造创建: 间接使用串池. 无论如何都会开辟对象空间, 再去串池中查找指定内容, 存在则直接存储串池地址, 不存在则先在串池中创建后存储该地址
		String str1 = "abc";String str2 = "abc";System.out.println(str1 == str2);//t 串池地址相同String s1 = new String("edf");String s2 = new String("edf");String str3 = "edf";System.out.println(s1 == s2);//f 对象地址不同System.out.println(s1 == str3);//f 对象地址 != 串池地址

在这里插入图片描述

2.StringBuffer/StringBuilder

  • StringBuffer/StringBuilder也是用来处理字符串的,因此方法和String方法非常类似;
  • 并非常量, 值可变
  • StringBuffer : JDK1.0 线程安全,效率低
  • StringBuilder :JDK5.0 线程不安全, 效率高
    这两个类的方法一模一样

2.1 层级

public final class StringBuilderextends AbstractStringBuilderimplements java.io.Serializable, Comparable<StringBuilder>, CharSequence{}public final class StringBufferextends AbstractStringBuilderimplements Serializable, Comparable<StringBuffer>, CharSequence{}

2.2 特点

  1. 不能使用串池

  2. 必须通过构造创建

  3. 必须调用方法操作字符串内容, 无法使用运算符

2.3 常用方法

   1. append(): 在末尾追加内容2. insert(index,str); 在指定的索引位置 插入字符串数据3. delete(startIndex,endIndex)  删除从startIndex到endIndex的字符串的数据  包头不包尾4. deleteCharAt(index) 删除指定索引的字符数据5. insert(index,str); 在指定的索引位置 插入字符串数据6. replace(startIndex,endIndex,newStr)  使用newStr替换从startIndex到endIndex的字符串的数据  包头不包尾7. reverse(): 内容反转

2.4 对比

类名值是否可变线程安全性能内存(拼接)
String不可变安全(final)其次+ new 占据更多内存
StringBuffer可变安全(synchronized)最后只有1个对象
StringBuilder可变不安全最快只有1个对象

2.5 与String的相互转换

  1. String 转 可变长字符串
 StringBuilder 引用名 = new StringBuilder(String引用名 | "值");
  1. 可变长字符串 转 String
   String 引用名 = StringBuilder引用名.toString();
		String str = "abc";//转为可变长字符串StringBuilder sb = new StringBuilder(str);//转StringString str2 = sb.toString();

当对String进行运算符操作时, 如+=, 会在底层中将其转换为StringBuilder完成操作, 再将StringBuilder转换回String

String s1 = "abcdefg";
String s2 = "abcd";s2 += "efg";//先将s2内容转换进StringBuilder, 在SB中完成拼接操作, 再转换回StringSystem.out.println(s1 == s2);//f//以下动作不会操作StringBuilderString str = "abc";str = "edf";str = "123"; 

3 正则表达式

能够读懂即可,一般在前端的js,校验数据。(判断用户客户端提交的数据是否满足正则要求)
● 后端编程语言 java也是支持正则匹配

3.1 概念

● 正则表达式,又称规则表达式,(Regular Expression,在代码中常简写为regex、regexp或RE),是一种文本模式,包括普通字符(例如,a 到 z 之间的字母)和特殊字符(称为"元字符"),是计算机科学的一个概念。
● 正则表达式使用单个字符串来描述、匹配一系列匹配某个句法规则的字符串,
● 通常被用来检索、替换那些符合某个模式(规则)的文本

String类的方法中: 支持正则编写。1.  String[] split(String regex,int limit); //根据正则模式要求分割源字符串的数据2.  boolean  matches(String regex); //检索/判断字符串的数据(文本数据)是否满足正则模式的要求。3.  String replaceAll(String regex,String replacement);//使用replacement替换原字符串中满足正则模式要求的文本数据String replaceFirst(String regex,String replacement);// 使用replacement替换原字符串中第一个满足正则模式要求的文本数据

3.2 语法

● 参考正则在线手册: https://tool.oschina.net/uploads/apidocs/jquery/regexp.html
语法: String regx = “^([]{})([]{})([]{})([]{})$”;
● ^:可以省略。以xxx开头。
● $:可以省略。以xxx结尾。
● (): 可以省略。代表的是一个组/域。简称域段。域和域之间没有关系的。正则模式里面: \n代表第n个域。从1开始。一般用于执行"替换功能"的时候,域段必须编写的。动态的获得第n个域里面的内容作为替换内容的话 $n
● []:可以省略。编写限定的字符数据。[a-zA-Z0-9_]{1}
● {}: 可以省略。 限定[]里面字符内容的次数。[ab]{1,3} {正整数}
● : 转义符号
: 匹配前面的子表达式零次或多次 [a]{0,} [a] a*
● +: 匹配前面的子表达式一次或多次 [a]{1,} a{1,} a+
● .: 匹配除“\n”之外的任何单个字符 [.]{1} 匹配任意一个字符
● x|y: 匹配x或y
● [xyz]: 匹配所包含的任意一个字符 [a-z]{1} [A-Z]{1} [0-9]{1} \d 等价于[0-9] \d{1}
● \s: 匹配的是空白字符 \s+ 匹配字符串里面出现>=1次的空格内容
● \w: 等价于[A-Za-z0-9_]

4.String方法汇总

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

5.StringBuilder方法总结

在这里插入图片描述

相关文章:

Java中的常用类 --String

学习目标 掌握String常用方法掌握StringBuilder、StringBuffer了解正则 1.String ● String是JDK中提前定义好的类型 其所在的包是java.lang ,String翻译过来表示字符串类型&#xff0c;也就是说String类中已经提前定义好了很多方法都是用来处理字符串的&#xff0c;所以Str…...

PWM(脉宽调制)技术详解:从基础到应用实践示例

PWM&#xff08;脉宽调制&#xff09;技术详解&#xff1a;从基础到应用实践示例 目录 PWM&#xff08;脉宽调制&#xff09;技术详解&#xff1a;从基础到应用实践示例学前思考&#xff1a;一、PWM概述二、PWM的基本原理三、PWM的应用场景四、PWM的硬件配置与使用五、PWM的编程…...

Hutool - DB 连接池配置集成

在实际开发中&#xff0c;尤其是在高并发场景下&#xff0c;使用连接池来管理数据库连接是非常必要的&#xff0c;它可以显著提高数据库操作的性能和效率。Hutool - DB 支持集成多种常见的连接池&#xff0c;如 HikariCP、Druid 等。下面分别介绍如何将这两种连接池集成到 Huto…...

激光工控机在自动化生产线中有什么关键作用?

激光工控机作为自动化生产线的核心设备&#xff0c;通过高精度控制、快速响应和智能化集成&#xff0c;在提升效率、保障质量、实现柔性制造等方面发挥着不可替代的作用。以下是其关键作用的具体分析&#xff1a; 一、实现高效连续生产&#xff1a; 1.高速加工能力&#xff1…...

Visual Studio Code的下载安装与汉化

1.下载安装 Visual Studio Code的下载安装十分简单&#xff0c;在本电脑的应用商店直接下载安装----注意这是社区版-----一般社区版就足够用了---另外注意更改安装地址 2.下载插件 重启后就是中文版本了...

nlp|微调大语言模型初探索(3),qlora微调deepseek记录

前言 上篇文章记录了使用lora微调llama-1b,微调成功,但是微调llama-8b显存爆炸,这次尝试使用qlora来尝试微调参数体量更大的大语言模型,看看64G显存的极限在哪里。 1.Why QLora? QLoRA 在模型加载阶段通过 4-bit 量化大幅减少了模型权重的显存占用。QLoRA 通过 反量化到 …...

【全栈】SprintBoot+vue3迷你商城-细节解析(1):Token、Jwt令牌、Redis、ThreadLocal变量

【全栈】SprintBootvue3迷你商城-细节解析&#xff08;1&#xff09;&#xff1a;Token、Jwt令牌、Redis、ThreadLocal变量 往期的文章都在这里啦&#xff0c;大家有兴趣可以看一下 后端部分&#xff1a; 【全栈】SprintBootvue3迷你商城&#xff08;1&#xff09; 【全栈】…...

基于ffmpeg+openGL ES实现的视频编辑工具(一)

在深入钻研音视频编辑开发这片技术海洋时&#xff0c;相信不少开发者都和我有同样的感受&#xff1a;网络上关于音视频编辑工具实现的资料繁多&#xff0c;理论阐释细致入微&#xff0c;代码片段也随处可见。然而&#xff0c;一个显著的缺憾是&#xff0c;缺乏一个完整成型的 A…...

面试完整回答:SQL 分页查询中 limit 500000,10和 limit 10 速度一样快吗?

首先&#xff1a;在 SQL 分页查询中&#xff0c;LIMIT 500000, 10 和 LIMIT 10 的速度不会一样快&#xff0c;以下是原因和优化建议&#xff1a; 性能差异的原因 LIMIT 10&#xff1a; 只需要扫描前 10 条记录&#xff0c;然后返回结果。 性能非常高&#xff0c;因为数据库只…...

Linux系统管理(十六)——通过WSL配置windows下的Linux系统(可视化界面与远程连接)

前言 WSL&#xff0c;即Windows Subsystem for Linux&#xff0c;是微软在Windows 10和Windows 11中引入的功能&#xff0c;允许用户在Windows上原生运行Linux的命令行工具和应用程序&#xff0c;无需启动完整的Linux虚拟机或进行双系统启动。 开启WSL服务 开启虚拟化 进入…...

【RabbitMQ业务幂等设计】RabbitMQ消息是幂等的吗?

在分布式系统中&#xff0c;RabbitMQ 自身不直接提供消息幂等性保障机制&#xff0c;但可通过业务逻辑设计和技术组合实现消息处理的幂等性。以下是 8 种核心实现方案及最佳实践&#xff1a; 一、消息唯一标识符 (Message Deduplication) 原理 每条消息携带全局唯一ID&#xff…...

flutter在安卓模拟器上运行

目录 下载android studio&#xff0c;然后把其中的模拟器设为环境变量&#xff0c;然后在vscode/cursor中使用插件&#xff0c;打开安卓模拟器一、下载android studio网址mac 下载64位 ARM 二、启动android studio三、设置SDK四、打开文件 打开模拟器五、运行程序六、在vscode/…...

linux shell 当命令执行出现错误立即退出的方法

在 Linux 脚本中&#xff0c;如果你想在整个脚本执行完毕后检查是否有错误发生&#xff0c;可以通过以下几种方式实现&#xff1a; 1. 使用 $? 检查上一条命令的退出状态 每个命令执行后&#xff0c;Shell 会将其退出状态存储在特殊变量 $? 中。$? 的值为 0 表示成功&#…...

与本地电脑PDF文档对话的PDF问答程序

文章目录 PDF问答程序程序流程处理PDF文档创建问答链 在探索和学习新技术时&#xff0c;了解LangChain框架的理论知识固然重要&#xff0c;但实际的案例分析与实践尝试能为你提供更加直观的认识和更深人的理解。本文主要以解析案例代码为主。通过具体的实践操作&#xff0c;你可…...

QT之改变鼠标样式

QT改变鼠标图片 资源路径如下 代码实现 QPixmap customCursorPixmap(":/images/mouse.png");QCursor customCursor(customCursorPixmap);QWidget::setCursor(customCursor); // 可以设置为整个窗口或特定控件QWidget::setCursor(); // 设置为透明光标&#xff0c…...

后端开发:开启技术世界的新大门

在互联网的广阔天地中&#xff0c;后端开发宛如一座大厦的基石&#xff0c;虽不直接与用户 “面对面” 交流&#xff0c;却默默地支撑着整个互联网产品的稳定运行。它是服务器端编程的核心领域&#xff0c;负责处理数据、执行业务逻辑以及与数据库和其他后端服务进行交互。在当…...

Sun-Panel:简洁且美观的导航首页开源项目!!

在这个数字化飞速发展的时代&#xff0c;我们几乎每个人都拥有自己的服务器或者NAS。但问题来了&#xff0c;管理这些设备往往需要记住一大堆复杂的命令和界面&#xff0c;对于像了不起这样追求简洁生活的程序员来说&#xff0c;简直是噩梦&#xff01; 今天介绍一款界面清爽&…...

第4章 信息系统架构(四)

4.6 网络架构 网络是信息技术架构中的基础&#xff0c;不仅是用户请求和获取IT信息资源服务的通道&#xff0c;同时也是 信息系统架构中各类资源融合和调度的枢纽。特别是云计算、大数据和移动互联网技术飞速发 展的今天&#xff0c;网络更加成为实现这些技术跨越的重要环节。…...

【Java八股文】07-Redis面试篇

【Java八股文】07-Redis面试篇 Redis面试篇认识redis为什么用 Redis 作为 MySQL 的缓存&#xff1f; 数据结构讲一下Redis底层的数据结构ZSet底层是由什么实现的 线程模型Redis 是单线程吗&#xff1f;Redis怎么进行I/O多路复用的&#xff1f;Redis 采用单线程为什么还这么快&a…...

Windows PyCharm的python项目移动存储位置后需要做的变更

项目使用的venv虚拟环境&#xff0c;因此项目移动存储位置后需要重新配置python解释器的位置&#xff0c;否则无法识别&#xff0c;若非虚拟环境中运行&#xff0c;则直接移动后打开即可&#xff0c;无需任何配置。 PyCharm版本为2021.3.3 (Professional Edition)&#xff0c;其…...

关于iview组件中使用 table , 绑定序号分页后序号从1开始的解决方案

问题描述&#xff1a;iview使用table 中type: "index",分页之后 &#xff0c;索引还是从1开始&#xff0c;试过绑定后台返回数据的id, 这种方法可行&#xff0c;就是后台返回数据的每个页面id都不完全是按照从1开始的升序&#xff0c;因此百度了下&#xff0c;找到了…...

Mac软件卸载指南,简单易懂!

刚和Adobe分手&#xff0c;它却总在Library里给你写"回忆录"&#xff1f;卸载的Final Cut Pro像电子幽灵般阴魂不散&#xff1f;总是会有残留文件&#xff0c;别慌&#xff01;这份Mac软件卸载指南&#xff0c;将用最硬核的方式教你"数字分手术"&#xff0…...

算法岗面试经验分享-大模型篇

文章目录 A 基础语言模型A.1 TransformerA.2 Bert B 大语言模型结构B.1 GPTB.2 LLamaB.3 ChatGLMB.4 Qwen C 大语言模型微调C.1 Fine-tuningC.2 Adapter-tuningC.3 Prefix-tuningC.4 P-tuningC.5 LoRA A 基础语言模型 A.1 Transformer &#xff08;1&#xff09;资源 论文&a…...

用鸿蒙HarmonyOS5实现中国象棋小游戏的过程

下面是一个基于鸿蒙OS (HarmonyOS) 的中国象棋小游戏的实现代码。这个实现使用Java语言和鸿蒙的Ability框架。 1. 项目结构 /src/main/java/com/example/chinesechess/├── MainAbilitySlice.java // 主界面逻辑├── ChessView.java // 游戏视图和逻辑├──…...

stm32wle5 lpuart DMA数据不接收

配置波特率9600时&#xff0c;需要使用外部低速晶振...

Java求职者面试指南:Spring、Spring Boot、Spring MVC与MyBatis技术解析

Java求职者面试指南&#xff1a;Spring、Spring Boot、Spring MVC与MyBatis技术解析 一、第一轮基础概念问题 1. Spring框架的核心容器是什么&#xff1f;它的作用是什么&#xff1f; Spring框架的核心容器是IoC&#xff08;控制反转&#xff09;容器。它的主要作用是管理对…...

鸿蒙HarmonyOS 5军旗小游戏实现指南

1. 项目概述 本军旗小游戏基于鸿蒙HarmonyOS 5开发&#xff0c;采用DevEco Studio实现&#xff0c;包含完整的游戏逻辑和UI界面。 2. 项目结构 /src/main/java/com/example/militarychess/├── MainAbilitySlice.java // 主界面├── GameView.java // 游戏核…...

简单介绍C++中 string与wstring

在C中&#xff0c;string和wstring是两种用于处理不同字符编码的字符串类型&#xff0c;分别基于char和wchar_t字符类型。以下是它们的详细说明和对比&#xff1a; 1. 基础定义 string 类型&#xff1a;std::string 字符类型&#xff1a;char&#xff08;通常为8位&#xff09…...

使用python进行图像处理—图像滤波(5)

图像滤波是图像处理中最基本和最重要的操作之一。它的目的是在空间域上修改图像的像素值&#xff0c;以达到平滑&#xff08;去噪&#xff09;、锐化、边缘检测等效果。滤波通常通过卷积操作实现。 5.1卷积(Convolution)原理 卷积是滤波的核心。它是一种数学运算&#xff0c;…...

Linux信号保存与处理机制详解

Linux信号的保存与处理涉及多个关键机制&#xff0c;以下是详细的总结&#xff1a; 1. 信号的保存 进程描述符&#xff08;task_struct&#xff09;&#xff1a;每个进程的PCB中包含信号相关信息。 pending信号集&#xff1a;记录已到达但未处理的信号&#xff08;未决信号&a…...