Java工具类之String常用方法

简介: 1.String包 java.lang 2.构造方法 常量 无参数 带参数String byte[] char[] 3.不可变特性 长度 内容 4.String内存机制 常量"abc" 字符串常量池 构造方法new == equals()区别 "a"+"b"+"c"+"d"; 产生几个对象 5.String与StringBuffer与StringBuilder区别 6.常用的方法 第一梯队(重写) equals hashCode compareTo toString

知识回顾

String类

  1. 所属的包java.lang 没有继承类 默认继承Object
  2. 实现了三个接口  Serializable  CharSequence  Comparable<>
  3. String是一个非常特殊的引用数据类型,创建对象方式如下

    String str = "abc";

    String str = new String();

    String str = new String("abc");

    String str = new String(byte[] value);

    String str = new String(char[] value);

  1. String类的不可变特性 public final class String{  private final char[] value; }

    体现在长度及内容

    长度不可变是由于: 数组的长度是固定的 用final修饰数组(引用地址不能改变)

    内容不可变是由于: private修饰的属性只能在本类中访问

 5.  String类中的常用方法

    1.boolean = equals(Object obj);

       继承自Object类中的方法  重写啦  改变了规则  比较字符串中的字面值

       ==  equals()区别

     equalsIgnoreCase();

    2.int = hashCode();

       继承自Object类中的方法  重写啦  31*h+和

    3.int = compareTo();

       实现自Comparable接口  实现方法   结果按照字典排布(unicode编码)顺序

       按照两个字符串的长度较小的那个(次数)来进行循环

       若每次的字符不一致 则直接返回code之差  

       若比较之后都一致  则直接返回长度之差

     compareToIgnoreCase();

    4.String = toString()

       没有重写过的toString从Object类中继承过来的

       类名@hashCode(16进制形式)

       String类重写啦  返回的是String对象的字面值

5.char = charAt(int index);

   返回给定index位置对应的字符

   int = codePointAt(int index);

   返回给定index位置对应字符的code码

6.int = length();

   返回字符串的长度   (其实就是底层char[] value属性的长度)

   注意:  区别数组length是属性  String的length()方法    集合size()方法

7.String = concat(String str);

   将给定的str拼接在当前String对象的后面

   注意:  方法执行完毕需要接受返回值   String的不可变特性

        concat方法与   +拼接的性能问题

        开发中若遇到频繁的拼接字符串--->通常使用StringBuilder/StringBuffer

8.boolean = contains(CharSequence s);

   判断给定的s是否在字符串中存在

9. startsWith(String prefix);

    endsWith(String suffix);

   判断此字符串是否已xx开头/结尾

10.byte[] = getBytes();   --->    getBytes(String charsetName);

     char[] = toCharArray();

   将当前的字符串转化成数组   "我爱你中国"   char[]  '我' '爱' '你' '中' '国'

11. int index = indexOf(int/String str [,int fromIndex] );   四个方法重载

   找寻给定的元素在字符串中第一次出现的索引位置   若字符串不存在则返回-1

      lastIndexOf(int/String str , [int fromIndex]);

   找寻给定的元素在字符串中最后一次出现的索引位置  若不存在则返回-1

12.boolean = isEmpty();

   判断当前字符串是否为空字符串  (length是否为0)

   注意: 与null之间的区别

13.replace();

     replaceAll();

     replaceFirst(); 换第一次出现的那个字串

   将给定的字符串替换成另外的字符串

14.String[] = split(String regex [,int limit限度界限]);

   按照给定的表达式将原来的字符串拆分开的

15.String = substring(int beginIndex [,int endIndex]);

   将当前的字符串截取一部分    

   从beginIndex开始至endIndex结束 (beginIndex,endIndex)

   若endIndex不写 则默认到字符串最后

16.String = toUpperCase();

   String = toLowerCase();

  将全部字符串转换成大写/小写

17.String = trim();

  去掉字符串前后多余的空格

18.boolean = matches(String regex)

  regular有规律的 expression表达式

正则表达式

   1.String包  java.lang

   2.构造方法  常量 无参数 带参数String byte[] char[]

   3.不可变特性

    长度 内容

   4.String内存机制

    常量"abc" 字符串常量池      构造方法new

    ==  equals()区别

    "a"+"b"+"c"+"d";  产生几个对象

   5.String与StringBuffer与StringBuilder区别

   6.常用的方法

    第一梯队(重写)

    equals  hashCode  compareTo  toString

    第二梯队(常用)

    charAt()  codePointAt()

    indexOf()  lastIndexOf()

    substring()  split()  replace()

    length()  concat()  contains();  trim();

    getBytes()   toCharArray()  matches()

    第三梯队(一般)

    toUpperCase()  toLowerCase()

    startsWith()  endsWith();

    isEmpty();

   7.正则表达式

