String
特点
1:String是一个对象
2:String是一个常量,不可以被改变
3:String s1 = "abc" ; 和 String s2 = new String ("abc");的区别!
4:String判断 equals的判断,是判断字符串是否相同。
字符串最大的特点:一旦被初始化,就不可以被改变。
class Test
{
public static void main(String[] args)
{
String s1 = "abc" ; //S1是一个类类型变量,“abc”是一个对象
//字符串最大的特点:一旦被初始化,就不可以被改变。
s1 = "kk"; //这个不是改变abc的对象内容;而是改变了s1指向的地址。
System.out.println(s1); //输出结果是kk
}
}
String s1 = "abc" ;
String s2 = new String ("abc");
s1和s2的区别
s1在内存中有一个对象,“abc”
s2在内存中有两个对象,分别是 new 和 “abc”。
s1.equals(s2)
String类复写了Object类中的equals方法。该方法用于判断字符串是否相同。
class Test
{
public static void main(String[] args)
{
String s1 = "abc" ;
String s2 = new String ("abc");
String s3 = "abc";
System.out.println(s1==s2); //输出结果为false,因为是s2有两个对象;
System.out.println(s1.equals(s2)); //输出结果为true,因为地址值相同;
//String类复写了Object类中的equals方法,该方法用于判断字符串是否相同。
System.out.println(s1==s3); /*输出结果为true,当创建完s1的对象“abc”后,
s3创建时,因为内从中已经有了abc,就不会再单独创建。*/<pre name="code" class="java"><span style="font-family: Arial, Helvetica, sans-serif;"> /*s1和s2的区别s1在内存总有一个对象,“abc”s2在内存中有两个对象, </span><pre name="code" class="java"> <span style="font-family: Arial, Helvetica, sans-serif;"> 分别是 new 和 “abc”。equals 判断字符串,判断的是字符串内容是否相同。*/
}
}</span>
String类是用于描述字符串事物。
提供了多个方法对字符串进行操作。
常见操作有:
1.获取
1.1 字符串中包含的字符数,也就是字符串的长度。
int length(); 获取长度。
1.2获取指定脚标上的字符。
char charAt(int index);
1.3获取该字符(字符串)位置的脚标。
int indexOf(int ch); 返回的是ch在字符串中第一次出现的位置。
int indexOf (int ch, int fromIndex) 从fromIndex指定位置开始获取,ch在字符串中出现的位置。
int indexOf(String str); 返回的是str在字符串中第一次出现的位置。
int indexOf (String str , int fromIndex) 从fromIndex指定位置开始获取,str在字符串中出现的位置。
int lastIndexOf(int ch); 反向索引ch在字符串中第一次出现的位置。
int lastIndexOf (int ch, int fromIndex) 反向索引,从fromIndex指定位置开始获取,ch在字符串中出现的位置
class Test
{
public static void method_get()
{
String str = "abcdefghav" ;
sop(str.length()); //长度
sop(str.charAt(4)); //根据索引获取字符
sop(str.indexOf('b')); //根据字符获取索引
sop(str.indexOf('a',2)); //指定起始位置,根据字符获取索引
sop(str.indexOf('z',2)); //如果没有找到,返回-1.
sop(str.lastIndexOf('d')) //反响索引
}
public static void sop(Object obj)
{
System.out.println(obj);
}
public static void main(String[] args)
{
method_get();
}
}
2 判断
2.1 字符串中是否包含某一个子串
boolean contains(str);
特殊之处:indexOf(str);可以索引str第一次出现的位置,如果返回-1.表示str中不存在与字符串中。
所以,也可以用于对指定判断是否包含。
if(str.contains("aa")!=-1); 就是包含。
而且该方法既可以判断,又可以获取出现的位置。
2.2字符串中是否有内容
boolean isEmpty();原理就是判断长度是否为0.
2.3字符串 是否是以指定内容开头
boolean startsWith(str);
2.4字符串是否是以指定内容结尾
boolean endsWith(str);
2.5判断字符串内容是否相同,复写了Object类中的equals方法。
boolean equals(str);
2.6判断内容是否相同,忽略大小写。
boolean equalsIngoreCase();
class Test
{
public static void method_is()
{
String str = "ArrayDemo.java";
sop(str.startsWith("Array")); //判断文件名称是否已Array开头
sop(str.endsWith(".java")); //判断文件类型是否是.java
sop(str.contains("Demo")); //判断文件中是否包含Demo
sop(str.isEmpty()); //判断字符串长度是否为零
}
public static void sop(Object obj)
{
System.out.println(obj);
}
public static void main(String[] args)
{
method_is();
}
}
3 转换
class Test
{
public static void method_trans()
{
char[] arr = {'a','b','c','d','e','f'};
byte[] by = {'a','b','c','d','e','f'};
String str = "abcdefg";
String s = new String(arr); //构造函数,打印函数
sop("s="+s);
String s1 = new String(arr,2,3); //构造函数,将字符数组中的一部分转换成字符串
sop("s1="+s1);
String s3 = new String(by,2,3); //将字节数组转成字符串
sop("s3"+s3);
char[] c = str.toCharArray(); //将字符串转成字符数组
for (int x=0;x<c.length ;x++ )
{
sop("char c=["+c[x]+"]");
}
byte[] c1 =str.getBytes(); //将字符串转成字节数组
for (int x=0;x<c1.length ;x++ )
{
sop("char c1=["+c1[x]+"]");
}
}
public static void sop(Object obj)
{
System.out.println(obj);
}
public static void main(String[] args)
{
method_trans();
}
}
4 替换
class Test
{
public static void method_replace()
{
String r = "hello java";
sop("r="+r); //输出:r=hello java
String r1 = r.replace("a","e"); //替换字符
sop("r1="+r1); //输出:r1=hello jeve,在新字符串上改变。
sop("r="+r); //输出:r=hello java,因为字符串不变特性
String r2 = r.replace("d","e"); //如果要替换的字符不存在,返回的还是远串
sop("r2="+r2);
String r3 = r.replace("java","doc"); //替换多个字符
sop("r3="+r3); //输出:r1=hello doc,在新字符串上改变。
sop("r="+r); //输出:r=hello java,因为字符串不变特性
}
public static void sop(Object obj)
{
System.out.println(obj);
}
public static void main(String[] args)
{
method_replace();
}
}
5 切割
class Test
{
public static void method_split()
{
String s = "zhangsan,lisi,wangwu";
String[] arr = s.split(","); //切割
for(int x=0 ;x<arr.length; x++)
{
sop(arr[x]); /*输出结果
zhangsan
lisi
wangwu
*/
}
}
public static void sop(Object obj)
{
System.out.println(obj);
}
public static void main(String[] args)
{
method_split();
}
}
class Test
{
public static void method_sub()
{
String s = "abcdefg";
sop(s.substring(3)); //从指定位置开始到结尾
sop(s.substring(3,5)); //包含头,不包含尾
}
public static void sop(Object obj)
{
System.out.println(obj);
}
public static void main(String[] args)
{
method_sub();
}
}
class Test
{
public static void method_case()
{
String s = " Hello Java ";
sop(s.toUpperCase()); //全大写
sop(s.toLowerCase()); //全小写
sop(s.trim()); //去除空格
String s1= "xyz";
String s2= "bcdf";
sop(s1.compareTo(s2)); //比较两个字符串 转int后的大小
}
public static void sop(Object obj)
{
System.out.println(obj);
}
public static void main(String[] args)
{
method_case();
}
}
练习
/*
1.模拟一个trim方法,去除字符串两端的空格。
思路
1 判断字符串第一个位置是否是空格,如果是继续向下判断,直接到不是空格为止。
结尾处判断空格也是如此。
2 当开始和结束都判断到不是空格时,就是要获取的字符串。
*/
class Test
{
public static String myTrim(String str)
{
int start =0 ;
int end =str.length()-1;
while (start<=end && str.charAt(start)==' ')
start++;
while (start<=end && str.charAt(end)==' ')
end--;
return str.substring(start,end+1);
}
public static void main(String[] args)
{
String str = " abc c ";
sop(myTrim(str));
}
public static void sop(String str)
{
System.out.println(str);
}
}
/*
2将一个字符串进行反转,将字符串中指定部分进行反转,“abcdefg”-abfedcg
思路
1,将字符串变成数组,。
2,对数组反转
3,将数组变成字符串。
*/
class Test
{
public static String reverseString(String s,int start,int end)
{
char[] chs = s.toCharArray(); //字符串边数组
reverse(chs,start,end); //反转数组
return new String(chs); //将数组变成字符串
}
public static String reverseString(String s)
{
return reverseString(s,0,s.length()); //调用,并整串反转
}
private static void reverse(char[] arr,int x,int y)
{
for(int start=x,end=y-1;start<=end;start++,end--)
swap(arr,start,end);
}
private static void reverse(char[] arr)
{
for(int start=0,end=arr.length-1;start<=end;start++,end--)
swap(arr,start,end);
}
private static void swap(char[] arr,int start,int end)
{
char s = arr[start];
arr[start]=arr[end];
arr[end]=s;
}
public static void main(String[] args)
{
String str = "abcdefg";
sop(str);
sop(reverseString(str)); //调换整个字符串
sop(reverseString(str,2,6)); //调换指定字符
}
public static void sop(String str)
{
System.out.println(str);
}
}
/*
3获取一个字符串,在另一个字符串中出现的次数。
“abkkcdkkefkkskk”
思路
1,定义个计算器,
2,获取kk第一次出现的位置。
3,从第一次出现位置后,从剩余的字符串中继续获取kk出现的位置。
每获取一次就计数一次。
4,当获取不到时,计算完成。
*/
class Test
{
public static int getSubCount_2(String str,String key)
{
int count = 0 ;//出现次数
int index = 0;//出现位置脚标
while((index=str.indexOf(key,index))!=-1)
{
sop("index="+index);
index = index+ key.length();
count++;
}
return count ;
}
public static void main(String[] args)
{
String str = "abkkcdkkefkkskk";
sop("count="+getSubCount_2(str,"kk"));
}
public static void sop(String str)
{
System.out.println(str);
}
}
/*
4,获取两个字符串中最大相同子串,第一个动作:将短的那个串进行长度依次递减的子串打印
"abcwerthelloyuiodef"
"chvhellobnm"
思路:
1,将短的那个子串按照长度递减的方式获取到。
2,将没获取到的子串去长串中判断是否包含
如果包含,已经找到
*/
class Test
{
public static String getMaxSubring(String s1,String s2)
{
String max="",min="";
max=(s1.length()>s2.length())?s1:s2;
min=(max==s1)?s2:s1;
sop("max="+max);
sop("min="+min);
for (int x= 0;x<min.length() ;x++ )
{
for (int y=0,z=min.length()-x;z!=min.length()+1 ;y++,z++ )
{
String temp = min.substring(y,z);
if(max.contains(temp)) //或者 if(max.indexOf(temp)!=-1)
return temp;
}
}
return "";
}
public static void main(String[] args)
{
String s1 = "abcwerthelloyuiodef";
String s2 = "chvhellobnm";
sop(getMaxSubring(s1,s2));
}
public static void sop(String str)
{
System.out.println(str);
}
}