标签: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类
原文地址:http://blog.csdn.net/u012750578/article/details/47060215