String 字符串的一些常用方法

1. .contains() 和 .indexOf()

public boolean contains(CharSequence s)
public int indexOf(String str)

  这两种方法都是判断字符串中是否有子字符串。一般会用到 String 的 contains,如果包含则返回 true,否则返回 false。使用 indexOf 会返回该字符串在某字符串中的索引值,如果不存在则返回 -1。

String str1 ="tdint";
String cs1 = "int";
//一般会用到String的contains,如果包含则返回true,否则返回false。
System.out.println("str1中是否包含有cs1: " + str1.contains(cs1));
System.out.println("str1中是否包含有\"_\":" + str1.contains("_"));
//使用 indexOf 会返回该字符串在某字符串中的索引值,如果不存在则返回 -1
System.out.println("str1中是否包含有cs1: " + str1.indexOf(cs1));
System.out.println("str1中是否包含有\"_\":" + str1.indexOf("_"));

输出结果:

str1中是否包含有cs1: true
str1中是否包含有"_"false
str1中是否包含有cs1: 2
str1中是否包含有"_"-1

2. .isEmpty()

public boolean isEmpty()

该方法是判断字符串中是否为空。如果是则返回true,如果不是则返回false。

String str1 ="tutorials point";
boolean empty1 = "answer".isEmpty();
boolean empty2 = str1.isEmpty();
boolean empty3 = "".isEmpty();
boolean empty4 = " ".isEmpty();
System.out.println("empty1 : "+empty1);
System.out.println("empty2 : "+empty2);
System.out.println("empty3 : "+empty3);
System.out.println("empty4 : "+empty4);

输出结果:

empty1 : false
empty2 : false
empty3 : true
empty4 : false

3. .toUpperCase() 和 .toLowerCase()

public String toUpperCase()
public String toLowerCase()

toUpperCase() 方法用于把字符串转换为大写。
toLowerCase() 方法用于把字符串转换为小写。

String str1 ="set".toUpperCase();
String str2 = "SET".toLowerCase();
System.out.println("\"set\"转为大写后: "+str1);
System.out.println("\"SET\"转为小写后: "+str2);

输出结果:

"set"转为大写后: SET
"SET"转为小写后: set

4. String.format()

public static String format(String format, Object… args)

  该方法用于创建格式化的字符串以及连接多个字符串对象。熟悉C语言的同学应该记得C语言的 sprintf() 方法,两者有类似之处。format() 方法有两种重载形式。
format(String format, Object… args) 新字符串使用本地语言环境,制定字符串格式和参数生成格式化的新字符串。

显示不同转换符实现不同数据类型到字符串的转换,如表所示。

转 换 符说 明实 例
%s字符串类型“ewda”
%c字符类型“s”
%b布尔类型true
%d整数类型(十进制)52
%x整数类型(十六进制)FF
%o整数类型(八进制)77
%f浮点类型25.21
%a十六进制浮点类型FF.1A
%e指数类型9.38e+5
%h散列码
%%百分比类型%
%n换行符
%tx日期与时间类型(x代表不同的日期与时间转换符)

搭配转换符的标志,如图所示。

