String类

字符串是不可变的,对其做的任何改变,会生成一个对象,不会改变有原有对象。

==和equals()

String s1 = "good";
String s2 = "good";
if (s1 == s2) {} // true 这种直接把字符串赋值给对象的情况,是存储在常量池里的,指向同一个地址
// another example
String s1 = "good";
String s2 = new String("good");
if (s1 == s2) {} // false, new出来的对象存储在堆内存,和存放在常量池指向的不是同一个地址

// 当然,两个都是new出来的对象,即使他们内容相同,用“==”来比较地址也是不同的
// String类覆盖了equals()方法,比较的是字符串的内容。故一般不用==来比较
// 无论是以上那种情形,只要内容是"good",就是true
if (s1.equals(s2)) {}
  

像Integer一类的由基本数据类型封装成的对象,也是覆写了equals方法的,和String类一样也是比较的内容。但是在使用==比较的时候有些区别。

Integer a = new Integer(6);
Integer b = new Integer(6);
// 可以像如上方式实例化,也可像下面这样,下面这种方式称为自动装箱(从int -> Integer)
Integer c = 6;
Integer d = 6;
Integer e = 128;
Integer f = 128;
if (c==d) {} // true
if (e == f) {} // false,why?
  • 自动装箱时候,当使用==比较,仅限于闭区间[-128, 127],两个内容相同的对象地址也是相同的,超出这个范围,地址就不同了,比较结果false
  • 当然equals方法比较的还是内容,不管哪种方式实例化,只要内容相同,比较结构就是true。

compareTo()

字符串的比较用str1.compareTo(str2),实际上是String类实现了Comparable

String s1 = "abc";
String s2 = "abcd";
String s3 = "abcdfg";
String s4 = "1bcdfg";
String s5 = "cdfg";
System.out.println( s1.compareTo(s2) ); // -1 (前面相等,s1长度小1)
System.out.println( s1.compareTo(s3) ); // -3 (前面相等,s1长度小3)
System.out.println( s1.compareTo(s4) ); // 48 (第一个字符就不等,结束比较,"a"的ASCII码是97,"1"的的ASCII码是49,所以返回48)
System.out.println( s1.compareTo(s5) ); // -2 ("a"的ASCII码是97,"c"的ASCII码是99,所以返回-2)

注意:String s1 = ""String s2 = null无论是用equals()还是==比较都是flase。因为s1表示该字符串内容为空,长度为0,指向某个地址。而s2没有绑定任何地址,是一个空指针,更谈不上有长度(调用length()报错)。

String类一些常用方法

一般来说,实例化String类String str = "good"就可满足。但有时候使用String str = new String("...")能实现额外的功能。

char[] a = {97, 98, 99}; // 和这个等价char[] a = {'a', 'b', 'c'};
String str = new String(a); // 可以传入字符数组,打印abc
// 还能指定偏移量和字符个数,1表示从数组下标1开始,2表示取用的个数
String str = new String(a, 1, 2); // 打印bc
  • indexOf() / lastIndexOf
public class Demo {
  // 查找指定字符串是否存在
  public static void main(String[] args) {
    String str1 = "abcdefmnabc";
    // 从头开始查找是否存在指定的字符
    System.out.println(str1.indexOf("c")); // 打印2,这里传入99也是一样的,ASCII码对应
    // 从第4个字符位置开始往后继续查找
    System.out.println(str1.indexOf("c", 3)); // 打印10,即最后一个
    System.out.println(str1.indexOf("abc")); // 传字符串也行,打印0
    //若指定字符串中没有该字符则系统返回-1
    System.out.println(str1.indexOf("z"));
  } 

lastIndexOf()反向

charAt(int index)

// 返回指定下标的字符
String str1 = "abcdefmnabc";
// 若想打印字符串中每个字符,可以这样写
for (int i = 0; i < str.length(); i++) {
  System.out.println(str.charAt(i));
}

subString(int begin, int end)

// 返回该字符串的一个子字符串,区间是左闭右开的
String str1 = "abcdefmnabc";
str.subString(1, 4); // 返回bcd

toCharArray()

// 返回字符数组char[]
char[] chs = str.toCharArray();

String.valueOf()

// 可传入数字
System.out.println(String.valueOf(97)); // 仅仅是将97转换成字符串97,没有转换成'a'
// 传入字符数组,连接起来
 char[] chs = {'a','b', 98};
System.out.println(String.valueOf(chs)); // 打印abb

replace(char old, char new)

// 将指定的字符,全部替换成新的字符
String str1 = "abacd";
str.replace('a', 'e'); // 返回ebecd

可以传正则表达式(regex)的String类方法

