黑马程序员——Java基础--String类与基本数据类型对象包装类
2015-06-29 22:14
976 查看
------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.曾经学习过对数组的元素 c9eb 进行反转。 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); } }
相关文章推荐
- java对世界各个时区(TimeZone)的通用转换处理方法(转载)
- java-注解annotation
- java-模拟tomcat服务器
- java-用HttpURLConnection发送Http请求.
- java-WEB中的监听器Lisener
- Android IPC进程间通讯机制
- Android之获取手机上的图片和视频缩略图thumbnails
- android string.xml文件中的整型和string型代替
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- 介绍一款信息管理系统的开源框架---jeecg
- 聚类算法之kmeans算法java版本
- java实现 PageRank算法
- PropertyChangeListener简单理解
- 插入排序
- 冒泡排序
- 堆排序