什么是API?
API就是java对外提供的应用程序接口,就是给我们暴露出来的部分,能让我们直接使用的部分。
String(字符串)
字符串是一个特殊的对象。String类适用于描述字符串事物。
String的特点:
1. 它是一个对象
2. 它是一个常量,并且一旦被初始化就不可以改变
3. 字符串的比较有自己独特的方式,equals判断内容是否相同
4. String s1 = “a”;//在内存中有一个对象。String s2 = new String(“a”);//在内存中有两个对象。
常见的操作有哪些?
该类定义了专门用于操作字符串的方法。
获取
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在字符串中出现的位置。
如果没有找到,返回-1。
反向索引一个字符出现的位置
int lastIndexOf(int ch):返回指定字符在此字符串中最后一次出现处索引。
int lastIndexOf(int ch,int fromIndex):返回指定字符在此字符串中最后一次出现处的索引,从指定的索引处开始进行反向搜索。
int lastIndexOf(String str):返回指定子字符串在此字符串中最右边出现处的索引。
int lastIndexOf(String str,int fromIndex):返回指定子字符串在此字符串中最后一次出现处的索引,从指定的索引开始反向搜索。
1.4子串,获取字符串中的一部分
String substring(begin);//从指定位置开始到结尾。如果角标不存在,会出现字符串角标越界异常
String substring(begin,end);//包含头,不包含尾获取整个字符串就是:substring(0,.length());
1.5自己定义一个位置,返回ask码 Unicode代码点
int codePointAt(int index):返回指定索引处的字符(Unicode代码点)。
判断
2.1 字符串中是否包含某一个子串
boolean contains(str)
2.2 字符串中是否有内存
boolean isEmpty():原理就是判断长度是否为0。这个方法1.6版本才出现。
2.3 字符串是否是以指定内容开头
boolean startsWith(str);
2.4 字符串是否是以指定内容结尾
boolean endsWith(str);
2.5 判断字符串内容是否相同。复写了Object类中的equals方法
boolean equals(str);
2.6 判断内容是否相同,并忽略大小写。
boolean equalsIgnoreCase();
转换
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[]);
static String ValueOf(char[] data,int offset,int count);
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)
特殊:字符串和字节数组在转换过程中,是可以指定编码表的。
替换
String replace(oldchar,newchar):返回一个新的字符串,它是通过用newChar替换此字符串中出现的所有oldChar得到的。
String replaceAll(regex,replacement):按照指定规则替换字符串。
切割
String[] split(reqex);//可以把字符串分开,reqex相当于一个切割点,它是不显示的。
转换,去除空格,比较
6.1 将字符串转成大写或小写
String toUpperCase();转大写
String toLowerCase();转小写
6.2 将字符串两端多个空格去除
String trim();
6.3 对两个字符串进行自然顺序的比较
int compareTo(string);
返回:如果参数字符串等于此字符串,则返回值0;如果此字符串按字典顺序小于字符串参数,则返回一个小于0的值;如果此字符串按字典顺序大于字符串参数,则返回一个大于0的值。
StringBuffer(字符串缓冲区)
StringBuffer:是一个容器。
特点:
1.长度是可变化的。数组也是容器,但长度是固定的。
2.可以直接操作多个数据类型。而数组只可以操作一个。
3.最终会通过toString方法变成字符串。
StringBuffer的常见操作:
存储
StringBuffer append():将指定数据作为参数添加到已有数据结尾处。
.append().append.append();//方法调用链,返回的还是对象,对象还能调用方法。
StringBuffer insert(index,数据):可以将数据插入到指定index位置。
将缓冲区中指定数据存储到指定字符数组中
void getChars(int srcBegin,int srcEnd,char[] dst,int dstBegin)
删除
StringBuffer delete(start,end):删除缓冲区中的数据,包含start,不包含end。
StringBuffer deleteCharAt(index):删除指定位置的字符。
.delete(0,.length());//清空缓冲区
获取
char charAt(int index):获取一个
int indexOf(String str):根据字符串获取位置
int lastIndexOf(String str)
int length()
String substring(int start,int end)
修改
StringBuffer replace(start,end,string);
void setCharAt(int index, char ch) ;替换一个。
反转
StringBuffer reverse();
StringBuilder(JDK1.5 版本之后出现的,提高了效率)
StringBuilder:一个可变的字符序列。该类被设计用作StringBuffer的一个简易替换,用在字符串缓冲区被单个线程使用的时候。
StringBuffer与StringBuilder区别:
StringBuilder是线程不同步(不安全)。StringBuffer是线程同步(安全)。
将StringBuilder的实例用于多个线程是不安全的,如果需要同步,可以使用StringBuffer。但在开发时,建议使用StringBuilder。因为,StringBuilder比StringBuffer效率高。
基本数据类型对象包装类
基本数据类型 引用数据类型
byte Byte(类)
int Integer
long Long
short Short
boolean Boolean
float Float
double Double
char Character
基本数据类型对象包装类的最常见作用是什么?
用于基本数据类型和字符串类型之间做转换。
怎么转换呢?
基本数据类型转成字符串
基本数据类型+""
基本数据类型.toString(基本数据类型值);
如:Integer.toString(34);//将34整数变成"34";
字符串转成基本数据类型
静态方法:
static int parseInt(String s);将字符串参数作为有符号的十进制整数进行解析。
基本数据类型 a=引用数据类型.parseXxx(String s):Xxx为要转换的类型
如:boolean b = Boolean.parseBoolean("true");
非静态方法:
Integer i = new Integer("123");
int num = i.intValue();
注意:Character类型转不了,因为它本身就是字符。
十进制转成其他进制
toBinaryString();:十进制转换成二进制
toHexString();:十进制转换成十六进制
toOctalString();:十进制转换成八进制
其他进制转成十进制
格式:parseInt(string s,int radix)
parseInt("3c",16):十六进制转十进制
parseInt("110",2):二进制转十进制
位移运算
static int rotateLeft(int i, int distance):返回根据指定的位数循环左移指定的int值的二进制补码表示形式而得到的值。
static int rotateRight(int i, int distance):返回根据指定的位数循环右移指定的int值的二进制补码表示形式而得到的值。
获取一个类型的最大值与最小值范围
static int(类型) MAX_VALUE:最大值
static int MIN_VALUE:最小值
JDK1.5版本以后出现的新特性(简化了书写)
以前写法:Integer x = new Integer(4);
改版后写法:Integer x = 4;//这叫做自动装箱。
x = x+2;//这里面的x+2中的x进行了自动拆箱(拆成了x.intValue()),变成了int类型,和2进行加法运算,最后将和进行装箱赋给x。
新特性注意地方:Integer x = null; //空指针异常,新特性不可以为空,这里要进行判断。
享元模式:有很多小的对象它们有很多属性相同,就把它们变成一个对象,不同的属性变成方法的参数称为外部状态,那些方法的属性称为内部状态。
新特性示例:
Integer x = 128;
Integer y = 128;
System.out.println(x==y); false
Integer a = 127;
Integer b = 127;
System.out.println(a==b); true
为什么会是true?
因为a和b指向了同一个Integer对象。
为什么会是false?
因为当数值在byte范围内容,对于新特性,如果该数值已经存在,则不会在开辟新空间。而128超出了byte范围。
总结:
字符串定义的常量在常量池中,数组的length是属性,字符串的length是通过方法完成的。如果replace()中要替换的字符不存在,返回的还是原字符。在多线程中也可以使用StringBuilder,我们可以自己加锁。
字符串最大特点:一旦被初始化就不可以被改变。
indexOf(str)的特殊之处:可以用于对指定判断是否包含。
如:if(str.indexOf("aa")!=-1)说明包含了aa,而且该方法即可以判断,有可以获取出现的位置。
版本升级的三个因素:
1,提高效率。
2,简化书写。
3,提高安全性。