------- android培训、java培训、期待与您交流! ----------
(day13)********************************************************
@@String类
public final class String
String s1 = "abc";//s1是一个类类型变量, "abc"是一个对象。
//字符串最大特点:一旦被初始化就不可以被改变。
String s2 = new String("abc");
s1代表一个对象;s1在内存中有一个对象 "abc"
s2代表两个对象;s2在内存中有两个对象 new String 和 "abc"
字符串在内存中有常量池,池里面是数组,存放abc...
字符串的比较:
s1 == s2;比较的是地址值,false。
s1.equals(s2);String类复写了Object类中equals方法,比较两个字符串的值。
( == 两边是引用数据类变量,则比较地址值;两边是基本数据类型变量,比较具体的值)
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);
@@Stringbuffer 字符串缓冲器!
----字符串的组成原理就是通过该类实现的。
----StringBuffer可以对字符串的内容进行增删。
----StringBuffer是一个容器。
----很多方法和String相同。
----StringBuffer是长度可变的。
StringBuffer是一个容器。
特点:
1,长度是可变化的。
2,可以操作多个数据类型。
3,最终会通过toString方法变成字符串。
StringBuffer(String str)
构造一个字符串缓冲区,并将其内容初始化为指定的字符串内容。
1,存储。
StringBuffer append():将指定数据作为参数添加到已有数据结尾处。
StringBuffer insert(index,数据):可以将数据插入到指定index位置。
2,删除。//清空delete(0,sb.length())
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 的实例用于多个线程是不安全的。如果需要这样的同步,
则建议使用 StringBuffer。
StringBuffer可将字符串缓冲区安全地用于多个线程,可以在必要时对这些方法进行同步,而StringBuilder用在字符串缓冲区被单个线程使用的时候,不能实现同步。
StringBuffer之所以能实现同步是因为它的方法都是同步函数,被synchronized修饰。而StringBuilder中的方法都是普通方法。
下面拿append方法来说:
public synchronized StringBuffer append(Object obj) {
super.append(String.valueOf(obj));
return this;
}
上面这是StringBuffer中的append方法,被synchronized修饰,实现同步。
public StringBuilder append(Object obj) {
return append(String.valueOf(obj));
}
这是StringBuilder中的append方法,就是一般的函数,不能实现同步。
其他函数也是如此,所以StringBuffer比StringBuilder安全,在多进程中能实现同步。
不过在单进程中,这两个效果是一样的,并且StringBuilder会比StringBuffer效率高一些。
以后开发,建议使用StringBuilder,可以自己加锁来保证同步。
升级三个因素:
1,提高效率。
2,简化书写。
3,提高安全性。
@@基本数据类型对象包装类!
1 byte Byte
2 short short
4 int Integer*****
8 long Long
boolean Boolean
4 float Float
8 double Double
2 char Character******
基本数据类型对象包装类的最常见作用,
**就是用于基本数据类型和字符串类型之间做转换****
基本数据类型==>字符串。
基本数据类型+""
基本数据类型.toString(基本数据类型值);
如: Integer.toString(34);//将34整数变成"34";
字符串==>基本数据类型。
static 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();
十进制转成其他进制。
static Integer.toBinaryString(6);//二进制
static Integer.toHexString(6);//十六进制
static Integer.toOctalString(6);//八进制
其他进制转成十进制。
static parseInt(string,radix);//radix表示:string中的数是radix进制的数。
例如:
int x = new Integer.parseInt("110",2);//
int y = new Integer.parseInt("3c0",16);//
JDK1.5版本以后出现的新特性。
自动装箱(int=>integer)、拆箱(integer=>int)。
<装箱原理new Integer(4)>、<拆箱原理x.intValue>
Integer x = 4;//自动装箱。//<装箱原理new Integer(4)>
(Integer x = null;//可以写,编译通过,但不能拆箱了,也就是不能x.intValue)
x = x/* x.intValue() */ + 2;
//x+2:x 进行自动拆箱,从Integer类型变成了int类型。和2进行加法运算。
//再将和进行装箱(int=>Integer)赋给x。