标 志说 明实 例结 果
+为正数或者负数添加符号("%+d",15)+15
-左对齐("%-5d",15)|15   |
0数字前面补0("%04d",99)0099
空格在整数之前添加指定数量的空格("% 4d",15)|   99|
,以“,”对数字分组("%,f",9999.99)9,999.990000
(使用括号包含负数("%(f", -99.99)(99.990000)
#如果是浮点数则包含小数点,如果是16进制或8进制则添加0x或0("%#x", 99)
("%#o", 99)
0x63
0143
<格式化前一个转换符所描述的参数("%f和%< 3.2f", 99.45)99.450000和99.45
$被格式化的参数索引("%1$d,%2$s", 99,“abc”)99,abc

常见日期和时间组合的格式,如图所示。

转 换 符说 明实 例
c包括全部日期和时间信息星期六 十月 27 14:21:20 CST 2007
F“年-月-日”格式2007-10-27
D“月/日/年”格式10/27/07
r“HH:MM:SS PM”格式(12时制)02:25:51 下午
T“HH:MM:SS”格式(24时制)14:28:16
R“HH:MM”格式(24时制)14:28
String str="";
str=String.format("你好,%s", "任安");
System.out.println(str);
str=String.format("你好,%s:%s.%s", "张三","任安","小王");
System.out.println(str);
System.out.printf("字母b的大写是:%c %n", 'B');
System.out.printf("3>7的结果是:%b %n", 3>7);
System.out.printf("100的一半是:%d %n", 100/2);
System.out.printf("100的16进制数是:%x %n", 100);
System.out.printf("100的8进制数是:%o %n", 100);
System.out.printf("50元的书打8.5折扣是:%f 元%n", 50*0.85);
System.out.printf("上面价格的16进制数是:%a %n", 50*0.85);
System.out.printf("上面价格的指数表示:%e %n", 50*0.85);
System.out.printf("上面的折扣是:%d%% %n", 85);
System.out.printf("字母a的散列码是:%h %n", 'a');

// +的使用
System.out.printf("显示正负数的符号:%+d,%d %n", 99,-99);
// -的使用
System.out.printf("左对齐:|%-4d| %n", 15);
// 0的使用
System.out.printf("最牛的编号是:%03d %n", 7);
// 空格的使用
System.out.printf("Tab键的效果是:|%4d| %n", 15);
// ,的使用
System.out.printf("整数分组的效果是:%,f %n", 9999.99);
// (的使用
System.out.printf("包含负数:%(f %n", -99.99);
// #的使用
System.out.printf("16进制或8进制则添加0x或0:%#x,%#o %n", 99,99);
// <的使用
System.out.printf("格式化前一个转换符所描述的参数:%f和%<.2f %n", 99.45);
// 小数点后面个数
System.out.printf("小数点后面3位:%.3f元 %n", 49.8);
// $的使用
String str = "";
str = String.format("格式参数$的使用:%2$d,%1$s", "abc", 99);
System.out.println(str);

Date date=new Date();
System.out.printf("全部日期和时间信息:%tc%n",date);
System.out.printf("年-月-日格式:%tF%n",date);
System.out.printf("月/日/年格式:%tD%n",date);
System.out.printf("HH:MM:SS PM格式(12时制):%tr%n",date);
System.out.printf("HH:MM:SS格式(24时制):%tT%n",date);
System.out.printf("HH:MM格式(24时制):%tR",date);

输出结果:

你好,任安
你好,张三:任安.小王
字母b的大写是:B 
3>7的结果是:false 
100的一半是:50 
10016进制数是:64 
1008进制数是:144 
50元的书打8.5折扣是:42.500000 元
上面价格的16进制数是:0x1.54p5 
上面价格的指数表示:4.250000e+01 
上面的折扣是:85% 
字母a的散列码是:61 

显示正负数的符号:+99,-99 
左对齐:|15  | 
最牛的编号是:007 
Tab键的效果是:|  15| 
整数分组的效果是:9,999.990000 
包含负数:(99.990000) 
16进制或8进制则添加0x或00x63,0143 
格式化前一个转换符所描述的参数:99.45000099.45 
小数点后面3位:49.800元 
格式参数$的使用:99,abc

全部日期和时间信息:星期二 十月 13 11:25:33 CST 2020--日格式:2020-10-13//年格式:10/13/20
HH:MM:SS PM格式(12时制):11:25:33 上午
HH:MM:SS格式(24时制):11:25:33
HH:MM格式(24时制):11:25

5. .split()

public String[] split(String regex)
public String[] split(String regex, int limit)

split 分割 字符串(分隔符如:* ^ : | , . 等)
  简单来说就是通过使用 split() 方法,给定一个正则,会根据该正则来将字符串切割,并且返回String类型的数组,但是在他的重载方法split(String regex,int limit) 中,第二个参数是有点东西的。
  第一个 regex 是正则表达式,需要注意如果是要按照"|" “.“之类的特殊符号分割的话,需要加上转义,比如”\|”,不然切割的会不准确。
  第二个参数 limit 是要输入一个数值,①这个数值 n 如果 >0,则会执行切割 n-1次,也就是说执行的次数不会超过输入的数值次数,数组长度也不会大于切割次数,输入limit为数字1,切割执行1-1次,也就是0次,所以切割后的数组长度仍然是1,也就是原来的字符串。② 如果输入的limit数值是非正数,则执行切割到无限次,会将字符串所有匹配该正则的全部切割,如果输入limit数值等于0,则会去掉该数组最后的所有空字符串。比如下面代码:

  • ① limit > 0
// 以分隔符为 |,举例
String str = "||北京|上海|广州|深圳|||";
String[] split1 = str.split("\\|", 4);
String[] split2 = str.split("\\|", 1);
System.out.println("limit = 4,切割后的数组长度为:"+ split1.length +",数组为:");
for (int i = 0; i < split1.length; i++) {
    System.out.println(split1[i]);
}
System.out.println("limit = 1,切割后的数组长度为:"+ split2.length +",数组为:");
for (int i = 0; i < split2.length; i++) {
    System.out.println(split2[i]);
}

输出结果:

limit=4,切割后的数组长度为:4,数组为:


北京
上海|广州|深圳|||
limit=1,切割后的数组长度为:1,数组为:
||北京|上海|广州|深圳|||
  • ② limit <= 0
String str = "||北京|上海|广州|深圳|||";
String[] split1 = str.split("\\|", 0);
String[] split2 = str.split("\\|", -1);
System.out.println("limit = 0,切割后的数组长度为:"+ split1.length +",数组为:");
for (int i = 0; i < split1.length; i++) {
    System.out.println(split1[i]);
}
System.out.println("limit = -1,切割后的数组长度为:"+ split2.length +",数组为:");
for (int i = 0; i < split2.length; i++) {
    System.out.println(split2[i]);
}

输出结果:

limit = 0,切割后的数组长度为:6,数组为:


北京
上海
广州
深圳
limit = -1,切割后的数组长度为:9,数组为:


北京
上海
广州
深圳




6. .substring()

public String substring(int beginIndex)
public String substring(int beginIndex, int endIndex)

  第一个参数 beginIndex 为开始的索引,对应String数字中的开始位置,第二个参数 endIndex 是截止的索引位置,对应String中的结束位置。(前包括后不包括)

String str = "My Heart Will Go On!";
String subStr1 = str.substring(0,8);
System.out.println("subStr1:" + subStr1);
String subStr2 = str.substring(0,str.length());
System.out.println("subStr2:" + subStr2);

输出结果:

subStr1:My Heart
subStr2:My Heart Will Go On!

7. .regionMatches()

public boolean regionMatches(int toffset, String other, int ooffset, int len)
public boolean regionMatches(boolean ignoreCase, int toffset,String other, int ooffset, int len)

// ignoreCase - 忽略大小写
// toffset - 该字符串中子区域的开始偏移量
// other - 另一个参数字符串
// ooffset - 参数字符串中子区域的开始偏移量
// len - 要比较的字符数

  上述两个方法用来比较两个字符串中指定区域的子串。入口参数中,用 toffset 和 ooffset 分别指出当前字符串中的子串起始位置和要与之比较的字符串中的子串起始地址;other指出另一个参数字符串;len 指出比较长度。
  第一种方法是区分大小写字母的,而第二个方法中,如果在 ignoreCase处写 true,表示不区分大小写,写 false 则表示区分大小写。

String str  = "124a56789";
String tem1 = "1234a56789";
String tem2 = "1234A56789";
boolean bool1 = str.regionMatches(2, tem1, 3, 3);
boolean bool2 = tem1.regionMatches(true,3, tem2, 3, 3);
boolean bool3 = tem1.regionMatches(false,3, tem2, 3, 3);
System.out.println("第一种方法,str偏移2,tem1偏移3,比较3个字符的结果是:"+bool1);
System.out.println("第二种方法,忽略大小写,tem1偏移3,tem2偏移3,比较3个字符的结果是:"+bool2);
System.out.println("第二种方法,区分大小写,tem1偏移3,tem2偏移3,比较3个字符的结果是:"+bool3);

输出结果:

第一种方法,str偏移2,tem1偏移3,比较3个字符的结果是:true
第二种方法,忽略大小写,tem1偏移3,tem2偏移3,比较3个字符的结果是:true
第二种方法,区分大小写,tem1偏移3,tem2偏移3,比较3个字符的结果是:false

8. .equals() 和 .equalsIgnoreCase()

public boolean equals(Object anObject)
public boolean equalsIgnoreCase(String anotherString)
  上述两个方法用来做比较的,不同的是第一种方法是将此字符串与指定的对象比较,第二种是将此 String 与另一个 String 比较,不考虑大小写。

String str = "abc";
boolean b1 = "Abc".equals(str);
boolean b2 = "Abc".equalsIgnoreCase("abc");
System.out.println(b1);
System.out.println(b2);

输出结果:

false
true
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhangxin_zx

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值