Java 字符串
字符串比较
以下实例中我们通过字符串函数 compareTo (string) ,compareToIgnoreCase(String) 及 compareTo(object string) 来比较两个字符串,并返回字符串中第一个字母ASCII的差值。
实例代码如下:
public class StringCompareEmp {
public static void main(String[] args) {
String str = "Hello Worldm";
String anotherString = "hello world";
Object objStr = str;
// compareTo 比较的是两个字符的ASCII的值,
System.out.println(str.compareTo(anotherString));
// 比较两个字符串不区分大小写
System.out.println(str.compareToIgnoreCase(anotherString)); // 忽略大小写
// objStr.toString() 之后 进行比较
System.out.println(str.compareTo(objStr.toString()));
// 源码是这样的:
/*
public int compareTo(String anotherString) {
int len1 = value.length;
int len2 = anotherString.value.length;
int lim = Math.min(len1, len2);
char v1[] = value;
char v2[] = anotherString.value;
int k = 0;
while (k < lim) {
char c1 = v1[k];
char c2 = v2[k];
if (c1 != c2) {
return c1 - c2;
}
k++;
}
return len1 - len2;
}
*/
//忽略大小写之后的比较
/*
public int compare(String s1, String s2) {
int n1 = s1.length();
int n2 = s2.length();
int min = Math.min(n1, n2);
for (int i = 0; i < min; i++) {
char c1 = s1.charAt(i);
char c2 = s2.charAt(i);
if (c1 != c2) {
c1 = Character.toUpperCase(c1);
c2 = Character.toUpperCase(c2);
if (c1 != c2) {
c1 = Character.toLowerCase(c1);
c2 = Character.toLowerCase(c2);
if (c1 != c2) {
// No overflow because of numeric promotion
return c1 - c2;
}
}
}
}
return n1 - n2;
}
*/
}
}
编译后的结过为:
-32
0
0
源码的判断逻辑是这样的:
首先判断出两者的长度 然后取出最小的长度,对字符串中的每个字符的ASCII码做比较,
如果不一样,那么就返回两者的差值。
如果刚好两者的大小不同,但是一方包含另外一方的时候,这时候返回的就是两者的长度差值忽略了大小写之后 先比较的是两个大写是否一致 如果不一致比较小写的是否一致。对比的依然是ASCII码。
查找字符串最后一次出现的位置
以下实例中我们通过字符串函数 strOrig.lastIndexOf(Stringname) 来查找子字符串 Stringname 在 strOrig 出现的位置:
实例代码如下:
public class SearchlastString {
public static void main(String[] args) {
String strOrig = "Hello world ,Hello Runoob";
int lastIndex = strOrig.lastIndexOf("Runoob");
//好不到的时候返回-1
if(lastIndex == - 1){
System.out.println("没有找到字符串 Runoob");
}else{
System.out.println("Runoob 字符串最后出现的位置: "+ lastIndex);
}
}
}
编译后的结果为:
Runoob 字符串最后出现的位置: 19
删除字符串中的一个字符
以下实例中我们通过字符串函数 substring() 函数来删除字符串中的一个字符,我们将功能封装在 removeCharAt 函数中。
实例代码如下:
public class Main {
public static void main(String args[]) {
String str = "this is Java";
System.out.println(removeCharAt(str, 3));
}
public static String removeCharAt(String s, int pos) {
return s.substring(0, pos) + s.substring(pos + 1);
}
}
编译后的结果为:
thi is Java
字符串替换
public class StringReplaceEmp {
public static void main(String[] args) {
String str="Hllo World";
System.out.println( str.replace( 'H','W' ) );
System.out.println( str.replaceFirst("He", "Wa") );
System.out.println( str.replaceAll("He", "Ha") );
}
}
注意。这个替换是所有符合条件的都替换。。慎用。
编译后的结果为:
WWllo World
HHllo World
HHllo World
字符串反转
以下实例演示了如何使用 Java 的反转函数 reverse() 将字符串反转:
public class StringReverseExample{
public static void main(String[] args){
String string="runoob";
String reverse = new StringBuffer(string).reverse().toString();
System.out.println("字符串反转前:"+string);
System.out.println("字符串反转后:"+reverse);
}
}
编译后的结果为:
字符串反转前:runoob
字符串反转后:boonur
源码是这样的:
public AbstractStringBuilder reverse() {
boolean hasSurrogates = false;
int n = count - 1;
for (int j = (n-1) >> 1; j >= 0; j--) {
int k = n - j;
char cj = value[j];
char ck = value[k];
value[j] = ck;
value[k] = cj;
if (Character.isSurrogate(cj) ||
Character.isSurrogate(ck)) {
hasSurrogates = true;
}
}
if (hasSurrogates) {
reverseAllValidSurrogatePairs();
}
return this;
}
字符串搜索
以下实例使用了 String 类的 indexOf() 方法在字符串中查找子字符串出现的位置,如果存在返回字符串出现的位置(第一位为0),如果不存在返回 -1
public class SearchStringEmp {
public static void main(String[] args) {
String strOrig = "Google Runoob Taobao";
int intIndex = strOrig.indexOf("Runoob");
if(intIndex == - 1){
System.out.println("没有找到字符串 Runoob");
}else{
System.out.println("Runoob 字符串位置 " + intIndex);
}
}
}
编译后的结果为:
Runoob 字符串位置 7
字符串分割
以下实例使用了 split(string) 方法通过指定分隔符将字符串分割为数组:
public class StringReplaceEmp {
public static void main(String[] args) {
String str = "www-runoob-com";
String[] temp;
String delimeter = "-"; // 指定分割字符
temp = str.split(delimeter); // 分割字符串
// 普通 for 循环
for (int i = 0; i < temp.length; i++) {
System.out.println(temp[i]);
System.out.println("");
}
System.out.println("------java for each循环输出的方法-----");
String str1 = "www.runoob.com";
String[] temp1;
String delimeter1 = "\\."; // 指定分割字符, . 号需要转义
temp1 = str1.split(delimeter1); // 分割字符串
for (String x : temp1) {
System.out.println(x);
System.out.println("");
}
}
}
编译后的结果为:
runoob
com
------java for each循环输出的方法-----
www
runoob
com
字符串分隔(StringTokenizer)
Java 中我们可以使用 StringTokennizer 设置不同分隔符来分隔字符串,默认的分隔符是:空格、制表符(\t)、换行符(\n)、回车符(\r)。
以下实例演示了 StringTokennizer 使用空格和等号来分隔字符串:
import java.util.StringTokenizerDemo;
public class Main {
public static void main(String[] args) {
String str = "This is String , split by StringTokenizer, created by runoob";
StringTokenizer st = new StringTokenizer(str);
System.out.println("----- 通过空格分隔 ------");
while (st.hasMoreElements()) {
System.out.println(st.nextElement());
}
System.out.println("----- 通过逗号分隔 ------");
StringTokenizer st2 = new StringTokenizer(str, ",");
while (st2.hasMoreElements()) {
System.out.println(st2.nextElement());
}
}
}
编译后的结果为:
----- 通过空格分隔 ------
This
is
String
,
split
by
StringTokenizer,
created
by
runoob
----- 通过逗号分隔 ------
This is String
split by StringTokenizer
created by runoob
字符串小写转大写
以下实例使用了 String toUpperCase() 方法将字符串从小写转为大写:
public class StringToUpperCaseEmp {
public static void main(String[] args) {
String str = "string runoob";
String strUpper = str.toUpperCase();
System.out.println("原始字符串: " + str);
System.out.println("转换为大写: " + strUpper);
}
}
编译后的结果为:
原始字符串: string runoob
转换为大写: STRING RUNOOB
测试两个字符串区域是否相等
以下实例使用了 regionMatches() 方法测试两个字符串区域是否相等:
public class StringRegionMatchDemo{
public static void main(String[] args){
String first_str = "Welcome to Microsoft";
String second_str = "I work with microsoft";
boolean match1 = first_str.
regionMatches(11, second_str, 12, 9);
boolean match2 = first_str.
regionMatches(true, 11, second_str, 12, 9); //第一个参数 true 表示忽略大小写区别
System.out.println("区分大小写返回值:" + match1);
System.out.println("不区分大小写返回值:" + match2);
}
}
编译后的结果为:
区分大小写返回值:false
不区分大小写返回值:true
字符串性能比较测试
以下实例演示了通过两种方式创建字符串,并测试其性能:
public class StringComparePerformance{
public static void main(String[] args){
String variables[] = new String[50000];
long startTime0 = System.currentTimeMillis();
for (int i = 0; i < 50000; i++) {
variables[i] = "hello";
}
long endTime0 = System.currentTimeMillis();
System.out.println("使用字面量直接赋值字符串,花费时间:" + (endTime0 - startTime0) + "毫秒");
String variables1[] = new String[50000];
long startTime1 = System.currentTimeMillis();
for (int i = 0; i < 50000; i++) {
variables1[i] = new String("hello");
}
long endTime1 = System.currentTimeMillis();
System.out.println("使用字符串对象花费时间:" + (endTime1 - startTime1) + "毫秒");
String variables2[] = new String[50000];
long startTime2 = System.currentTimeMillis();
for (int i = 0; i < 50000; i++) {
variables2[i] = new String("hello");
variables2[i] = variables2[i].intern();
}
long endTime2 = System.currentTimeMillis();
System.out.println("使用字符串对象intern()方法花费时间:" + (endTime2 - startTime2) + "毫秒");
}
}
编译后的结果为:
使用字面量直接赋值字符串,花费时间:1毫秒
使用字符串对象花费时间:2毫秒
使用字符串对象intern()方法花费时间:7毫秒
字符串优化
以下实例演示了通过 String.intern() 方法来优化字符串:
public class StringOptimizationDemo {
public static void main(String[] args){
String variables[] = new String[50000];
for( int i=0;i <50000;i++){
variables[i] = "s"+i;
}
long startTime0 = System.currentTimeMillis();
for(int i=0;i<50000;i++){
variables[i] = "hello";
}
long endTime0 = System.currentTimeMillis();
System.out.println("直接使用字符串: "+ (endTime0 - startTime0) + " ms" );
long startTime1 = System.currentTimeMillis();
for(int i=0;i<50000;i++){
variables[i] = new String("hello");
}
long endTime1 = System.currentTimeMillis();
System.out.println("使用 new 关键字:" + (endTime1 - startTime1) + " ms");
long startTime2 = System.currentTimeMillis();
for(int i=0;i<50000;i++){
variables[i] = new String("hello");
variables[i] = variables[i].intern();
}
long endTime2 = System.currentTimeMillis();
System.out.println("使用字符串对象的 intern() 方法: "
+ (endTime2 - startTime2)
+ " ms");
}
}
编译后的结果为:
直接使用字符串: 1 ms
使用 new 关键字:3 ms
使用字符串对象的 intern() 方法: 6 ms
字符串格式化
以下实例演示了通过 format() 方法来格式化字符串,还可以指定地区来格式化:
import java.util.*;
public class StringFormatDemo {
public static void main(String[] args){
double e = Math.E;
System.out.format("%f%n", e);
System.out.format(Locale.CHINA , "%-10.4f%n%n", e); //指定本地为中国(CHINA)
}
}
编译后的结果为:
2.718282
2.7183
连接字符串
以下实例演示了通过 "+" 操作符和StringBuffer.append() 方法来连接字符串,并比较其性能:
public class StringConcatenateDemo {
public static void main(String[] args){
long startTime = System.currentTimeMillis();
for(int i=0;i<5000;i++){
String result = "This is"
+ "testing the"
+ "difference"+ "between"
+ "String"+ "and"+ "StringBuffer";
}
long endTime = System.currentTimeMillis();
System.out.println("字符串连接"
+ " - 使用 + 操作符 : "
+ (endTime - startTime)+ " ms");
long startTime1 = System.currentTimeMillis();
for(int i=0;i<5000;i++){
StringBuffer result = new StringBuffer();
result.append("This is");
result.append("testing the");
result.append("difference");
result.append("between");
result.append("String");
result.append("and");
result.append("StringBuffer");
}
long endTime1 = System.currentTimeMillis();
System.out.println("字符串连接"
+ " - 使用 StringBuffer : "
+ (endTime1 - startTime1)+ " ms");
}
}
编译后的结果为:
字符串连接 - 使用 + 操作符 : 1 ms
字符串连接 - 使用 StringBuffer : 4 ms
源地址:Java 实例
github地址:Java学习