  • split(String regex)
String str = "a1b2c3d";
String[] words = str.split("\\d"); // 按数字分割,注意返回的是String[]
for (String ch: words) {
  System.out.println(ch); // 依次打印abcd
}
  • replaceAll(String regex, String another)
String str = "a1b2c3d";
String new_str = str.replaceAll("\\d", "-"); // 把所有数字替换为"-"
System.out.println(new_str); // 打印a-b-c-d
  • matches()
// 判断该字符串是否和指定的正则表达式规则匹配
String str = "abc123de45@163.com";
// 匹配邮箱
boolean b = str.matches("\\w+@\\w+\\.[a-z]{2,3}");
System.out.println(b);

正则表达式的一般调用顺序

  • [abc]a或者b或者c
  • {2,}、{2,5}、{11}分别表示重复至少2次,重复2次到5次之间(包括),恰好重复11次
  • \w表示匹配单词字符[a-zA-Z_0-9]
  • \d匹配数字
  • \s匹配空白字符,包括空格、换行符、制表符
  • .表示匹配任意
  • +匹配一个或多个,*匹配0个或多个,?匹配0个或者1个
  • .*?非贪婪模式匹配任意字符串
Pattern p = Pattern.compile("1\\d{10}");
Matcher m = p.matcher("12345678901dhf18133338888");

// m.matches(); 返回false,虽然前面11位是满足的,但是Java中是matches()匹配整个,当整个字符串都和规则匹配才返回true
// Python中是从头开始匹配,若有满足,返回第一个匹配的,所有会匹配上12345678901

// find()找到所有和规则匹配的字符串。调用一次只能找到一个,若找到,指向下一个,用while找到所有
while (m.find())
  System.out.println(m.group()); // 会找到两个结果

// 注意不要使用了m.matches()后又去用m.find(),会有影响,我也不知道是为什么
Pattern p = Pattern.compile("1\\d{10}");
Matcher m = p.matcher("12345678901dhf18133338888");
boolean b = m.matches(); // 返回false,匹配后再用如下的find()
while (m.find())
  System.out.println(m.group()); // 只能找到最后一个结果18133338888

String一些简单的方法

  • trim()去除字符串两端的空格。

  • concat()连接两个字符串,功能和+连接字符串类似。

  • contains()返回boolean值,判断该字符串是否包含传入的字符串。

  • startWith()/endWith()判断该字符串是否以指定的字符串开头或者结尾。

  • toUpperCase()/toLowerCase()转换大小写,对每个字符进行操作。

  • getBytes(),使用平台的默认字符集将此 String 编码为 byte 序列,并将结果存储到一个新的 byte 数组中。

StringBuffer/StringBuilder

两个都是可变字符序列。StringBuffer可用于多线程,保证同步,线程安全。效率不高。StringBuilder一般用于单线程,不保证同步,线程不安全,但是效率高。一般用StringBuilder就行。

  • 长度可变
  • 可以存储不同类型的数据
  • 需要转换为字符串后来使用
public static void main(String[] args) throws InterruptedException {
        StringBuilder sb = new StringBuilder();
        sb.append(123);
        sb.append("abc"); // 可以添加任意类型数据
        System.out.println(sb); // 123abc
        sb.insert(3,"good");    // 第三个字符后面插入
        System.out.println(sb); // 123goodabc
        sb.replace(0, 3, "zzz"); // [0,3)区间的替换
        System.out.println(sb); // zzzgoodabc
        System.out.println(sb.length()); // 10
        sb.setLength(20);
        sb.setCharAt(19,'z');
        System.out.println(sb); // zzzgoodabc         z,中间有9个空格
        sb.deleteCharAt(19);
        System.out.println(sb); // zzzgoodabc         ,后面有10个空格
        System.out.println(sb.reverse()); // 字符序列反转,         cbadoogzzz,前面10个空格
        System.out.println(sb.capacity()); // 34,容量是通常大于长度的
        //sb.setLength(0); 删除该字符序列的一种方法,长度设置为0
        sb.delete(0, sb.length()); // 删除该字符序列的另外一种方法,删除整个区间内的字符
    }

by @sunhaiyu

2016.12.14

Java基础之String类的更多相关文章

  1. Java基础笔记-String类

    String 类(被final修饰) 字符串是一种特殊的对象,一旦字符串被初始化就不可以被改变了.(内容不变) 例如: String  s = “abc”; String  s1 = new Stri ...

  2. Java基础教程——String类

