码迷,mamicode.com
首页 > 其他好文 > 详细

String类

时间:2015-07-25 23:06:37      阅读:266      评论:0      收藏:0      [点我收藏+]

标签:string类

public class StringDemo {
	public static void main(String[] args) {
		String s1="abc";//s1是一个类型变量,"abc"是一个对象
						//字符串最大特点:一旦被初始化就不可以改变。
		String s2=new String("abc");
		//s1="kk";//s1指向kk,"abc"已初始化,并没有变
		//System.out.println(s1);
		//s1和s2有什么区别
		//s1在内存有一个对象
		//s2在内存中有两个对象
		System.out.println(s1==s2);//不相等,比较是内存地址
		System.out.println(s1.equals(s2));//String类复写了Object类中equals
										  //该方法用于判断字符串是否相同
	}
}

/*
 * String类适用于描述字符串事物
 * 那么它就提供了多个方法对字符串进行操作
 * 常见的操作有哪些方法?
 * "abcd"
 * 1.获取
 * 	1.1 字符串中包含的字符数,也就是字符串的长度
 *  int length();获取长度
 *  1.2 根据位置获取位置上某个字符
 *  char charAt(int index);
 *  1.3根据字符串该字符在字符中第一次出现的位置
 *  int indexOf(int ch):返回的是ch在字符串第一次出现的位置,没有找到返回-1
 *  int indexOf(int ch,int formIndex):从formIndex指定位置开始,获取ch在字符串第一次出现的位置,没有找到返回-1
 *  int indexOf(String str):返回的是字符串str在字符串第一次出现的位置,没有找到返回-1
 *  int indexOf(String str,int formIndex):从formIndex指定位置开始,获取字符串str第一次出现的位置,没有找到返回-1
 *  int lastOf(int ch):反向索引一个字符出现的位置,没有找到返回-1
 *  int lastOf(int ch,int formIndex):反向索引formIndex开始,一个字符出现的位置,没有找到返回-1
 *  int lastOf(String str):反向索引一个字符串出现的位置,没有找到返回-1
 *  int lastOf(String str,int formIndex):反向索引formIndex开始,一个字符出现的位置,没有找到返回-1
 * 2.判断
 *  2.1 字符串中是否包含某一个子串
 *   boolean contains(str)
 *   特殊之处:indexOf(str):可以索引str第一次出现位置,如果返回-1,表示该字符str不在字符串中存在
 *   所以,也可以用于对指定判断是否包含
 *   if(str.indexOf("aa")!=-1)
 *   而且该方法即可判断,有可以获取出现的位置
 *  2.2 字符串是否有内容。
 *  boolean isEmpty():原理就是判断长度是否为0
 *  2.3 字符串是否是以指定内容开头
 *   boolean startsWith(str)
 *  2.4 字符串是否以指定内容结尾
 *   boolean endWith(str)
 *  2.5 判断字符串内容是否相同,复写了Object类中的equals方法
 *  boolean equals(str);
 *  2.6 判断内容是否相同 ,并忽略大小写
 *  boolean equalsIgnoreCase();
 *  3转换
 *  3.1 将字符数组转换成字符串
 *  构造函数:String(char[])
 *  	   String(char[],offset,count):将字符数组中的一部分转换成字符串
 *  静态方法
 *  static String copyValue(char[]);
 *  static String copyValueOf(char[] data,int offset,int count)
 *  static String value(char[])
 *  3.2 将字符串转换成字符数组
 *  toCharArray(String str);
 *  3.3 将字节数组转换成字符串
 *  	String(byte[])
 *  	String(byte[],offset,count):将字符数组中的一部分转换成字符串
 *  3.4 将字符串转换成字节数组
 *  	byte[] getBytes
 *  3.5 将基本数据类型转换成字符串.
 *  static String valueOf(object)
 *  字符中和字节数组转换过程中,是可以指定编码表的
 *  4.替换
 *  String replace(oldchar,newchar);
 *  5.切割
 *  String[] split(regex)
 *  6.子串
 *  substring(begin)
 *  substring(begin,end)
 *  7.转换,去除空格 ,比较
 *  7.1将字符串转换成大写或小写
 *  String toUpperCase();
 *  String toLowerCase();
 *  7.2将字符串两端的多个空格去除
 *  String trim();
 *  7.3对丙个字符串进行自然顺序的比较 
 *  int compareto(String)
 */
public class StringMethodDemo {
	public static void method_7(){
		String s="    Hello Java";
		sop(s.toUpperCase());
		sop(s.toLowerCase());
		sop(s.trim());//用户登录时使用,注册邮件时用
		String s1="abc";
		String s2="aAA";
		sop(s1.compareTo(s2));
	}
	public static void method_sub(){
		String s="abcdef";
		sop(s.substring(2));//从指定位置开始到结尾,如果角标不存在,就会存在角标越界导常
		sop(s.substring(2, 4));//包含头,不包含尾s.substring(0,str.lentgh)
	}
	public static void method_split(){
		String s="zhangsha,lisi,wangwu";
		String [] arr=s.split(",");
		for(int i=0;i<arr.length;i++)
			sop(arr[i]);
	}
	public static void method_replace(){
		String str="100,000,000";
		sop(str.replace("", ""));
		String s="hello java";
		String s1=s.replace("java", "world");
		sop("s="+s);
		sop("s1="+s1);
	}
	public static void method_trans(){
		char[] arr={'a','b','c','d','e'};
		
	}
	public static void method_is(){
		String str="ArrayDemo.java";
		//判断文件名称是否是Array单词开头
		sop(str.startsWith("Array"));
		//判断文件名称是.java的文件
		sop(str.endsWith(".java"));
		//判断文件中是否包含Demo
		sop(str.contains("Demo"));
		sop(str.equalsIgnoreCase("ARRAYDEMO.JAVA"));
	}
	public static void method_get(){
		String str="abcdefakf";
		//长度
		sop(str.length());
		//根据索引获取字符
		sop(str.charAt(4));
		//获取第一次出现位置
		sop(str.indexOf('a'));
		sop(str.indexOf('a',3));
		sop(str.indexOf("abc"));
		sop(str.indexOf("abc",3));
		sop(str.lastIndexOf("a"));
		sop(str.lastIndexOf("a",2));
		sop(str.lastIndexOf("abc"));
		sop(str.lastIndexOf("abc",2));
	}
	public static void main(String[] args) {
		/*String s1="abc";
		String s2=new String("abc");
		String s3="abc";//"abc"已在常量池中.内存中已经存在,不需要重新开辟空间
		System.out.println(s1==s2);//falase
		System.out.println(s1==s3);//true
		 */		
		//method_get();
		method_is();
		method_replace();
		method_split();
		method_sub();
		method_7();
	}
	public static void sop(Object o){
		System.out.println(o);
	}
}


 

版权声明:本文为博主原创文章,未经博主允许不得转载。

String类

标签:string类

原文地址:http://blog.csdn.net/u012750578/article/details/47060215

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!