黑马程序员-- Java基础---> String类与包装类

来源:互联网 发布:淘宝找果服务靠谱吗 编辑:程序博客网 时间:2024/05/18 03:54


------Java培训、Android培训、iOS培训、.Net培训、期待与您交流! -------

                                  第一讲  String类

一、String类概述   

  String类适用于描述字符串事物。每个用双引号括起来的字符串都是String类的一个实例。字符串是一个特殊的对象。特殊之处就在于: Stings= new String();和String s1=””;两种写法都是在创建对象,使用起来一样。

二、特点

 1、String是一个final的类型,即不可被继承修改,一经初始化就终生不可改变。

 2、通过String创建的对象分别可存在于字符串池(StringPool)和堆内存中。

例:

String s1 = "abc";//s1是一个类类型变量, "abc"是一个对象。String s2 = new String("abc");//s1和s2有什么区别? //s1在内存中有一个对象。//s2在内存中有两个对象。new创建了一个,abc代表一个String s3 = "abc";//在常量池中寻找,故不重新开辟空间,s3和s1都指向“abc”System.out.println(s1==s2);//--->falseSystem.out.println(s1==s3);//--->trueSystem.out.println(s1.equals(s2));//--->true,因为String类复写了Object类中equals方法,该方法用于判断字符串是否相同。

3、对常量池的理解---->StringPool(字符串池):
在java的内存分配中,存在着一个方法区,这里有一个常量池,是存放那些常量等不变的值,StringPool即字符串池就是存在于这里,它是一个存放字符串的公共存储池。字符变量指向存储池中的相应位置。如果是通过复制一个字符串变量,原始的字符串和复制的字符串将共享这个相同的字符串。


三、常见的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 equalsIgnoreCase();
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、替换
   String replace(oldchar,newchar);
5、切割
   String[] split(regex);
6、子串。获取字符串中的一部分。
   String substring(begin);
   String substring(begin,end);
7、转换,去除空格,比较。
  7.1 将字符串转成大写或则小写。
   String toUpperCase();
   String toLowerCase();
  7.2 将字符串两端的多个空格去除。
   String trim();
7.3 对两个字符串进行自然顺序的比较。
   int compareTo(string);
实例练习:

1、

