Javase | String字符串-1

news2024/12/23 17:07:41

目录:

    • 1.字符串 (String)
    • 2.new String对象 和 不new String对象时内存分析:
      • 2.1 不new String对象时内存分析
      • 2.2 new String对象时内存分析
    • 3.以下程序一共创建了几个对象?
    • 4.String类中常用“构造方法”
      • String( )
      • String(byte [ ] b)
      • String( byte [ ] b ,int offset ,int length )
      • String( char [ ]c )
      • String( char [ ]c ,int offset ,int length )
    • 5.String类中常用“方法”
      • char charAt( int index)
      • int compareTo( String s )
      • boolean contains( CharSequence c )
      • boolean endsWith( String s )
      • boolean startsWith( String s )
      • boolean equals( Object o )
      • boolean equalsIgnoreCase( String s)
      • byte[ ] getBytes(String s)
      • int indexOf( String s )
      • int lastindexOf( String s )
      • boolean isEmpty( )
      • int length( )
      • 面试题 :判断“数组长度”和“字符串长度”不一样
      • String replace( CharSequence target, CharSequence replacement )
      • String[ ] split( String s )
      • String substring( int beginIndex)
      • String substring( int beginIndex , int endIndex)
      • char[ ] toCharArray( )
      • String toUpperCase( )
      • String toLowerCase( )
      • String trim( )

