string 获取 判断 转换 替换 切割 子串 转换

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 转换
3.1将字符数组转换成字符串
构造函数:String(char[])
String(char[],offset,count);将字符数组中的一部分转换成字符串

静态方法:static String copyValueOf(char[]); 
 static String copyValueOf(char[] data, int offset ,int count)

static String valueOf(char[]);


3.2将字符串转成字符数组 *****
char[]  toCharArray();

3.3将字节数组转成字符串
String(byte[])
String(byte[],offset,count);将字节数组中的一部分转换成字符串

3.4将字符串转成字节数组
byte[] getByte();
3.5将基本数据类型转换成字符串。
static String valueOf(int);
static String valueOf(double);
特殊注意:字符串和字节数组在转换过程中,是可以指定编码表的。

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  替换
String replace (oldchar,newchar);
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  切割
String[]  split(regex);
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();
	}
}

6子串,获取字符串中的一部分
String substring (begin);
String substring (begin,end);
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();
	}
}

7转换 ,去除空格,比较
7.1将字符串转成大写,或者小写
String toUpperCase();
String toLowerCase() ;

7.2将字符串两端的多个空格去除
String trim();
7.3对两个字符串进行自然顺序的比较
int  compareTo(string);
 

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);
	}
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值