    String类 Java程序中的所有字符串字面值(如 "abc" )都是String的实例 字符串是常量(因为 String 对象是不可变的,所以可以共享) 字符串的本质是字符数组 ...

  3. Java 基础之 String 类

    String String 被声明为 final,因此不能被继承.(Integer 等包装类也不能被继承) 在 java8 中,String 内部使用 char 数组 来存储数据 public fin ...

  4. Java基础笔记-String类2

    StringBuffer 特点: 是字符串缓冲区. 是一个容器,其长度可变,可以操作添加多个数据类型. 最后通过toString方法变成字符串. 被final锁修饰,因此不能被继承. 存储: 方法1: ...

  5. Java入门 - 语言基础 - 14.String类

    原文地址:http://www.work100.net/training/java-string.html 更多教程:光束云 - 免费课程 String类 序号 文内章节 视频 1 概述 2 创建字符 ...

  6. Java基础-DButils工具类(QueryRunner)详解

    Java基础-DButils工具类(QueryRunner)详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 如果只使用JDBC进行开发,我们会发现冗余代码过多,为了简化JDBC ...

  7. Java基础之File类的使用

    Java基础之File类的使用 1.File类的构造方法和常用方法 2.对File中listFile(FileNameFilter name)学习 3.与File文件类相关的实现 File类的构造方法 ...

  8. Java基础之String、StringBuffer、StringBuilder浅析

    Java基础之String.StringBuffer.StringBuilder浅析 一.前言: 位于java.lang包下的String.StringBuilder.StringBuffer一般都是 ...

  9. Java基础-常用工具类(一)

    object类 Object 类是所有类的的父类,如果一个类没有明确使用EXPENTS关键字明确标识继承另外一个类,那么这个类默认继承object类,oject类中的方法适合所有子类 1)toStri ...

随机推荐

  1. [css 实践篇] CSS box-orient

    定义和用法 box-orient 属性规定框的子元素应该被水平或垂直排列. 提示:水平框中的子元素从左向右进行显示,而垂直框的子元素从上向下进行显示.不过,box-direction 和 box-or ...

  2. IntelliJ IDEA:给web应用提供JSTL支持

    最近在看<Head First Servlet JSP>学习JSP,看到JSTL一章,为了添加JSTL支持折腾了好久. 网上的教程五花八门,而且多数比较旧. 我尝试了各种方法都没有成功,很 ...

  3. 用Markdown优雅的写文章

    简介 Markdown是一种可以使用普通文本编辑器编写的标记语言,通过简单的标记语法,它可以使普通文本内容具有一定的格式. 简单点来说,Markdown是文本标记语言,在普通文本的基础上加了一些特殊标 ...

  4. a bad dream

    最近在恶补 数据结构,网络,操作系统.有关技术实践(项目)的博客基本会停一停. 4月18号早上,我做了一个梦.6点左右就醒了,醒来后马上趁着记忆"热乎乎"写下来.大概在手机上写了一 ...

  5. accp8.0转换教材第3章MySQL高级查询(一)理解与练习

    一.单词部分 ①constraint约束②foreign外键③references参考 ④subquery子查询⑤inner内部的⑥join连接 二.预习部分 1.修改表SQL语句的关键字是什么 RE ...

  6. (转载)oracle 在一个存储过程中调用另一个返回游标的存储过程

    原文链接:http://www.jb51.net/article/20160.htm 实际项目当中经常需要在一个存储过程中调用另一个存储过程返回的游标,本文列举了两种情况讲述具体的操作方法. 第一种情 ...

  7. hdu2410(水)

    题意 如果两个数字除了带问号的位以外都相同,我们称这两个数可以相互匹配 给你两个数,其中第一个数字里有一些问号,问有多少个大于第二个数的数字可以和第一个数字匹配 一开始懒得读题,到网上搜题意,结果居然 ...

  8. 拥抱.NET Core系列:依赖注入(2)

    上一篇"拥抱.NET Core系列:依赖注入(1)"大体介绍了服务注册.获取和生命周期,这一篇来做一些补充. 由于内容跨度大(.NET Core.ASP.NET Core),所以文 ...

  9. DELPHI下的SOCK编程

     DELPHI下的SOCK编程(转自http://www.cnblogs.com/devcjq/articles/2325600.html) 本文是写给公司新来的程序员的,算是一点培训的教材.本文不会 ...

  10. 3,Spring Boot热部署

    问题的提出: 在编写代码的时候,你会发现我们只是简单把打印信息改变了,就需要重新部署,如果是这样的编码方式,那么我们估计一天下来就真的是打几个Hello World就下班了.那么如何解决热部署的问题呢 ...