1.字符串 (String)

  1. JDK中内置的一个类: Java.lang.String

  2. String表示字符串类型,属于引用数据类型不属于基本数据类型。。

  3. 在java中用双引号括起来的的都是String对象,都存储在“字符串常量池”中。例如”abc“ 、”abcde“,这两个都是字符串。

  4. String字符串是不可变的,也就是说”abc“ 自出生到死亡,是不可变的,不能变成”abcd“,也不能变成“ab”

  5. 字符串存储“方法区” 中的 “字符串常量池”中。
    (把数据放在字符串常量池中的原因字符串使用很频繁

例子1如:

  /**
  * s1是对象的引用,s1的内存空间在“栈”的 “main方法栈帧”中,s1存放的是这个对象的“内存地址”
  * 这个“内存地址”指向"方法区"中的"字符串常量池"中的“"abcdef"对象
  * 
  * 同时s1是个局部变量 (该变量在main方法中)
  */
  String s1 = "abcdef";  // 字符串是不可变的

//这里的 "abcdef" 没发生改变,所以没必要新建,直接从字符串常量池中获得 "abcdef"对象即可。
//把数据放在字符串常量池的原因: 字符串使用很频繁
//  "xy" --- 在字符串常量池中新建了一个String对象
// "abcdef" 和 "xy" 相结合,形成了一个新的字符串 “abcdefxy”,存放在字符串常量池中
  String s2 = "abcdef" + "xy";
//此时字符串常量池中有三个字符串对象


//用new对象的方式来创建字符串对象
//双引号括起来的字符串都在“字符串常量池”中有一份
//new对象时会在“堆内存”中开辟空间
//对内存中的String对象也是指向“字符串常量池”中的“xy”
//  new String("xy"); 对象的“内存地址”赋给了 s3
//s3是对象的引用,在内存中位置为“栈”中“main方法栈帧”中,存储的是其对象的内存的内存地址,同时“堆内存”中的该对象指向“字符串常量池”中“xy ”
  String s3 = new String("xy"); //在堆内存中开辟空间

上述代码中(例子1)的内存图:

在这里插入图片描述


例子2如:

public class User {
    private int id;
    private String name;

    public User() {
    }

    public User(int id, String name) {
        this.id = id;
        this.name = name;
    }

    public int getId() {
        return id;
    }

    public String getName() {
        return name;
    }

    public void setId(int id) {
        this.id = id;
    }

    public void setName(String name) {
        this.name = name;
    }

    public static void main(String[] args) {

        //在“堆内存”中会存储一个“User对象”
        //“张三”这个值传最终传给 String name
        //在堆内存中有一个 “String name” ,其保存的是 “张三”这个字符串常量的“内存地址”,			这个“内存地址”指向“字符串常量池”中的“张三”对象
        // name变量中存的是 “张三”这个对象的内存地址
        User user = new User(101, "张三"); // "张三"存储在“字符串常量池”中
        /**
         *  User user 中的user的对象的引用,其的内存空间为“栈”的“main方法栈帧”中,其中		 *	存储的是该对象的“内存地址”
         *  该“内存地址”指向“堆内存中的”的User对象
         */
    }
}

上述代码(例子2)中的内存图:

在这里插入图片描述

2.new String对象 和 不new String对象时内存分析:

2.1 不new String对象时内存分析

//String s1 是一个变量
// s1是对象的引用 : 其的内存空间在“栈”的“main方法栈帧”中,其存储的内容为 "Hello"对象的内存地址
//这个内存地址指向 "Hello" 对象
//"Hello" 存储在“字符串常量池”中
String s1 = "Hello";
//所以第一个"Hello" 不会新建,直接拿来就行(因为这个对象已经存在了)
// s2中存的也是同一个"Hello" 对象的内存地址
String s2 = "Hello";
/*
对于对象引用类型:“==”比较的是对象的内存地址
对于基本类型数据,“==”其实比较的是它的值
*/
//此处的 == 号比较的是内存地址
System.out.println(s1==s2);  //true (两者都指向同一对象,内存地址一样)

上述代码的内存图:

在这里插入图片描述

2.2 new String对象时内存分析

 //创建了两个String对象
 /*
 String x : 是一个“变量”, 其的内存空间为“栈”中的“main方法栈帧”,存储的是new String的		“内存地址” (new String的内存地址赋给 x)
 */
// new String()对象的内存空间在“堆内存”中,该对象存储的"xyz"对象的“内存地址”
String x = new String("xyz"); //在“字符串”常量池中有“xyz”对象
//每new一次就会在“堆内存”里多一个对象
//此处 new String()对象的内存空间在“堆内存”中,但其的所在内存地址肯定不等于“上一个new的对     象”,该对象存储的"xyz"对象的“内存地址”
String y = new String("xyz");
//但这个两个new String()对象中存放的同一个"xyz"对象的"内存地址"

/**
 对于对象引用类型:“==”比较的是对象的内存地址
 对于基本类型数据,“==”其实比较的是它的值
 */
//false (两者都指向不同的new String()对象,这两个对象内存地址不一样)
System.out.println(x==y);  

//所以: 想要比较两个字符串是否相等,要用.equals()方法
//String重写了.equals()方法,让其判断两个“字符串的值”是否相等
System.out.println(x.equals(y)); //true

上述代码的内存图:

在这里插入图片描述

3.以下程序一共创建了几个对象?

   //以下程序一共创建了几个对象
   String s1 = new String("hello");
   String s2 = new String("hello");

   /**
    * 一共3个对象:
    *字符串常量池中1个“hello”对象。
    *堆内存中有两个String对象
    */

4.String类中常用“构造方法”

  • String s =“xxx” : 创建字符串对象最常用的方式
/**
   * 创建“字符串对象”最常用的一种方式
*/
String s1 = "hello world!";
/*
 s1保存的是 "hello world!"对象的内存地址,
 按理说以下应输出一个内存地址
 但输出了一个字符串,说明String重写了toString()方法
*/
System.out.println(s1); // helloWorld
System.out.println(s1.toString()); // helloWorld

String( )

   //无参构造方法
   String s = new String();

String(byte [ ] b)

        /**
         *   常用的构造方法
         */
        byte[] bytes = {97, 98, 99};
        String s2 = new String(bytes); //将“字节型数组”转换为“字符串对象”
        /*
           s2保存的是新new的String对象的在“堆内存”中的“内存地址”
           按理说以下应该输出该String对象的内存地址 (因为不重写toString的话,输出的是内存地址)
           但却输出了一个字符串(abc/字符串本身),说明String重写了toString()方法
         */
        System.out.println(s2); //abc

String( byte [ ] b ,int offset ,int length )

  • String(byte [ ] b ,int offset ,int length) : String(字节数组 ,数组元素下标的开始位置 ,长度)
byte[] bytes = {97, 98, 99,100,101};
String s3 = new String(bytes,2,3);
System.out.println(s3); //cde

String( char [ ]c )

   char [] chars ={'我','是','中','国','人'};
   //将char数组转换为 String字符串
   String s = new String(chars);
   System.out.println(s); //我是中国人

String( char [ ]c ,int offset ,int length )

   char [] chars ={'我','是','中','国','人'};
   //将char数组中“指定范围”的字符转换为字符串
   String s = new String(chars,2,3);
   System.out.println(s); //中国人

5.String类中常用“方法”

char charAt( int index)

  String s = "中国人"; //“中国人”是一个字符串String对象,只要是对象就能调用方法。
  //返回指定索引处的char值
  char c = s.charAt(1);
  System.out.println(c); //国

int compareTo( String s )

  • int compareTo( String s ) : 按字典顺序比较两个字符串。该比较基于字符串中各个字符Unicode 值。
    比较“对应位置”上的字符的Unicode值的大小,一个一个的比较,直到分出大小为止

  • 如果要比较的两个字符相等返回值为0

  • 如果前面字符串的Unicode值 > 后字符串的Unicode值返回值为一个大于0的数

  • 如果前面字符串的Unicode值 < 后字符串的Unicode值返回值为一个小于0的数

  • 前后一致:返回值为0;
    前大后小 : 返回值为一个大于0的数;
    前小后大:返回值为一个小于0的数;

  • 字符之间之间的比较不能用 > < ,需要使用功能compareTo( )方法

    例子如:

      //比较“对应位置”上的字符的Unicode值的大小
            
      //如: 比较a与a:相等; 比较b与b:相等;  比较c与c:相等;  返回值为0
      System.out.println("abc".compareTo("abc"));    // 0
    
      System.out.println("abcd".compareTo("abce"));  // (前小后大: )一个小于0的值 :-1
      System.out.println("abce".compareTo("abcd"));  // (前大后小: )一个大于0的值 : 1
    
      System.out.println("abcd".compareTo("abcd"));  // 0
    
     //如: 比较a与a:相等; 比较b与b:相等;  比较c与c:相等;  d与空白: d大: 前大后小 : 返回值为1
     System.out.println("abcd".compareTo("abc"));     // (前大后小 :)一个大于0的数 : 1
     System.out.println("abcd".compareTo("abcdef"));  // (前小后大 :)一个小于0的值 :-2
    

boolean contains( CharSequence c )

  • 判断前面的字符串是否包含后面的子字符串

  • 返回值为boolean类型。

       // 判断前面的字符串是否包含后面的子字符串。
       boolean contains1 = "HelloWorld.java".contains(".java");
       boolean contains2 = "http://www.baidu.com".contains("https://");
    
       System.out.println(contains1);//true
       System.out.println(contains2);//false
    

boolean endsWith( String s )

  • 判断“当前字符串”是否以“某个字符串结尾

  • 返回值为boolean类型。

       //判断“当前字符串”是否以“某个字符串” "结尾"
       System.out.println("test.txt".endsWith(".java")); //false
       System.out.println("test.txt".endsWith(".txt")); //true
       System.out.println("abacaseihsuwksss".endsWith("sss")); //true
    

boolean startsWith( String s )

  • 判断“当前字符串”是否以“某个字符串开始

  • 返回值为boolean类型。

       //判断“当前字符串”是否以“某个字符串” "开始"
       System.out.println("http://www.baidu.com".startsWith("http://")); //true
       System.out.println("http://www.baidu.com".startsWith("https://")); //false
    

boolean equals( Object o )

  • 判断两个字符串是否相等

      //判断两个字符串是否相等
      System.out.println("abc".equals("abc")); //true
      System.out.println("aaa".equals("bbb")); //false
    

boolean equalsIgnoreCase( String s)

  • 判断两个字符串是否相等,并且同时忽略大小写.

      //判断两个字符串是否相等,并且同时忽略大小写
      System.out.println("ABC".equalsIgnoreCase("abc")); //true
      System.out.println("AB".equalsIgnoreCase("abc")); //false
    

byte[ ] getBytes(String s)

  • 将“字符串”转换为“字节数组

      //将“字符串”转换为“字节数组”
      String s = "Hello,World";
      byte[] bytes = s.getBytes();
      //遍历byte数组
      for (int i = 0; i < bytes.length; i++) {
      System.out.println(bytes[i]);
    }
    

int indexOf( String s )

  • 判断“某个子字符串”在“当前字符串”中 第一次 出现的索引/下标
    (为 第一次 出现的字符串中的 第一个字符索引/下标)

  • 能找到则返回值为: 该索引,不能找到则返回值为 -1

    例子如:

       //判断“某个子字符串”在“当前字符串”中"第一次"出现的索引/下标
       //能找到则返回值为: 该索引,不能找到则返回值为 -1
       System.out.println("oracleJavaC++JavaoraclepythonC++".indexOf("Java")); //6
       System.out.println("123abc123abc".indexOf("123")); // 0
       System.out.println("123abc123abc".indexOf("11111")); //-1
    

int lastindexOf( String s )

  • 判断“某个子字符串”在“当前字符串”中 最后一次 出现的索引/下标
    (为 最后一次 出现的字符串中的 第一个字符索引/下标)

  • 能找到则返回值为: 该索引,不能找到则返回值为 -1

    例子如:

      //判断“某个子字符串”在“当前字符串”中"最后一次"出现的索引/下标
      //能找到则返回值为: 该索引,不能找到则返回值为 -1
      System.out.println("JavaC++JavaoraclepythonJava".lastIndexOf("Java")); //23
      System.out.println("123abc123abc".lastIndexOf("123"));  // 6
      System.out.println("123abc123abc".lastIndexOf("11111")); //-1
    

boolean isEmpty( )

  • 判断某个字符串是否为“空字符串

       //判断某个字符串是否为“空字符串
       String s1 = "";
       String s2 = "123";
       System.out.println(s1.isEmpty()); //true
       System.out.println(s2.isEmpty()); //false
    

int length( )

  • 获取字符串的“长度

      //获取字符串的“长度”
      System.out.println("abc".length()); // 3
    

面试题 :判断“数组长度”和“字符串长度”不一样

  • 判断“数组长度”是length( )属性,判断“字符串长度”是length( )方法

      System.out.println("abc".length()); // .length()方法
    
      int[] a = {1, 2, 3};
      for (int i = 0; i < a.length; i++) { // .length属性
      System.out.println(a[i]);
    }
    

String replace( CharSequence target, CharSequence replacement )

  • 用”新字符“替换”老字符“,返回一个“新的String字符串

      //用”新字符“替换”老字符“,返回一个“新的String字符串”
      String newString1 = "http://www.baidu.com".replace("http://", "https://");
      System.out.println(newString1); //https://www.baidu.com
     
      String newString2 = "name=zhangsan&password=123&word=123&age=20".replace("=",   ":");
      System.out.println(newString2); //name:zhangsan&password:123&word:123&age:20
    

String[ ] split( String s )

  • 根据给定"字符"/“正则表达式”的匹配拆分此字符串

       //根据给定"字符"/“正则表达式”的匹配拆分此字符串。
       String[] split = "1980-10-11".split("-");
       for (int i = 0; i < split.length; i++) {
       System.out.println(split[i]);
    }
    

String substring( int beginIndex)

  • 截取 指定索引之后字符返回值为一个字符串

      //截取字符串
      System.out.println("http://www.baidu.com".substring(7)); //www.baidu.com
    

String substring( int beginIndex , int endIndex)

  • 截取 开始索引”到“结束索引-1范围内 的字符,返回值为一个字符串

     //截取”开始索引”到“结束索引-1”范围内的字符,返回值为一个字符串
     System.out.println("http://www.baidu.com".substring(11,16)); //baidu
    

char[ ] toCharArray( )

  • 字符串转换为char数组

       //将字符串转换为char数组
       String str = "我是中国人呢";
       char[] chars = str.toCharArray();
       for (int i = 0; i < chars.length; i++) {
       System.out.println(chars[i]);
    }
    

String toUpperCase( )

  • 转换为 大写

      //转换为大写
      String str3 = "klaghlig";
      String str4 = str1.toUpperCase();
      System.out.println(str4); //KLAGHLIG
    

String toLowerCase( )

  • 转换为 小写

      //转换为小写
      String str1 = "AFSGGAsgy";
      String str2 = str1.toLowerCase();
      System.out.println(str2); //afsggasgy
    

String trim( )

  • 去除字符串 前后 的“空白"

      //去除字符串“前后”的“空白"
      String str1 = "    我是    中国人   ";
      String str2 = str1.trim();
      System.out.println(str2); //我是    中国人
    

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/994632.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

字符串逆序(不使用库函数并用递归实现)

文章目录 前言一、题目要求二、解题步骤1.大概框架2.如何反向排列&#xff1f;3.模拟实现strlen4.实现反向排列5.递归实现反向排列 总结 前言 嗨&#xff0c;亲爱的读者们&#xff01;我是艾老虎尤&#xff0c;。今天&#xff0c;我们将带着好奇心&#xff0c;探索一个题目&am…

显示器鼠标滚动时或者拖拽文字变为绿色

新电脑&#xff0c;新显示器&#xff0c;看文章时滚动鼠标滑轮&#xff0c;文字颜色就变为绿色。 拖住文本文档或者浏览器等有文字的窗口&#xff0c;文字也会变为绿色。 静止时一点儿问题没有。 以下视频展示滚动和拖拽的操作&#xff0c;视频看不出变色&#xff0c;只参考…

TuyaOS开发学习笔记(2)——NB-IoT开发SDK架构、运行流程

一、SDK架构 1.1 架构框图 基于 TuyaOS 系统&#xff0c;可以裁剪得到的适用于 NB-IoT 协议产品接入的 SDK。SDK 将设备配网、上下行数据通信、产测授权、固件 OTA 升级等接口进行封装&#xff0c;并提供相关函数。 1.2 目录结构 1.2.1 TuyaOS目录说明 adapter&#xff1a;T…

transformer 总结(超详细-初版)

相关知识链接 attention1attention2 引言 本文主要详解 transformer 的算法结构以及理论解释&#xff0c;代码实现以及具体实现时候的细节放在下一篇来详述。 下面就通过上图中 transformer 的结构来依次解析 输入部分(Encode 侧) input 输出主要包含 两个部分&#xff1a…

[acwing周赛复盘] 第 120 场周赛20230909

[acwing周赛复盘] 第 120 场周赛20230909 总结5146. 最大GCD1. 题目描述2. 思路分析3. 代码实现 5147. 数量1. 题目描述2. 思路分析3. 代码实现 5148. 字符串匹配1. 题目描述2. 思路分析3. 代码实现 六、参考链接 总结 T1好难啊。T1 数学T2 dfs/数位dpT3 计数贪心 5146. 最大…

第51节:cesium 范围查询(含源码+视频)

结果示例: 完整源码: <template><div class="viewer"><el-button-group class="top_item"><el-button type=

render和jsx

render和jsx 1..vue文件最后会变成一个对象。 一个vue文件要么是render写法&#xff0c;要么是模板写法。 为什么React在大型项目中比较适合&#xff1f; 在大型项目中比较适合&#xff1f; 因为React使用jsx&#xff0c;比较灵活。

ISYSTEM调试实践11-Profiler Timeline和软件运行时间分析

一 前言 本文主要内容是讨论嵌入式软件的时间分析&#xff0c;供大家探讨&#xff0c;如果有疑问欢迎探讨。 对于汽车软件&#xff0c;往往对执行的时序和代码运行的时间有着严格要求。对于在主循环内执行的任务函数&#xff0c;不论是手写还是Autosar生成,能否节拍执行到&…

flink时间处理语义

背景 在flink中有两种不同的时间处理语义&#xff0c;一种是基于算子处理时间的时间&#xff0c;也就是以flink的算子所在的机器的本地时间为准&#xff0c;一种是事件发生的实际时间&#xff0c;它只与事件发生时的时间有关&#xff0c;而与flink算子的所在的本地机器的本地时…

利用grafana展示Zabbix数据可视化

导入zabbix数据源&#xff0c;可以直接创建图形了。 单击“”按钮&#xff0c;选择创建仪表盘&#xff0c;单击要创建的图形&#xff0c;图形种类有很多&#xff0c;常用的有图表&#xff0c;列表&#xff0c;报警清单&#xff0c;zabbix触发器&#xff0c;文本。 创建巡检图形…

C++ 多线程 学习笔记

线程睡眠很稳定&#xff0c;但无线程睡眠不稳定 线程调用类方法&#xff1a; 有参数时调用方法&#xff1a; 当参数为引用时&#xff1a; 当同一资源被多个线程同时引用时&#xff0c;为防止资源抢占&#xff0c;使用mutex&#xff0c;互斥锁 头文件#include "mutex"…

蓝桥杯官网练习题(纸牌三角形)

题目描述 本题为填空题&#xff0c;只需要算出结果后&#xff0c;在代码中使用输出语句将所填结果输出即可。 A,2,3,4,5,6,7,8,9 共 99 张纸牌排成一个正三角形&#xff08;A 按 1 计算&#xff09;。要求每个边的和相等。 下图就是一种排法。 这样的排法可能会有很多。 如果…

thinkphp6-简简单单地开发接口

目录 1.前言TP6简介 2.项目目录3.运行项目运行命令访问规则 4.model db使用db连接配置model编写及调用调用接口 5.返回json格式 1.前言 基于上篇文章环境搭建后&#xff0c;便开始简单学习上手开发接口…记录重要的过程&#xff01; Windows-试用phpthink发现原来可这样快速搭…

Spring Data JPA:简化数据库交互的艺术

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

Jmeter 实现 mqtt 协议压力测试

1. 下载jmeter&#xff0c;解压 https://jmeter.apache.org/download_jmeter.cgi 以 5.4.3 为例&#xff0c;下载地址&#xff1a; https://dlcdn.apache.org//jmeter/binaries/apache-jmeter-5.4.3.zip linux下解压&#xff1a; unzip apache-jmeter-5.4.3.zip 2. 下载m…

六)Stable Diffussion使用教程:图生图SD Upscale

