黑马程序员——Java语言基础:String、基本数据类型对象包装类

来源:互联网 发布:windows kit 8.1 编辑:程序博客网 时间:2024/04/27 23:42
------Java培训、Android培训、iOS培训、.Net培训、期待与您交流! -------

一、String

1.概念:String是字符串的类类型,用于描述字符串事物。字符串是一个特殊的对象。

    特殊之处在于:Stings= new String( );和String s1=" ";两种写法都是在创建对象,使用起来一样。

2.特点:字符串最大的特点就是,一旦被初始化就不可以被改变。

     例:

String s1=“abc”;

String s2 = new String(“abc”);

String s3=“abc”;

比较的结果:

s1==s2   ( false )

s1.equals(s2) ( true )

※ String类复写了Object类中的equals方法,该方法用于判断字符串内容是否相同。

s1==s3   ( true )  

※ 因为“abc”这个字符串对象已经在内存中存在,作为字符串这种特殊的对象,这种在常量池中存在的数据。s3进行初始化时,发现abc已经在内存中存在,就不会再独立开辟空间,因为再开辟空间就比较浪费空间。因此为了节约内存,在字符串对象当中只要字符串相同,那么s1和s3就指向同一个对象。

※ s1和s2的区别:s1在内存中有一个对象;s2在内存中有两个对象。            

 

3.常见操作方法

(1)获取

a.字符串中包含的字符数,也就是字符串的长度

int   length():获取长度。

b.根据位置获取位置上的某个字符

char  charAtint  index):当访问到字符串中不存在的角标时,会发生字符串角标越界的错误。

c.根据字符获取该字符存在字符串的位置

int  indexOfint ch):返回的是ch在字符串中第一次出现的位置,传入的是字符对应的ASCII码,如果没有找到,返回-1

int  indexOf(int ch,int fromIndex):从fromIndex指定位置开始,获取ch在字符串中出现的位置。

int  indexOf(String str):返回的是str在字符串中第一次出现的位置。

int  indexOf(String str,int fromIndex):从fromIndex指定位置开始,获取str在字符串中出现的位置。

int  lastIndexOf():反向索引 

(2)判断

a.字符串中是否包含某一个子串

boolean contains(str);

※ indexOf(str)可以索引str第一次出现的位置,如果返回-1表示该str不在字符串中存在,所以,也可以用于对指定判断是否包含。如:if(str.indexOf("aa")!=-1)而且该方法既可以判断,又可以获取出现的位置;如果只为判断,用contains。

b.字符串中是否有内容

boolean ifEmpty();//原理就是判断长度是否为0。

c.字符串是否是以指定内容开头

boolean startsWith(str);

d.字符串是否是以指定内容结尾

boolean endsWith(str);

e.判断字符串内容是否相同,复写了Object类中的equals方法

boolean equals(str);

f.判断内容是否相同,并忽略大小写。

boolean equalsIgnoreCase();

(3)转换

a.将字符数组转成字符串

构造函数:String (char[]);

String(char[],offset,count);(将字符数组中的一部分转成字符串)

静态方法:static String copyValueOf(char[])

staticString copyValueOf(char[] data,int offset ,int count );

static String valueOf(char[]);

b.将字符串转成字符数组

char[]toCharArray()

c.将字节数组转成字符串

String (byte[]);

String(byte[],offset,count);(将字节数组中的一部分转成字符串。count表示个数)

d.将字符串转成字节数组

byte[]getBytes();

f.将基本数据类型转成字符串

StringvalueOf(int);

StringvalueOf(double);

※ 字符串和字节数组在转换过程中,是可以指定编码表的

(4)替换

        Stringreplace(oldchar,newchar);(返回的是一个新字符串。如果要替换的字符不存在,返回的还是原字符串)

(5)切割

        String[] split(regex);(涉及到正则表达式的点,不能作为切割字符串的regex)

(6)子串,获取字符串中的一部分

        String substring(begin);(从指定位置开始到结尾,如果角标不存在,会出现字符串角标越界异常)

        Stringsubstring(begin,end);(含头不含尾)

(7)转换,去除空格,比较

a.将字符串转成大写或小写

StringtoUpperCase();

String toLowerCase();

b.将字符串两端的多个空格去除

String trim();        

c.对两个字符串进行自然顺序的比较

intcompareTo(String);

例:

public class StringMethodDemo {public static void method_get()//获取{String str = "abcdeakpf";sop(str.length()); //长度sop(str.charAt(4)); //根据索引获取字符,当访问到字符串不存在的角标时会发生StringIndexOutOfBoundExceptionsop(str.indexOf('a',3));//如果没有找到,返回-1sop(str.indexOf("cd"));//查找该字符串的索引sop(str.lastIndexOf("a"));//反向索引一个字符出现的位置,从右到左查找}public static void method_is()//判断{String str = "ArrayDemo.java";sop(str.startsWith("Array")); //判断是否Array单词开头sop(str.endsWith(".java"));//判断文件名称是否是.java的文件sop(str.contains("Demo"));//判断文件名中是否包含Demo}public static void method_trans()//转换{char [] arr = {'a','b','c','d','e','f'};String s = new String(arr,1,3); //bcdsop("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_replace()//替换{String s = "        hello java           ";//String s1 = s.replace('a','n'); //如果要替换的字符不存在,返回还是原字符串String s1 = s.replace("java","world");sop("s="+s);sop("s1="+s1);}public static void method_split()//切割{String s = "zhangsan,lisi,wanwu";String[] arr = s.split(",");for(int x = 0; x<arr.length; x++){sop(arr[x]);}}public static void method_sub()//获取子串{String s = "abcdef";sop(s.substring(2)); //从指定位置开始到结尾,如果角标不存在,会出现字符串角标越界异常sop(s.substring(2,4)); //包含头,不会包含尾。s.substring(0,length);获取整串}public static void method_other()//其他方法{String s = "Hello Java";sop(s.toUpperCase());sop(s.toLowerCase());sop(s.trim());String s1 = "abc";String s2 = "aaa";sop(s1.compareTo(s2)); //等于返回0,s1<s2返回小于0的值,s1>s2返回大于0的值}public static void sop(Object obj){System.out.println(obj);}

二、StringBuffer

1. 概念StringBuffer是字符串缓冲区(容器),字符串的组成原理就是通过该类实现的。

      StringBuffer可以对字符串内容进行增删改查等操作,很多方法和String相同。

2. 特点:(与数组相比较)

(1)而且长度是可变化的。(数组是固定的)

(2)可以直接操作多个数据类型。(数组只能操作一个)

(3)最终会通过toString方法变成字符串。 

3. 常见操作

(1)存储

        StringBuffer append():将指定数据作为参数添加到已有数据的结尾处。

        StringBuffer insert(intoffset ,数据):可以将数据插入到指定offset位置。

(2)删除

        StringBufferedelete(start,end):删除缓冲区中的数据,包含start,不包含end。

        StringBuffer deleteCharAt(index):删除指定位置的字符。

        清空缓冲区:对象.delete(0,对象.length());

(3)获取

        char charAt(int index);

        int indexOf(String str);

        int lastIndexOf(String str);

        int length();

        String substring(int start,int end);

(4)修改

        StringBuffer replace(int start,int end,String str);

        void setCharAt(int index,char ch);

(5)反转

        StringBuffer reverse();

(6)将缓冲区中指定数据存储到指定字符数组中

        voidgetChars(int srcBegin, int srcEnd,char[] dst,int dstBegin)

※ 在JDK1.5版本之后出现了StringBuilder。

        StringBuffer是线程同步的,有锁,效率低

        StringBuilder是线程不同步的,无锁,效率高

以后开发,建议使用StringBuilder。如遇多线程,使用StringBuffer或自己加锁。

※升级三因素: 提高效率、简化书写、提高安全性

三、基本数据类型对象包装类

1. 概述:基本数据类型对象包装类的最常见作用,就是用于基本数据类型和字符串类型之间做转换

         将基本数据类型封装成对象的好处,在于可以在对象中定义更多的功能方法操作该数据。          

2. 基本数据类型对象包装类包含:

byte Byte

short Short

int Integer

long Long

boolean Boolean

float Float

double Double

char Character

3. 基本数据类型转成字符串

基本数据类型+" "

基本数据类型.toString(基本数据类型值);

例:Integer.toString(20);(将整数20变成字符串"20")

4. 字符串转成基本数据类型

xxx a=Xxx.parseXxx(string);(必须传入对应类型的字符串)

例: int a=Integer.parseInt("123");

      boolean b=Boolean.parseBoolean("true");

Integer i=new Integer("123");

int num=i.intValue();//跟上面的静态方式的结果一样,但这种属于对象调用方式。

5. 十进制转成其他进制

二进制   :toBinaryString(); 

十六进制:toHexString(); 

八进制   :toOctalString();

6. 其他进制转成十进制

parseInt(String,radix);

如:int a= Intager.parseInt("3c",16);

JDK1.5版本以后出现的新特性。

Integer x=new Integer(4);    等效于:Integer x=4;【自动装箱】

还可以直接进行运算:x=x+2;【自动拆箱:x.intValue()】。变成了int类型进行加法运算,再将和进行装箱赋给x 

例:        

Integer x=128;

Integer y=128;

x==y   (false)

Integer m=127;

Integer n=127;

m==n ( true)

※ m和n指向了同一个Integer对象。当数值在byte范围内,对于新特性,如果该数组已经存在,则不会再开辟新的空间。



0 0