------
Java培训、Android培训、iOS培训、.Net培训、期待与您交流! -------
第一讲、String类
一、概念
字符串是一个特殊的对象。通过一个例子了解认识String类。
class StringDemo { public static void main(String[] args) { //s1是一个类类型变量,"abc"是一个对象。 String s1 = "abc"; //字符串最大特点,一旦被初始化就不可以被改变。 String s2 = new String("abc"); /* s1和s2有什么区别? s1在内存中有一个对象。 s2在内存中有两个对象。 */ System.out.println(s1==s2);//false System.out.println(s1.equals(s2));//true //String类复写了Object类中的equals方法,该方法用于判断字符串是否相同。 } }
二、String类常用方法
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):反向索引
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 endsWith(str);
2.5 判断字符串内容是否相同。复写了Object类中的equals方法。
boolean equals(str);
2.6 判断内容是否相同,并忽略大小写。
boolean equalsIgnoreCace();
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[] getBytes{};
3.5 将基本数据类型转换成字符串。
static String ValueOf(int)
static String ValueOf(double)
3+"";//String.ValueOf(3);
特殊:字符串和字节数组在转换过程中,是可以指定编码表的。
4.替换。
Stinge replace(oldchar,newchar);
5.切割
String[] split(regex)
6.子串。获取字符串中的一部分
String substring(begin);
String sunstring(begin,end)
7.转换,去除空格,比较
7.1 将字符串转成大写或者小写。
String toUpperCase();大写
String toLowerCase();小写
7.2 将字符串两端的多个空格去除。
String trim();
7.3 对两个字符串进行自然顺序的比较
int compareTo(String);
示例:
class StringMethodDemo { public static void method_7() { String s = " Hello Java "; sop(s.toLowerCase()); sop(s.toUpperCase()); 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)); //包含头,不含尾, } 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 method_replace() { String s ="hello java"; // String s1 =s.replace('a','n'); <span style="white-space:pre"> </span>//如果要替换的字符不存在,返回的还是原来的字符串。 String s1 =s.replace("java","world"); sop("s="+s); sop("s1="+s1); } public static void method_trans() { char[] arr = {'a','b','c','d','e','f'}; String s= new String(arr,1,3);//bcd sop("s="+s); String s1 = "zxcvbnm"; char[] chs =s1.toCharArray(); for(int x=0;x<chs.length;x++) { sop("ch=="+chs[x]); } } public static void method_is() { String str = "ArrayDemo.java"; //判断文件名称是否是Array单词开头 sop(str.startsWith("Array")); //判断文件名称是否是.java结尾 sop(str.endsWith(".java")); //判断文件名中是否包含Demo sop(str.contains("Demo")); } public static void method_get() { String str = "abcdeakpf"; //长度 sop(str.length()); //根据索引获取字符 sop(str.charAt(4)); //当访问到字符串中不存在的角标时会发出StringIndexOutOfBoundsException,角标越界 //根据字符获取索引 sop(str.indexOf('a'));//如果没有找到,返回-1. sop(str.indexOf('a',3)); //反向索引一个字符出现的位置。 sop(str.lastIndexOf("a")); } public static void main(String[] args) { method_7(); method_sub(); method_split(); method_replace(); method_trans(); method_is(); method_get(); /* String s1= "abc"; String s2= new String("abc"); String s3="abc"; System.out.println(s1==s2); System.out.println(s1==s3); */ } public static void sop(Object obj) { System.out.println(obj); } }
三、String类常用方法练习
1.模拟一个trim方法,去除字符串两端的空格。
思路:
a.判断字符串第一个位置是否是空格,如果是继续向下判断,直到不是空格为止。结尾处判断空格也是如此。
b.当开始和结尾都判断到不是空格时,就是要获取的字符串。
2.将一个字符串进行反转,将字符串中指定部分进行反转,“abcdefg”;abfedcg
思路:
a.曾经学习过对数组的元素进行反转。
b.将字符串变成数组,对数组反转。
c.将反转后的数组变成字符串。
d.只要将反转的部分的开始和结束位置作为参数进行传递即可。
class StringTest { public static void sop(String str) { System.out.println(str); } public static void main(String[] args) { String s = " ab cd "; sop("("+s+")"); // s = myTrim(s); // sop("("+s+")"); sop("("+reverseString(s)+")"); } //练习一,去除字符串连段空格。 public static String myTrim(String str) { int start = 0,end = str.length()-1; while(start<=end && str.charAt(start)==' ') start++; while(start<=end && str.charAt(end)==' ') end--; return str.substring(start,end+1); } //练习二,将字符串反转。 /*思路: 1.将字符串变成数组。 2.对数组反转。 3.讲数组变成字符串。*/
<span style="white-space:pre"> </span>//将指定区间内的字符串反转 public static String reverseString(String s,int start,int end) { //字符串变成数组 char[] chs = s.toCharArray(); //反转数组,根据数组反转方法 reverse(chs,start,end); //将数组变成字符串。 return new String(chs); }
<span style="white-space:pre"> </span>//反转整个字符串 public static String reverseString(String s) { return reverseString(s,0,s.length()); /* //字符串变成数组 char[] chs = s.toCharArray(); //反转数组 reverse(chs); //将数组变成字符串。 return new String(chs); */ } 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 swap(char[] arr,int x,int y) { char temp =arr[x]; arr[x] = arr[y]; arr[y] = temp; } }
3.获取一个字符串在另一个字符串中出现的次数。
“abkkcdkkefkkskk”
思路:
a.顶一个计数器。
b.获取kk第一次出现的位置。
c.从第一次出现的位置后剩余的字符串中继续获取kk出现的位置。每获取一次则计数一次。
d.当获取不到时,计数完成。
4.获取两个字符串中最大相同字符串。第一个动作:将短的那个串进行长度依次递减的子串打印。
“abcwerthelloyuiodef”
"cvhellobnm"
思路:
a.将短的那个子串按照长度递减的方式获取到。
b.将每获取到的子串去长串中判断是否包含。如果包含,已经找到!
class StringTest2 { //练习三 public static int getSubCount(String str,String key) { int count = 0; int index = 0; while((index=str.indexOf(key))!=-1) { sop("str="+str); <span style="white-space:pre"> </span>//获取新的字符串 str = str.substring(index+key.length()); count++; } return count; } //练习三方式二 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);
<span style="white-space:pre"> </span>//通过改变起始查询位置来寻找 index = index + key.length(); count++; } return count; } //练习四。 public static String getMaxSubString(String s1,String s2) { //比较字符串的长短 String max = "",min = ""; max = (s1.length()>s2.length())?s1:s2; min = (max==s1)?s2:s1; sop("max="+max+"....min="+min); for(int x=0;x<s2.length();x++) { for(int y=0,z=min.length()-x;z!=min.length()+1;y++,z++) { String temp=min.substring(y,z); // sop(temp); if(max.contains(temp))//if(s1.indexOf(temp)!=-1) return temp; } } return ""; } public static void main(String[] args) { String s1 = "abcwerthelloyuiodef"; String s2 = "cvhellobnm"; sop(getMaxSubString(s1,s2)); String str = "abkkcdkkefkkskk"; //sop("count="+str.split("kk").length);不建议使用 sop("count="+getSubCount_2(str,"kk")); } public static void sop(String str) { System.out.println(str); } }
四、StringBuffer
StringBuffer是字符串缓冲区。是一个容器。
1、特点:
a.而且长度是可变化的。
b.可以操作多个数据类型
c.最终通过toString方法变成字符串。
2、常用方法
2.1存储。
StringBuffer append():将指定数据作为参数添加到已有数据的结尾处。
StringBuffer insert(index,数据);可以将数据插入到指定index位置。
2.2删除。
StringBuffer delete(start,end);删除缓存区中的数据,包含start,不包含end
stringBuffer deleteCharAt(index):删除指定位置的数据。
2.3获取。
char charAt(int index)
int indexOf(String str)
int lastindexOf(String str)
int length()
String substring(int start,int end)
2.4修改。
StringBuffer replace(start,end,str);
void setCharAt(index,char);
2.5反转。
StringBuffer reverse()
2.6将缓冲区中的指定数据存储到指定数组中。
void getChars(int srcBegin,int srcEnd,char[] dst,int dstBegin)
src源 dst目的
JDK1.5 版本之后出现了StringBuilder
StringBuffer是线程同步。
StringBuilder是线程不同步。
以后开发,建议使用StringBuilder
(将StringBuilder的事例用于多个线程是不安全的,如果需要这样的同步,则建议使用StringBuffer。)
class StringBufferDemo { public static void main(String[] args) { // method_updata(); StringBuilder sb = new StringBuilder("abcdef"); char[] chs = new char[4]; sb.getChars(1,4,chs,1); for(int x=0;x<chs.length;x++) { sop("chs("+x+")="+chs[x]+";"); } } public static void method_updata() { StringBuffer sb = new StringBuffer("abcdef"); // sb.replace(1,4,"java"); sb.setCharAt(2,'k'); sop(sb.toString()); } public static void method_del() { StringBuffer sb = new StringBuffer("abcdef"); sop(sb.toString()); sb.delete(1,3); //清空缓存区。 //sb.delete(0,sb.length()); //sb.delete(2,3); sb.deleteCharAt(2); sop(sb.toString()); } public static void method_add() { StringBuffer sb =new StringBuffer(); //方法调用链 sb.append("abc").append(true).append(34); sb.insert(1,"qq"); sop(sb.toString());//aqqbctrue34 /* StringBuffer sb1 =sb.append(34); sop("sb==sb1"+(sb==sb1)); sop(sb.toString()); sop(sb1.toString()); */ } public static void sop(String str) { System.out.println(str); } }
第二讲、基本数据类型对象包装类
一、基本认识
基本数据类型对象包装类。
byte Byte
short Short
int Integer
long Long
boolean Boolean
float Float
double Double
char Character
二、最常见作用
就是用于基本数据类型和字符串类型之间做转换。
1、基本数据类型转成字符串。
基本数据类型+""
基本数据类型.toString(基本数据类型值);
如:Integer.toString(34);//将34整数变成"34";
2、字符串转成基本数据类型。
静态 xxx a = Xxx.parseXxx(String)
int a = Integer.parseInt("123");
double b = Double.parseDouble("123");
boolean b = Boolean.parseBoolean("true");
3、对象调用Integer i = new Integer("123");
int num = i.inValue();
4、十进制转成其他进制。
toBinaryString();
toHexString();
toOctalString();
5、其他进制转成十进制。
parseInt(String,radix);
示例:
class IntegerDemo { public static void main(String[] args) { //整数类型的最大值 //sop("int MAX = "+Integer.MAX_VALUE); <span style="white-space:pre"> </span>//将一个字符串转换成整数。 int num = Integer.parseInt("123");//必须传入数字格式的字符串。 // long x = Long.parseLong("123"); // sop("num="+(num+4)); // sop(Integer.toBinaryString(6)); //使用第二个参数指定的基数,将字符串参数解析为有符号的整数。 int x = Integer.parseInt("3c",16); sop("x="+x); } public static void sop(String str) { System.out.println(str); } }
<*>JDK1.5版本以后出现的新特性。
class IntegerDemo1 { public static void main(String[] args) { // Integer x = new Integer(4); Integer x = 4;//自动装箱//new Integer(4); x = x/*x.inValue()*/ + 2;//x+2:x进行了自动拆箱,变成了int类型,和2进行加法运算再将和进行装箱赋给x。 Integer m =128; Integer n =128; sop("m==n:"+(m==n));//false Integer a =127; Integer b =127; sop("a==b:"+(a==b)); //结果为true。因为a和b指向了同一个Integer对象 //因为当数值在byte范围内,对于新特性,如果该数值已经存在,则不会在开辟新空间。 } public static void method() { Integer x = new Integer("123"); Integer y = new Integer(123); sop("x==y"+(x==y));//false两个对象 sop("x.equals(y)"+x.equals(y));//true,数值相同 } public static void sop(String str) { System.out.println(str); } }