黑马程序员——Java String、StringBuffer、StringBuilder、基本数据类型对象包装类

时间:2023-01-18 04:02:32

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

自学Java第七天笔记。本人是根据毕向东老师的JavaSE视频学习的。


Java String、StringBuffer、StringBuilder、基本数据类型对象包装类




一.String。


1.概述:
java中用String类进行描述。对字符串进行了对象的封装。这样的好处是可以对字符串这种常见数据进行方便的操作。对象封装后,可以定义N多属性和行为。
String是字符串的类类型,用于描述字符串事物。


2.特点:
一旦被初始化就不可以被改变。存放在方法区中的常量池中。


3.面试题:
String s1 = "abc";
String s2 = new String("abc");
String s3 = "abc";
s1和s2有什么区别?
s1在内存中有一个对象abc。
s2在内存中有两个对象abc、new。


s1==s2   ( false )
s1.equals(s2) ( true )
String类复写了Object类中的equals方法,该方法用于判断字符串是否相同。


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


4.操作字符串方法:


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();反向索引。


2)、判断:
2.1 字符串中是否包含某一个子串:boolean contains(str);
特殊之处:indexOf(str)可以索引str第一次出现的位置,如果返回-1表示该str不在字符串中存在。所以,也可以用于对指定判断是否包含。
2.2 字符串中是否有内容(长度是否为0):boolean isEmpty();
2.3 字符串是否以指定内容开头:boolean startsWith(str);
2.4 字符串是否以指定内容结尾:boolean endsWith(str);
2.5 判断字符串内容是否相同: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);将字节数组中的一部分转成字符串。count表示个数。
3.4 将字符串转成字节数组:
              byte[] getBytes();
3.5 将基本数据类型转成字符串:
              StringvalueOf(int);
              StringvalueOf(double);
特殊:字符串和字节数组在转换过程中,是可以指定编码表的。


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);
注:如果参数字符串等于此字符串,则返回值0;如果此字符串按字典顺序小于字符串参数,则返回一个小于0的值;如果此字符串按字典顺序大于字符串参数,则返回一个大于0的值。


这7中字符串操作方法代码体现:
(代码 StringMethodDemo.java):
class StringMethodDemo 
{
public static void main(String[] args)
{
method_get();//获取
method_is();//判断
method_trans();//转换
method_replace();//替换
method_split();//切割
method_sub();//获取子串
method_7();
}
public static void sop(Object obj)
{
System.out.println(obj);
}
public static void method_get()//获取
{
String str = "abcdec";
sop(str.length());//长度
sop(str.charAt(3));//根据索引获取字符
sop(str.indexOf('c',3));//根据字符获取索引
sop(str.lastIndexOf('b'));//反向索引
}
public static void method_is()//判断
{
String str = "StringMethodDemo.java";
sop(str.startsWith("String"));//判断文件名称是否是String单词开头。
sop(str.endsWith(".java"));//判断文件名称是否是.java的文件。
sop(str.contains("Demo"));//判断文件中是否包含Demo。
}
public static void method_trans()//转换
{
char[] arr = {'a','b','c','d','e'};
String s = new String(arr);//将字符数组转成字符串。
String s1 = new String(arr,1,3);//注意:1是从角标1开始,3是个数。
sop("s= "+s);
sop("s1= "+s1);
//将字符数组转成字符串。
String str = "asdfg";
char[] chs= str.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');
sop("s="+s);
sop("s1="+s1);
}
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]);
}
public static void method_sub()//获取子串
{
String s = "abcdef";
sop(s.substring(2));//从指定位置到结尾。
sop(s.substring(2,4));//包含头,不包含尾。
}
public static void method_7()
{
String s = " Hello Java ";
sop(s.toUpperCase());//大写
sop(s.toLowerCase());//小写
sop(s.trim());//将字符串两端的多个空格去除。

String s1 = "acc";
String s2 = "aaa";
sop(s1.compareTo(s2));//对两个字符串进行自然顺序的比较。
}

}