/* 需求:将一个字符串反转 ,并能将字符串中指定部分进行反转思路:1、将字符串转换为字符数组     2、将数组反转     3、将字符数组转换为字符串 */  public class test01_ReverseString {public static void main(String[] args) {String s="abcd  efgh";          sop(s);  //      ReverseString r=new ReverseString();  //      sop(new ReverseString().reverseString(s));         sop(ReverseString.reverseString(s));  //因为方法静态的,类直接调用}public static void sop(Object obj)      {          System.out.println(obj);      }  }class ReverseString  {            public static String  reverseString(String s,int start,int end)      {          //将字符串变为字符数组          char[] chs=s.toCharArray();            //将数组进行反转          charReverse(chs,start,end);                    //将字符数组变为字符串          return new String(chs);        }      //反转整个字符串      public static String reverseString(String s)      {          return reverseString(s,0,s.length());      }            //反转指定字符数组位置      private static void charReverse(char[] ch,int start,int end)      {          for (int x=start,y=end-1; x<y;x++,y--)          {              swap(ch,x,y);          }      }            //交换相应数组元素      private static  void swap(char[] ch, int start,int end)      {             char temp=ch[start];          ch[start]=ch[end];          ch[end]=temp;      }  }  
结果为

2、

import java.util.Arrays;/* 需求:对一个字符串中的字符进行自然排序 ,例如:"bdacxrtq" --> "abcdqrtx";思路:        1、将字符串转换为字符数组。       2、对字符数组进行选择、冒泡排序       3、将排好序的字符数组转换为字符串  */  public class test02_SortString {public static void main(String[] args) {String s1 = "bdacxrtq";System.out.println(s1);// 将字符串转换成数组char[] ch = s1.toCharArray();//定义一个对字符串进行排序的函数 sortString(ch); //将字数组转换成字符串s1 = new String(ch); System.out.println(s1);}private static void sortString(char[] ch) {//2 对数组进行排序Arrays.sort(ch);}}
结果为


3、

/* 需求:获取一个字符串在另一个字符串中出现的次数 思路:1、定义一计数器       2、获得字符串第一次在另个字符中出现的位置       3、从第一次出现的位置后剩余的字符串中继续获取字符串出现的次数,每出现一次,计数器就加一次       3、当获取不到时候,计数停止 */  public class test03_CountString {public static void main(String[] args) { String s="Live the life you love!!";          sop("s="+s);               sop("count="+countString(s,"ve"));  }public static int countString(String s,String key)      {          int count=0;//定义计数器          int index=0;//定义获取角标变量          while((index=s.indexOf(key,index))!=-1)//如果包含,则继续          {              index=index+key.length();//从找到的子串位置后一位开始获取              count++;          }          return count;      }        private static  void sop(Object obj)      {          System.out.println(obj);      }    }
结果为


4、

/* 需求:获取两个字符串中最大相同子串 思路:1、将短的一个字符串与长的进行比较,如果没有,则将短串的字串按长度递减的方式获取     2、将每次获取的子串,去长串中判断是否包含,包含即找到。 */  public class test04_MaxSubString {public static void main(String[] args) {String s1="HelloafsfWorldcgagb!";          String s2="fWorldafdffsfsfsfsfdc";          sop("s1="+s1);        sop("s2="+s2);        sop(getMaxSubstring(s1,s2));  }public static String getMaxSubstring(String s1,String s2)      {          String max,min;          max=(s1.length()>s2.length())?s1:s2;//判断出大字符串          min=(max==s1)?s2:s1;//判断出小字符串            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))//如果长串包含,则表示找到                      return temp;              }          }          return "没有相同的字符串";      }        //打印输出      public static void sop(Object obj)      {          System.out.println(obj);      }  }
结果为




                       第二讲  StringBuffer类
一、概念

StringBuffer是字符串缓冲区。是一个容器。
二、特点
1,长度是可变化的。(数组是固定的)
2,可以字节操作多个数据类型。(数组只能操作一个)
3,最终会通过toString方法变成字符串。

三、常见操作方法
C create U update R read D delete
1,存储。
StringBuffer append():将指定数据作为参数添加到已有数据结尾处。
StringBuffer insert(index,数据):可以将数据插入到指定index位置。
2,删除。
StringBuffer delete(start,end):删除缓冲区中的数据,包含start,不包含end。
StringBuffer deleteCharAt(index):删除指定位置的字符。
3,获取。
char charAt(int index) 
int indexOf(String str) 
int lastIndexOf(String str) 
int length() 
String substring(int start, int end) 
4,修改。
StringBuffer replace(start,end,string);
void setCharAt(int index, char ch) ;
5,反转。
StringBuffer reverse();
6,将缓冲区中指定数据存储到指定字符数组中。
void getChars(int srcBegin, int srcEnd, char[] dst, int dstBegin) 
,JDK1.5 版本之后出现了StringBuilder.
StringBuffer是线程同步。
StringBuilder是线程不同步。
以后开发,建议使用StringBuilder
升级三个因素:
1,提高效率。
2,简化书写。
3,提高安全性。
                     第三讲  基本数据类型对象包装类
一、基本数据类型对象包装类。

byte Byte
short short
int Integer
long Long
boolean Boolean
float Float
double Double
char Character
基本数据类型对象包装类的最常见作用,就是用于基本数据类型和字符串类型之间做转换。
二、基本数据类型转成字符串。
基本数据类型+""
基本数据类型.toString(基本数据类型值);
如: Integer.toString(34);//将34整数变成"34";
三、字符串转成基本数据类型。
静态:
xxx a = Xxx.parseXxx(String);
int a = Integer.parseInt("123");
double b = Double.parseDouble("12.23");
boolean b = Boolean.parseBoolean("true");
非静态:
Integer i = new Integer("123");
int num = i.intValue();
四、十进制转成其他进制。
toBinaryString();
toHexString();
toOctalString();
其他进制转成十进制。
parseInt(string,radix);
五、JDK1.5版本以后出现的新特性:
自动装箱和拆箱。
              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范围内容,对于新特性,如果该数值已经存在,则不会在开辟新的空间。



0 0
原创粉丝点击