一、String
1、知识点
(1)、因为被final修饰,所以不能被继承
(2)、 字符串一旦被初始化就不可以被改变(是指字符串,而不是引用的指向)
(3)、String s1=””;和String s1=new String();是一样的
(4)、String s1=”abc”;
String s2=new String(“abc”);
“abc”是一个对象。以上二者用起来一样,但是,String类复写了Object类中的equals方法,用于判断字符串的内容是否相同。S1在内存中只有一个对象“abc”,S2在内存中有两个对象”abc”和new出来的对象
(5)、Strng s1=”abc”; String s2=”abc”;
s1==s2;//结果是true
这个和常量池有关,常量池在方法区,用于存放常量,当S2初始化时,发现已经有一个”abc”,就不会再开辟空间,而是直接指向
2、string类中常用方法
(1),获取。
1.1 字符串中的包含的字符数,也就是字符串的长度。
int length():获取长度。
1.2 根据位置获取位置上某个字符。
char charAt(int index)(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) 返回指定字符在此字符串中最后一次出现处的索引,反向搜索
int lastIndexOf(int ch, int fromIndex)
int lastIndexOf(String str):
int lastIndexOf(String str, int fromIndex) :
(2),判断。
2.1 字符串中是否包含某一个子串。
boolean contains(str):
特殊之处:indexOf(str):可以索引str第一次出现位置,如果返回-1.表示该str不在字符串中存在。所以,也可以用于对指定判断是否包含。
if(str.indexOf("aa")!=-1),而且该方法即可以判断,有可以获取出现的位置。
2.2 字符中是否有内容。
boolean isEmpty(): 原理就是判断长度是否为0.(1.6以上版本,’’’’和null不是一回事,””长度为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):将字符数组中的一部分转成字符串。
(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(double/ boolean/char/int/long/float)
//3+"";//String.valueOf(3);结果都是”3”
特殊:字符串和字节数组在转换过程中,是可以指定编码表的。
(4),替换
String replace(oldchar,newchar);
String replace(str,str);
(5),切割
String[] split(regex);
(6),子串。获取字符串中的一部分。
String substring(begin);(从begin处到结尾)
String substring(begin,end);(从begin到end-1,含头不含尾)
(7),转换,去除空格,比较。
7.1 将字符串转成大写或则小写。
String toUpperCase();
String toLowerCase();
7.2 将字符串两端的多个空格去除。
String trim();
7.3 对两个字符串进行自然顺序的比较。
int compareTo(string);(返回的结果是第一个不想等的字符对应的ASCII码表的数字之差)
//实例:
public class S {
public static void main(String[] args) {
String s=" ab cd 34 dd fdsa ee12 ";
//sop("+"+myTrim(s)+"+");
//sop("="+s+"=");
//sop("="+fanZhuan(s)+"=");
// sop("="+fanZhuan(s,1,3)+"=");
// s=" w eruyt ws-ws wwws ";
// sop(sNum2(s,"-"));
sop(sameString("的我们啊","啊哈我们是中国人哈哈"));
}
public static void sop(Object obj){
System.out.println(obj);
}
//两个字符串中出现的最大子穿
private static String sameString(String s1,String s2){
String big,small;
big=(s1.length()>s2.length())?s1:s2;
small=(big==s2)?s1:s2;
//将s2按长度递减来获取,外循环控制次数,最多s2.length次。因为s的长度等于次数
for(int i=0;i<small.length();i++){
//内循环就是从初始角标0角标开始截取,长度一定的前提下,初始角标递增
//l就是长度
for(int start=0,l=small.length()-i;start+l<=small.length();start++){
String s=null;
s=small.substring(start,start+l);
sop(i+"--"+start+"---"+l+"----"+s+"---"+s.length());
if(big.contains(s))
return s;
}
}
return "";
}
//s2在s1中出现的次数
public static int sNum(String s1,String s2){//比较麻烦
int sum=0;
for(int i=0;i<s1.length()&&s1.indexOf(s2,i)!=-1;i+=s2.length()){
sum+=1;
i=s1.indexOf(s2,i);
}
return sum;
}
public static int sNum1(String s1,String s2){//这会在内存中建立很多对象吧
int sum=0;
while(s1.indexOf(s2)!=-1){
sum+=1;
s1=s1.substring(s1.indexOf(s2)+s2.length());
}
return sum;
}
public static int sNum2(String s1,String s2){//这会在内存中建立很多对象吧
int sum=0;
int i=0;
while((i=s1.indexOf(s2,i))!=-1){
sum+=1;
i=i+s2.length();
}
return sum;
}
//去掉字符串两端空格
public static String myTrim(String s){
int i=0,j=s.length()-1;;
String s1=null;
while(i<=j&&s.charAt(i++)==' '){}
while(i<=j&&s.charAt(j--)==' '){}
s1=s.substring(--i,j+2);
return s1;
}
//对字符串进行制定位置的反转,从start到end-1
public static String fanZhuan(String s,int start,int end){
char ch[]=new char[s.length()];
ch=s.toCharArray();
fan(ch,start,end);
return new String(ch);
}
//字符串反转
public static String fanZhuan(String s){
return fanZhuan(s,0,s.length());
}
//数组反转
private static void fan(char[] ch,int start,int end){
for(int i=start,j=end-1;i<=end/2;i++,j--){
huanWei(ch,i,j);
}
}
//数组换位
private static void huanWei(char[] ch,int x,int y){
char a=0;
a=ch[x];
ch[x]=ch[y];
ch[y]=a;
}
}
二、StringBuffer和Stringbuild
1、知识点
StringBuffer是字符串缓冲区。是一个容器。容器可以改变数据(增删改查)
特点:
1,长度是可变化的。
2,可以字节操作多个数据类型。
3,最终会通过toString方法变成字符串。
2、常用方法
(1),存储。
StringBuffer append(数据):将指定数据作为参数添加到已有数据结尾处。
StringBuffer insert(index,数据):可以将数据插入到指定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)
(含头不含尾。注意角标)
StringBuilder
JDK1.5 版本之后出现了StringBuilder.
StringBuffer是线程同步。StringBuilder是线程不同步。以后开发,建议使用StringBuilder
JDK升级三个因素:
1,提高效率。
2,简化书写。
3,提高安全性。
三、基本数据类型对象包装类
1、对应:
byte Byte
short short
int Integer
long Long
boolean Boolean
float Float
double Double
char Character
基本数据类型对象包装类的最常见作用,就是用于基本数据类型和字符串类型之间做转换
(1)基本数据类型转成字符串。
基本数据类型+""
包装类.toString(基本数据类型值);
如: Integer.toString(34);//将34整数变成"34";
(2)字符串转成基本数据类型。
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();
(3)十进制转成其他进制。
toBinaryString();
toHexString();
toOctalString();
(4)其他进制转成十进制。
parseInt(string,radix);//radix表示string的进制类型
如parseInt(“ff”,16)
2、自动装箱,自动拆箱(JDK1.5新特性)
Integer x = new Integer(4);
Integer x = 4;//自动装箱。相当于new Integer(4)
//x=x+2 x可以直接进行运算,因为x进行自动拆箱。变成成了int类型。
//和2进行加法运算。然后计算的结果再自动装箱赋给x。过程就是//x.intValue()+2
Integer m = 128;
Integer n = 128;
//m==n,结果为false
Integer a = 127;
Integer b = 127;
//a==b 结果为true。因为a和b指向了同一个Integer对象。
//因为当数值在byte范围内容,对于新特性,如果该数值已经存在,则不会在开辟新的空间。