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

【JavaSE】认识String类,了解,进阶到熟练掌握

#1024程序员节 | 征文#

下面就让博主带领大家一起解决心中关于String类的疑问吧~~~

1.字符串构造:

第一种和第二种(有一定的区别,在常量池上)

public static void main(String[] args) {
// 使用常量串构造
String s1 = "hello";
System.out.println(s1);// 直接newString对象
String s2 = new String("hello");
System.out.println(s1);// 使用字符数组进行构造
char[] array = {'h','e','l','l','o'};
String s3 = new String(array);
System.out.println(s1);
}

其他方法需要用到时,大家参考Java在线文档:

String类在线文档

每个成员里面都有这两个变量

两个String方法

1:和数组的长度属性array.length不一样,String的s1.length()是一个方法

2:isEmpty是判断字符串长度是否为0;要是空指针可就要报空指针异常了

public class StringTest {public static void main(String[] args) {
// s1和s2引用的是不同对象 s1和s3引用的是同一对象String s1 = new String("hello");String s2 = new String("world");String s3 = s1;System.out.println(s1.length()); // 获取字符串长度---输出5System.out.println(s1.isEmpty()); // 如果字符串长度为0,返回true,否则返回falseString s4 = null;
//        System.out.println(s4.isEmpty());}
}

这样获得长度也可以

// 打印"hello"字符串(String对象)的长度
System.out.println("hello".length());

2:String对象的比较

2.1:equals比较以及常量池的一些知识