这一篇说说SD放大(SD Upscale)。 图生图是没有 “高清修复” 选项的,因为从文生图的高清修复原理来看,图生图本身就是高清修复:只需要在重绘目标图像时,等比例增大图像的分辨率就可以了。 这里我们通过图库浏览器浏览一张图片,然后点击图生图,图片的所有出图参数就会…

运维学习之采集器 node_exporter 1.3.1安装并使用

参考《监控系统部署prometheus基本功能》先完成prometheus部署。 wget https://github.com/prometheus/node_exporter/releases/download/v1.3.1/node_exporter-1.3.1.linux-amd64.tar.gz下载压缩包。 tar -zxf node_exporter-1.3.1.linux-amd64.tar.gz进行解压。 cp node_e…

安全实战 | 怎么用零信任防范弱密码?

防范弱密码&#xff0c;不仅需要提升安全性&#xff0c;更需要提升用户体验。 比如在登录各类业务系统时&#xff0c;我们希望员工登录不同系统不再频繁切换账号密码&#xff0c;不再需要3-5个月更换一次密码&#xff0c;也不再需要频繁的输入、记录、找回密码。 员工所有的办…

Spring Boot与Kubernetes:现代云部署的完美组合

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

第六章 图 四、图的广度优先遍历(BFS算法、广度优先生成树、广度优先生成森林)

一、实现步骤 广度优先遍历的实现步骤如下&#xff1a; 1.从图的某一个节点开始&#xff0c;将该节点标记为已经访问过的节点。 2.将该节点加入到队列中。 3.当队列非空时&#xff0c;执行以下操作&#xff1a; a. 取出队列队首节点&#xff0c;并遍历该节点与之相邻的所有…