5.字符串操作练习:
(代码 StringTest.java):
//练习1:将一个字符串进行反转。
/*
思路:
1,将字符串变成数组。
2,将数组反转。
3,将数组变成字符串。
*/
class StringTest
{
public static void main(String[] args)
{
String s = "abcd";
System.out.println(s);
System.out.println(reverseString(s));
}

public static String reverseString(String str)
{
char[] chs = str.toCharArray();
reverse(chs);
return new String(chs);
}
//反转指定字符数组位置
private static void reverse(char[] arr)
{
for(int start=0,end=arr.length-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;
}
}



(代码 StringTest2.java):
//练习2:获取一个字符串在另一个字符串中出现的次数。

class StringTest2
{
public static void main(String[] args)
{
String str = "asddfgddhhjkdd";
System.out.println(getSubCount(str,"dd"));
}
public static int getSubCount(String str,String key)
{
int count = 0;
int index = 0;
while((index=str.indexOf(key))!=-1)
{
System.out.println(str);
str = str.substring(index+key.length());
count++;
}
return count;
}
}



(代码 StringTest3.java):
//获取两个字符串中的最大相同子串。
/*
思路:
1、将短的一个字符串与长的进行比较,
如果没有,则将短串的字串按长度递减的方式获取。
2、将每次获取的子串,去长串中判断是否包含,包含即找到。
*/
class StringTest3
{
public static void main(String[] args)
{
String s1="asdfhellosfg";
String s2="frhelloy";
System.out.println(getMaxSubstring(s1,s2));
}
public static String getMaxSubstring(String s1,String s2)
{
String max,min;
max=(s1.length()>s2.length())?s1:s2;
min=(s1.length()<s2.length())?s1:s2;

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 "没有相同的字符串";
}

}



二.StringBuffer。


1.概述:
字符串缓冲区,可以对字符串进行增删改查操作,StringBuffer是一个容器。


2.特点:
1)、长度可变。
2)、可以字节操作多个数据类型。
3)、最终会通过toString方法变成字符串。


3.与数组区别:
1)、StringBuffer长度是可变化的。(数组是固定的)。
2)、StringBuffer可以直接操作多个数据类型。(数组只能操作一个)。


4.容器中的方法:
1)、添加。
StringBuffer append(data):在缓冲区中添加数据。添加到尾部。
StringBuffer insert(index,data):在指定位置插入数据。
2)、删除。
StringBuffer delete(start,end);删除从start至end-1范围的元素(包含头,不包含尾)。
StringBuffer deleteCharAt(index);删除指定位置的元素。
注意:例子:sb.delete(0,sb.length());清空缓冲区(包含头,不包含尾)。
3)、获取(查找)。
int indexOf(string); 返回指定子字符串在此字符串中第一次出现处的索引。没有就返回-1。
int indexOf(string,int fromIndex);从指定位置开始查找字符串。
int lastIndexOf(string); 返回指定子字符串在此字符串中最右边出现处的索引。
int lastIndexOf(string,int fromIndex); 从指定的索引开始反向搜索。
string substring(start); 返回start到结尾的子串。
string substring(start,end); 返回start至end-1的子串。
4)、修改。
StringBuffer replace(start,end,string);将start至end-1替换成string。(包含头,不包含尾)。
void setCharAt(index,char);替换指定位置的字符。
void setLength(len);将原字符串置为指定长度的字符串。
5)、反转。
StringBuffer reverse();字符串反转,如果String想反转就要转换成StringBuffer再反转。
6)、将缓冲区中指定数据存储到指定字符数组中。
void getChars(int srcBegin, int srcEnd,char[] dst,int dstBegin)




三.StringBuilder。


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


2.StringBuffer与StringBuilder区别:
1)、StringBuffer是线程同步。(安全)
2)、StringBuilder是线程不同步。(不安全)
以后开发,建议使用StringBuilder。提高效率。如果遇到多线程,使用StringBuffer或自己加锁。


3.升级三因素:
            1)、提高效率。
            2)、简化书写。
            3)、提高安全性。



四.基本数据类型对象包装类。



1.概念:是按照面向对象思想将基本数据类型封装成了对象。


2.好处:
      1)、可以通过对象中的属性和行为操作基本数据。
      2)、可以实现基本数据类型和字符串之间的转换。


3.基本数据类型对象包装类:
byte        Byte
short       Short
int         Integer
long        Long
boolean     Boolean
float       Float
double      Double
char        Character


4.基本数据类型转成字符串:
基本数据类型+" "
基本数据类型.toString(基本数据类型值);
例如:Integer.toString(34);//将34整数变成"34"。


5.字符串转成基本数据类型:
xxx a=Xxx.parseXxx(string);
例如:
int a = Integer.parseInt("123");静态。注意:必须传入数字格式的字符串。
boolean b = Boolean.parseBoolean("true");


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


6.十进制转成其他进制。
转成二进制:toBinaryString
转成八进制:toOctalString
转成十六进制:toHexString


7.其他进制转成十进制。
parseInt(String,radix);
例如:
int x = Integer.parseInt("110",10);
int a = Integer.parseInt("3c",16);


8.在jdk1.5版本后,对基本数据类型对象包装类进行升级。在升级中,使用基本数据类型对象包装类可以像使用基本数据类型一样,进行运算。
Integer i = new Integer(4);  1.5版本之前的写法。
Integer i = 4;  自动装箱,1.5版本后的写法。
i = i + 2;  i进行自动拆箱。变成了int类型。和2进行加法运算。再将和进行装箱赋给i。


9.小知识点:
Integer x=128;
Integer y=128;
x==y   (false)
Integer m=127;
Integer n=127;
m==n   ( true)
在装箱时,如果数值在byte范围之内,那么数值相同,不会产生新的对象,也就是说多个数值相同的引用指向的是同一个对象。