目录
相关文章
|
2月前
|
前端开发 JavaScript Java
Java 开发中 Swing 界面嵌入浏览器实现方法详解
摘要:Java中嵌入浏览器可通过多种技术实现:1) JCEF框架利用Chromium内核,适合复杂网页;2) JEditorPane组件支持简单HTML显示,但功能有限;3) DJNativeSwing-SWT可内嵌浏览器,需特定内核支持;4) JavaFX WebView结合Swing可完美支持现代网页技术。每种方案各有特点,开发者需根据项目需求选择合适方法,如JCEF适合高性能要求,JEditorPane适合简单展示。(149字)
215 1
|
1月前
|
算法 Java 开发者
Java 项目实战数字华容道与石头迷阵游戏开发详解及实战方法
本文介绍了使用Java实现数字华容道和石头迷阵游戏的技术方案与应用实例,涵盖GUI界面设计、二维数组操作、游戏逻辑控制及自动解法算法(如A*),适合Java开发者学习游戏开发技巧。
158 47
|
2月前
|
Java 索引
Java ArrayList中的常见删除操作及方法详解。
通过这些方法,Java `ArrayList` 提供了灵活而强大的操作来处理元素的移除,这些方法能够满足不同场景下的需求。
282 30
|
2月前
|
自然语言处理 Java Apache
在Java中将String字符串转换为算术表达式并计算
具体的实现逻辑需要填写在 `Tokenizer`和 `ExpressionParser`类中,这里只提供了大概的框架。在实际实现时 `Tokenizer`应该提供分词逻辑,把输入的字符串转换成Token序列。而 `ExpressionParser`应当通过递归下降的方式依次解析
158 14
|
2月前
|
安全 Java API
Java 17 及以上版本核心特性在现代开发实践中的深度应用与高效实践方法 Java 开发实践
本项目以“学生成绩管理系统”为例,深入实践Java 17+核心特性与现代开发技术。采用Spring Boot 3.1、WebFlux、R2DBC等构建响应式应用,结合Record类、模式匹配、Stream优化等新特性提升代码质量。涵盖容器化部署(Docker)、自动化测试、性能优化及安全加固,全面展示Java最新技术在实际项目中的应用,助力开发者掌握现代化Java开发方法。
93 1
|
2月前
|
安全 Java API
Java 集合高级应用与实战技巧之高效运用方法及实战案例解析
本课程深入讲解Java集合的高级应用与实战技巧,涵盖Stream API、并行处理、Optional类、现代化Map操作、不可变集合、异步处理及高级排序等核心内容,结合丰富示例,助你掌握Java集合的高效运用,提升代码质量与开发效率。
175 0
|
2月前
|
算法 搜索推荐 Java
Java中的Collections.shuffle()方法及示例
`Collections.shuffle()` 是 Java 中用于随机打乱列表顺序的方法,基于 Fisher-Yates 算法实现,支持原地修改。可选传入自定义 `Random` 对象以实现结果可重复,适用于抽奖、游戏、随机抽样等场景。
73 0
|
2月前
|
安全 Java
JAVA:Collections类的shuffle()方法
`Collections.shuffle()` 是 Java 中用于随机打乱列表顺序的工具方法,适用于洗牌、抽奖等场景。该方法直接修改原列表,支持自定义随机数生成器以实现可重现的打乱顺序。使用时需注意其原地修改特性及非线程安全性。
76 0
|
2月前
|
算法 安全 Java
java中Collections.shuffle方法的功能说明
`Collections.shuffle()` 是 Java 中用于随机打乱列表顺序的方法,基于 Fisher-Yates 算法实现,常用于洗牌、抽奖等场景。可选 `Random` 参数支持固定种子以实现可重复的随机顺序。方法直接修改原列表,无返回值。
70 0
|
2月前
|
Java 程序员 项目管理
Java 程序员不容错过的 Git Flow 全套学习资料及应用方法详解 Git Flow
本文详细介绍了Git Flow技术方案及其在Java项目中的应用实例,涵盖分支管理、版本发布与紧急修复流程,帮助开发者掌握高效的代码管理方法,提升团队协作效率。附示例操作及代码下载链接。
59 0