        public static void main(String[] args) {String s1 = new String("hello");String s2 = new String("hello");String s3 = new String("Hello");
// s1、s2、s3引用的是三个不同对象,因此==比较结果全部为falseSystem.out.println(s1 == s2); // falseSystem.out.println(s1 == s3); // false
//String类重写了equals方法,只要内容一样就相等System.out.println("===============================");System.out.println(s1.equals(s2)); // trueSystem.out.println(s1.equals(s3)); // falseSystem.out.println("===============================");
//但是这么比较呢?String s4 = "hello";String s5 = "hello";System.out.println("===============================");}

这就不得不涉及到常量池的概念了(现在只能懵懂的了解一下);

2.2:int compareTo(String s) 方法: 按照字典序进行比较

与equals不同的是,equals返回的是boolean类型,而compareTo返回的是int类型。具体比较方式:

1. 先按照字典次序大小比较,如果出现不等的字符,直接返回这两个字符的大小差值

2. 如果前k个字符相等(k为两个字符长度最小值),返回值两个字符串长度差值

(一个字符大小差值,一个长度差值)

​
public static void main(String[] args) {
String s1 = new String("abc");
String s2 = new String("ac");
String s3 = new String("ABc");
String s4 = new String("abcdef");
System.out.println(s1.compareToIgnoreCase(s2)); // 不同输出字符差值-1
System.out.println(s1.compareToIgnoreCase(s3)); // 相同输出 0
System.out.println(s1.compareToIgnoreCase(s4)); // 前k个字符完全相同,输出长度差值 -3
}

2.3:int compareToIgnoreCase(String str) 方法:

与compareTo方式相同,但是忽略大小写比较

public static void main(String[] args) {
String s1 = new String("abc");
String s2 = new String("ac");
String s3 = new String("ABc");
String s4 = new String("abcdef");
System.out.println(s1.compareToIgnoreCase(s2)); // 不同输出字符差值-1
System.out.println(s1.compareToIgnoreCase(s3)); // 相同输出 0
System.out.println(s1.compareToIgnoreCase(s4)); // 前k个字符完全相同,输出长度差值 -3
}

3. 字符串查找:

字符串查找也是字符串中非常常见的操作,String类提供的常用查找的方法

方法功能

char charAt(int index)

返回index位置上字符,如果index为负数或者越界,抛出

IndexOutOfBoundsException异常

int indexOf(int ch)

返回ch第一次出现的位置,没有返回-1

int indexOf(int ch, int

fromIndex)

从fromIndex位置开始找ch第一次出现的位置,没有返回-1

int indexOf(String str)

返回str第一次出现的位置,没有返回-1

int indexOf(String str, int

fromIndex)

从fromIndex位置开始找str第一次出现的位置,没有返回-1

int lastIndexOf(int ch)

从后往前找,返回ch第一次出现的位置,没有返回-1

int lastIndexOf(int ch, int

fromIndex)

从fromIndex位置开始找,从后往前找ch第一次出现的位置,没有返

回-1

int lastIndexOf(String str)

从后往前找,返回str第一次出现的位置,没有返回-1

int lastIndexOf(String str, int

fromIndex)

从fromIndex位置开始找,从后往前找str第一次出现的位置,没有返

回-1

4:转换

4.1.字符串和数字转化:

        public static void main(String[] args) {// 数字转字符串String s1 = String.valueOf(1234);String s2 = String.valueOf(12.34);String s3 = String.valueOf(true);String s4 = String.valueOf(new Student("lisi", 18));System.out.println(s1);System.out.println(s2);System.out.println(s3);System.out.println(s4);System.out.println("=================================");
// 字符串转数字
// 注意:Integer、Double等是Java中的包装类型,这个后面会讲到int data1 = Integer.parseInt("1234");double data2 = Double.parseDouble("12.34");System.out.println(data1);System.out.println(data2);}

String类对于这些转换字符串的方法进行了重载处理:

4.2. 大小写转换

public static void main(String[] args) {
String s1 = "hello";
String s2 = "HELLO";
// 小写转大写
System.out.println(s1.toUpperCase());
// 大写转小写
System.out.println(s2.toLowerCase());
}

4.3.字符串和数组的转换:
 

public static void main(String[] args) {String s = "hello";
// 字符串转数组char[] ch = s.toCharArray();for (int i = 0; i < ch.length; i++) {System.out.print(ch[i]);}System.out.println();
// 数组转字符串String s2 = new String(ch);//或者(你俩不太一样)String s3 = Arrays.toString(ch);System.out.println(s2);System.out.println(s3);}

4.4:格式化输入字符串

public static void main(String[] args) {
String s = String.format("%d-%d-%d", 2019, 9,14);
System.out.println(s);
}

4.5:字符串替换

使用一个指定的新的字符串替换掉已有的字符串数据,可用的方法如下:

方法功能

String replaceAll(String regex, String replacement)

替换所有的指定内容

String replaceFirst(String regex, String replacement)

替换首个内容

        String str = "abbbbbababab" ;System.out.println(str.replaceAll("ab", "++"));
//这个替换也是,不是在原有的基础上进行替换,而是产生了新的对象System.out.println(str.replaceFirst("ab", "=="));

注意事项: 由于字符串是不可变对象, 替换不修改当前字符串, 而是产生一个新的字符串

4.6:字符串拆分

可以将一个完整的字符串按照指定的分隔符划分为若干个子字符串。

可用方法如下:

方法功能

String[] split(String regex)

将字符串全部拆分

String[] split(String regex, int limit)

将字符串以指定的格式,拆分为limit组

        String str = "hello world hello" ;String[] result = str.split(" ") ; // 按照空格拆分for(String s: result) {System.out.println(s);}

将字符串以指定的格式,拆分为limit组

String str = "hello world hello bit" ;
String[] result = str.split(" ",2) ;
for(String s: result) {
System.out.println(s);
}

拆分是特别常用的操作. 一定要重点掌握. 另外有些特殊字符作为分割符可能无法正确切分, 需要加上转义.

代码示例: 拆分IP地址

public static void main(String[] args) {String str = "192.168.11" ;String[] result = str.split("\\.") ;for(String s: result) {System.out.println(s);}}

注意事项:

1. 字符"|","*","+"都得加上转义字符,前面加上 "\\" .

2. 而如果是 "\" ,那么就得写成 "\\\\" .

3. 如果一个字符串中有多个分隔符,可以用"|"作为连字符.

代码示例: 多次拆分

//多次拆分public static void main(String[] args) {String s1 = "zhnagsan=18&lisi=19";String []ret = s1.split("&");for (int i = 0; i < ret.length; i++) {//result.length的长度为2String []ret1 =ret[i].split("=");//第一次的字符串为zhangsan=18for (int j = 0; j < ret1.length; j++) {System.out.println(ret1[j]);//每一次拆开的两部分打印出来}}}

4.7:字符串截取

从一个完整的字符串之中截取出部分内容。可用方法如下

区间:左闭右开

方法功能

String substring(int beginIndex)

从指定索引截取到结尾

String substring(int beginIndex, int endIndex)

截取部分内容

//区间截取public static void main(String[] args) {String str = "helloworld" ;System.out.println(str.substring(5));System.out.println(str.substring(0, 1));}

如果截取的长度为整个字符串的长度(0,array.length)返回的是原地址

public class previewTest {public static void main(String[] args) {String s = "hello";String s1 = s.substring(0);String s2 = s.substring(0,5);System.out.println(s.hashCode());System.out.println(s1.hashCode());System.out.println(s2.hashCode());}
}

大家可以看到是三个的哈希值都是一样的

4.8:去掉字符串中的左右空格,保留中间空格

变成了一个新的字符串(但是如果不需要去除空格制表符,换行等,还是本来的引用)

 public static void main(String[] args) {String str = "          hello   world            " ;System.out.println(str.trim());}

trim 会去掉字符串开头和结尾的空白字符(空格, 换行, 制表符等).

5:字符串的不可变性

譬如:

public static void main(String[] args) {

final int array[] = {1,2,3,4,5};

array[0] = 100;

System.out.println(Arrays.toString(array));

// array = new int[]{4,5,6}; // 编译报错:Error:(19, 9) java: 无法为最终变量array分配值

// 被final修饰了,array这个引用就不能指向其他数组了!!!!

}

那如果我们要修改字符串的内容,要怎么修改呢?

6:修改字符串(效率高点)

注意:尽量避免直接对String类型对象进行修改,因为String类是不能修改的,所有的修改都会创建新对象,效率非常低下。

譬如直接修改的话:
 

public static void main(String[] args) {
String s = "hello";
s += " world";
System.out.println(s); // 输出:hello world
}

我们编译一下,我们要先build一下生成一个字节码文件

然后cmd

我们发现

竟然有两次StringBuild,还有append,这都是怎么回事呢?

实际上,上面hello加上world可以分为以下几步

public class StringTest {public static void main(String[] args) {String s = "hello";StringBuilder stringBuilder = new StringBuilder();stringBuilder.append(s);stringBuilder.append("world");s = stringBuilder.toString();System.out.println(s); // 输出:hello world}
}

对于StringBuild这个类里面的方法都是在原有的对象上直接进行更改,并不会创建新的对象

我们可以测试一下

进行字符串的加法,对于String,StringBuffer以及StringBuild三者所需要的时间

 public static void main(String[] args) {long start = System.currentTimeMillis();//计算开始的时间String s = "";for(int i = 0; i < 10000; ++i){s += i;}long end = System.currentTimeMillis();//计算结束的时间System.out.println(end - start);//完成这个加法所需要的时间start = System.currentTimeMillis();StringBuffer sbf = new StringBuffer("");//用StringBuffer,不改变对象for(int i = 0; i < 10000; ++i){sbf.append(i);}end = System.currentTimeMillis();System.out.println(end - start);start = System.currentTimeMillis();//用StringBuild,不改变对象StringBuilder sbd = new StringBuilder();for(int i = 0; i < 10000; ++i){sbd.append(i);}end = System.currentTimeMillis();System.out.println(end - start);}

很显然,后二者都比String快了不止一星半点

可以看出在对String类进行修改时,效率是非常慢的,因此:尽量避免对String的直接需要,如果要修改建议尽量使用StringBuffer或者StringBuilder。

7:StringBuffer以及StringBuild

由于String的不可更改特性,为了方便字符串的修改,Java中又提供StringBuilder和StringBuffer类。这两个类大 部分功能是相同的,这里介绍 StringBuilder常用的一些方法,其它需要用到了大家可参阅 

public static void main(String[] args) {

StringBuilder sb1 = new StringBuilder("hello");

StringBuilder sb2 = sb1;

// 追加:即尾插-->字符、字符串、整形数字

sb1.append(' '); // hello

sb1.append("world"); // hello world

sb1.append(123); // hello world123

每一次append都是在原来的对象上面添加字符,只是对象的内容可以改变,但是还是这个对象(没有创建新的对象)

和String的区别就在于,String类型的对象内容别人改变不了,只能每次都创建新的对象

System.out.println(sb1); // hello world123

System.out.println(sb1 == sb2); // true

System.out.println(sb1.charAt(0)); // 获取0号位上的字符 h

System.out.println(sb1.length()); // 获取字符串的有效长度14

System.out.println(sb1.capacity()); // 获取底层数组的总大小

capacity()方法是用来获取这个内部字符数组当前的总大小,即这个数组在不进行扩容的情况下可以存储的最大字符数。这个大小并不等同于StringBuilder(或类似对象)当前实际存储的字符数,而是指数组的总容量。

解释:

  • 实际存储的字符数:可以通过length()或size()方法获取(对于StringBuilder来说是length()),它表示当前StringBuilder对象中实际包含的字符数量。
  • 数组的容量:通过capacity()获取,它表示StringBuilder内部用于存储字符的数组的大小。这个大小通常大于或等于实际存储的字符数,因为当字符序列增长时,底层数组可能需要扩容以容纳更多的字符。以下代码
  • StringBuilder sb1 = new StringBuilder();  
    System.out.println("Initial capacity: " + sb1.capacity()); // 打印初始容量  
    sb1.append("Hello, World!");  
    System.out.println("Capacity after appending: " + sb1.capacity()); // 打印追加后的容量  
    System.out.println("Actual length: " + sb1.length()); // 打印实际长度

    这段代码展示了如何查看StringBuilder的初始容量、追加字符后的容量以及实际存储的字符长度。注意,实际运行时的初始容量可能因JVM实现和版本而异,并且不一定总是16(虽然这是Java 8及之前版本中StringBuilder的默认初始容量)。

续:

sb1.setCharAt(0, 'H'); // 设置任意位置的字符 Hello world123

sb1.insert(0, "Hello world!!!"); // Hello world!!!Hello world123

System.out.println(sb1);

System.out.println(sb1.indexOf("Hello")); // 获取Hello第一次出现的位置

System.out.println(sb1.lastIndexOf("hello")); // 获取hello最后一次出现的位置

sb1.deleteCharAt(0); // 删除首字符

sb1.delete(0,5); // 删除[0, 5)范围内的字符

String str = sb1.substring(0, 5); // 截取[0, 5)区间中的字符以String的方式返回

System.out.println(str);

sb1.reverse(); // 字符串逆转

str = sb1.toString(); // 将StringBuffer以String的方式返回

System.out.println(str);

}

从上述例子可以看出:String和StringBuilder最大的区别在于String的内容无法修改,而StringBuilder的内容可以修改

频繁修改字符串的情况考虑使用StringBuilder。

注意:String和StringBuilder类不能直接转换。如果要想互相转换,可以采用如下原则:

String变为StringBuilder: 利用StringBuilder的构造方法或append()方法

StringBuilder变为String: 调用toString()方法

最后问大家一个问题:

1. String、StringBuffer、StringBuilder的区别?

String的内容不可修改,StringBuffer与StringBuilder的内容可以修改.

StringBuffer和StringBuilder?

StringBuffer与StringBuilder大部分功能是相似的

StringBuffer采用同步处理,属于线程安全操作(多线程)

而StringBuilder未采用同步处理(单线程),属于线程不安全操作

如图:

上述就是 【JavaSE】认识String类,了解,进阶到熟练掌握的全部内容了,能看到这里相信您一定对小编的文章有了一定的认可,今天我们了解String类的各种方法,以及StringBuild和StringBuffer的区别,我们的Java知识更近一步啦~~~

有什么问题欢迎各位大佬指出
欢迎各位大佬评论区留言修正

您的支持就是我最大的动力​​​!!!!

相关文章:

【JavaSE】认识String类,了解,进阶到熟练掌握

#1024程序员节 | 征文# 下面就让博主带领大家一起解决心中关于String类的疑问吧~~~ 1.字符串构造&#xff1a; 第一种和第二种&#xff08;有一定的区别&#xff0c;在常量池上&#xff09; public static void main(String[] args) { // 使用常量串构造 String s1 "h…...

vue3 vben-admin 窗口大小更改后 echarts尺寸变为 100px的问题

问题描述: 当切换切换tab 并且窗口尺寸更改时, echarts的尺寸因为父元素为 0, 自动设置为 100px 网上查找资料的结果: 1,使用vue 中的 v-if 来重新设置dom树 缺点: 频繁操作dom树结构, 极其消耗性能 优点: 自适应展示 2,设置固定宽高 缺点: 不能自适应展示, 无需消耗额外…...

Web应用框架-Django应用基础(3)-Jinja2

1.创建姓名模板 username里的数据发生改变&#xff0c;页面中渲染的数据发生改变&#xff0c;该效果称为动态数据 #hello/views:def hello_user(request):username000html <!DOCTYPE html><html lang"en"><head><meta charset"UTF-8&quo…...

js(深浅拷贝,节流防抖,this指向,改变this指向的方法)

一、深浅拷贝 1.基本数据类型和引用数据类型的区别&#xff1a; 1. 基本数据类型的变量存储的是值 引用数据类型的变量存储的是地址值 2. 基本数据类型的变量存储的值在栈内存 引用数据类型的变量存储的值在堆内存 3. 基本数据类型的变量存储的是值和值之间相互不影响 引用数据…...

香橙派5(RK3588)使用npu加速yolov5推理的部署过程

香橙派5使用npu加速yolov5推理的部署过程 硬件环境 部署过程 模型训练(x86主机) 在带nvidia显卡(最好)的主机上进行yolo的配置与训练, 获取最终的best.pt模型文件, 详见另一篇文档 模型转换(x86主机) 下载airockchip提供的yolov5(从pt到onnx) 一定要下这个版本的yolov5, …...

基于MWORKS的蓝桥杯「智能装备数字化建模大赛」正式发布,首期培训本周六开启

为强化装备数字化人才培养&#xff0c;推动装备数字化技术快速发展&#xff0c;第十六届蓝桥杯全国软件和信息技术专业人才大赛设置专项赛暨智能装备数字化建模大赛&#xff0c;使用MWORKS作为参赛软件。关于参赛软件授权、技术支持与培训、教材与案例开发支持、成果转化培训及…...

021、深入解析前端请求拦截器

目录 深入解析前端请求拦截器&#xff1a; 1. 引言 2. 核心实现与基础概念 2.1 基础拦截器实现 2.2 响应拦截器配置 3. 实际应用场景 3.1 完整的用户认证系统 3.2 文件上传系统 3.3 API请求缓存系统 3.4 请求重试机制 3.5 国际化处理 4. 性能优化实践 4.1 请求合并…...

windows中的tracert命令

在 Windows 操作系统中&#xff0c;tracert&#xff08;全称 Trace Route&#xff09;是一个用于确定 IP 数据包到达目标主机所经过的路径的命令行工具。它通过发送具有不同生存时间&#xff08;TTL&#xff09;的 ICMP&#xff08;Internet Control Message Protocol&#xff…...

【玩儿】Java 数字炸弹小游戏(控制台版)+ IO 数据存储

Java 数字炸弹小游戏&#xff08;控制台版&#xff09; IO 数据存储 数字炸弹小游戏概述功能实现实体类User.java 玩家信息实体类GameRecode.java 游戏记录实体类 自定义异常AccountLockedException.java 账号锁定异常PasswordErrorException.java 密码错误异常UnknowAccountEx…...

今日头条躺赚流量:自动化新闻爬取和改写脚本

构建一个自动化的新闻爬取和改写系统&#xff0c;实现热点新闻的自动整理和发布&#xff0c;需要分为以下几个模块&#xff1a;新闻爬取、信息解析与抽取、内容改写、自动发布。以下是每个模块的详细实现步骤和代码示例&#xff1a; 1. 新闻爬取模块 目标&#xff1a;从新闻网…...

日常实习与暑期实习详解

日常实习与暑期实习详解 问了下正在实习的同学&#xff0c;发现天要塌了–才知道日常实习是没有笔试的 1. 实习的定义 1.1 日常实习 日常实习是企业长期招聘的实习岗位&#xff0c;通常没有时间限制。企业会在需要时进行招聘&#xff0c;招聘对象包括在校大学生和大一、大二的…...

Git的原理和使用(六)

本文主要讲解企业级开发模型 1. 引入 交付软件的流程&#xff1a;开发->测试->发布上线 上面三个过程可以详细划分为一下过程&#xff1a;规划、编码、构建、测试、发 布、部署和维护 最初&#xff0c;程序⽐较简单&#xff0c;⼯作量不⼤&#xff0c;程序员⼀个⼈可以完…...

Elasticsearch 中的高效按位匹配

作者&#xff1a;来自 Elastic Alexander Marquardt 探索在 Elasticsearch 中编码和匹配二进制数据的六种方法&#xff0c;包括术语编码&#xff08;我喜欢的方法&#xff09;、布尔编码、稀疏位位置编码、具有精确匹配的整数编码、具有脚本按位匹配的整数编码以及使用 ESQL 进…...

LSTM,全称长短期记忆网络(Long Short-Term Memory),是一种特殊的循环神经网络(RNN)结构

关于lstm超参数设置&#xff0c;每个参数都有合适的范围&#xff0c;超过这个范围则lstm训练不再有效&#xff0c;loss不变&#xff0c;acc也不变 LSTM&#xff0c;全称长短期记忆网络&#xff08;Long Short-Term Memory&#xff09;&#xff0c;是一种特殊的循环神经网络&am…...

导出问题处理

问题描述 测试出来一个问题&#xff0c;使用地市的角色&#xff0c;导出数据然后超过了20w的数据&#xff0c;提示报错&#xff0c;我还以为是偶然的问题&#xff0c;然后是发现是普遍的问题&#xff0c;本地环境复现了&#xff0c;然后是&#xff0c;这个功能是三套角色&…...

通过cv库智能切片 把不同的分镜切出来 自媒体抖音快手混剪

用 手机自动化脚本&#xff0c;从自媒体上获取视频&#xff0c;一个商品对应几百个视频&#xff0c;我们把这几百个视频下载下来&#xff0c;进行分镜 视频切片&#xff0c;从自媒体上下载视频&#xff0c;通过cv库用直方图识别每个镜头进行切片。 下载多个图片进行视频的伪原…...

【机器学习】——numpy教程

文章目录 1.numpy简介2.初始化numpy3.ndarry的使用3.1numpy的属性3.2numpy的形状3.3ndarray的类型 4numpy生成数组的方法4.1生成0和1数组4.2从现有的数组生成4.3生成固定范围的数组4.4生成随机数组 5.数组的索引、切片6.数组的形状修改7.数组的类型修改8.数组的去重9.ndarray的…...

多线程——线程的状态

线程状态的意义 ‌线程状态的意义在于描述线程在执行过程中的不同阶段和条件&#xff0c;帮助开发者更好地管理和调度线程资源。 线程的多种状态 线程的状态是一个枚举类型&#xff08;Thread.State&#xff09;&#xff0c;可以通过线程名.getState&#xff08;&#xff09…...

开源数据库 - mysql - 组织结构(与oracle的区别)

组织形式区别 mysql&#xff08;Schema -> Table -> Column -> Row&#xff09; Schema&#xff08;方案&#xff09;&#xff1a; Scheme是关于数据库和表的布局及特性的信息。它可以用来描述数据库中特定的表以及整个数据库和其中表的信息&#xff0c;如表的一些特…...

vue3+vite 部署npm 包

公司需要所以研究了一下怎么部署安装&#xff0c;比较简单 先下载个vue项目 不用安准路由&#xff0c;pinna 啥的&#xff0c;只需要一个最简单的模版 删掉App.vue 中的其它组件 npm create vuelatest 开始写自定义组件 新建一个el-text 组件, name是重点&#xff0c;vue3中…...

国防科技大学计算机基础课程笔记02信息编码

1.机内码和国标码 国标码就是我们非常熟悉的这个GB2312,但是因为都是16进制&#xff0c;因此这个了16进制的数据既可以翻译成为这个机器码&#xff0c;也可以翻译成为这个国标码&#xff0c;所以这个时候很容易会出现这个歧义的情况&#xff1b; 因此&#xff0c;我们的这个国…...

论文解读:交大港大上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化学习框架(二)

HoST框架核心实现方法详解 - 论文深度解读(第二部分) 《Learning Humanoid Standing-up Control across Diverse Postures》 系列文章: 论文深度解读 + 算法与代码分析(二) 作者机构: 上海AI Lab, 上海交通大学, 香港大学, 浙江大学, 香港中文大学 论文主题: 人形机器人…...

Oracle查询表空间大小

1 查询数据库中所有的表空间以及表空间所占空间的大小 SELECTtablespace_name,sum( bytes ) / 1024 / 1024 FROMdba_data_files GROUP BYtablespace_name; 2 Oracle查询表空间大小及每个表所占空间的大小 SELECTtablespace_name,file_id,file_name,round( bytes / ( 1024 …...

Java如何权衡是使用无序的数组还是有序的数组

在 Java 中,选择有序数组还是无序数组取决于具体场景的性能需求与操作特点。以下是关键权衡因素及决策指南: ⚖️ 核心权衡维度 维度有序数组无序数组查询性能二分查找 O(log n) ✅线性扫描 O(n) ❌插入/删除需移位维护顺序 O(n) ❌直接操作尾部 O(1) ✅内存开销与无序数组相…...

基于uniapp+WebSocket实现聊天对话、消息监听、消息推送、聊天室等功能,多端兼容

基于 ​UniApp + WebSocket​实现多端兼容的实时通讯系统,涵盖WebSocket连接建立、消息收发机制、多端兼容性配置、消息实时监听等功能,适配​微信小程序、H5、Android、iOS等终端 目录 技术选型分析WebSocket协议优势UniApp跨平台特性WebSocket 基础实现连接管理消息收发连接…...

什么是库存周转?如何用进销存系统提高库存周转率?

你可能听说过这样一句话&#xff1a; “利润不是赚出来的&#xff0c;是管出来的。” 尤其是在制造业、批发零售、电商这类“货堆成山”的行业&#xff0c;很多企业看着销售不错&#xff0c;账上却没钱、利润也不见了&#xff0c;一翻库存才发现&#xff1a; 一堆卖不动的旧货…...

React19源码系列之 事件插件系统

事件类别 事件类型 定义 文档 Event Event 接口表示在 EventTarget 上出现的事件。 Event - Web API | MDN UIEvent UIEvent 接口表示简单的用户界面事件。 UIEvent - Web API | MDN KeyboardEvent KeyboardEvent 对象描述了用户与键盘的交互。 KeyboardEvent - Web…...

是否存在路径(FIFOBB算法)

题目描述 一个具有 n 个顶点e条边的无向图&#xff0c;该图顶点的编号依次为0到n-1且不存在顶点与自身相连的边。请使用FIFOBB算法编写程序&#xff0c;确定是否存在从顶点 source到顶点 destination的路径。 输入 第一行两个整数&#xff0c;分别表示n 和 e 的值&#xff08;1…...

Linux --进程控制

本文从以下五个方面来初步认识进程控制&#xff1a; 目录 进程创建 进程终止 进程等待 进程替换 模拟实现一个微型shell 进程创建 在Linux系统中我们可以在一个进程使用系统调用fork()来创建子进程&#xff0c;创建出来的进程就是子进程&#xff0c;原来的进程为父进程。…...

Yolov8 目标检测蒸馏学习记录

yolov8系列模型蒸馏基本流程&#xff0c;代码下载&#xff1a;这里本人提交了一个demo:djdll/Yolov8_Distillation: Yolov8轻量化_蒸馏代码实现 在轻量化模型设计中&#xff0c;**知识蒸馏&#xff08;Knowledge Distillation&#xff09;**被广泛应用&#xff0c;作为提升模型…...