您的位置:首页 > 职场人生

黑马程序员----集合1(String、StringBuffer、基本数据类型对象)

2015-10-22 09:22 603 查看
——Java培训、Android培训、iOS培训、.Net培训、期待与您交流! ——-

String

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

String s1 = "abc";//s1是一个类类型变量, "abc"是一个对象。
String s2 = new String("abc");

//s1和s2有什么区别?
//s1在内存中有一个对象。
//s2在内存中有两个对象。   (   new       “abc”  )

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


String类是对字符串事物的描述。

该类定义了专门用于操作字符串的方法。

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);

去除字符串两端空格

String trim();

示例

public class StringMethodDemo {
public static void main(String[] args){
StringMethodDemo();
}
public static void StringMethodDemo(){
System.out.println( "-" + "   ab  c    " .trim() + "-");
}
}


运行结果:



**将字符串进行连接

String concat(String str);**

示例

public class StringMethodDemo{
public static void main(String[] args){
StringMethodDemo();
}
public static void StringMethodDemo(){
System.out.println( "abc".concat("kk" ));
System.out.println( "abc" + "kk" );
}
}


运行结果:



P.S.

concat效果与”+”连接符效果一致,但是效果更高一些。

练习:

1、给定一个字符串数组,按照字典顺序进行从小到大的排序。

{“nba”,”abc”,”cba”,”zz”,”qq”,”haha”}

思路:
①对数组排序,可以用选择,冒泡都行。
②for嵌套、比较以及换位。
③使用String类中提供的用于字符串比较的功能进行比较。


代码:

public class StringTest{
public static void main(String[] args){
String[] arr = { "nba","abc" ,"cba" ,"zz" ,"qq" ,"haha" };
printArray(arr);
sortString(arr);
printArray(arr);
}
public static void printArray(String[] arr){
System.out.print( "[");
for(int i = 0; i < arr.length; i++){
if(i != arr.length -1)
System.out.print(arr[i] + ",");
else
System.out.println(arr[i] + "]");
}
}
public static void sortString(String[] arr){
for(int i = 0; i < arr.length - 1; i++){
for(int j = i + 1; j < arr.length; j++){
if(arr[i].compareTo(arr[j])>0){
swap(arr,i,j);
}
}
}
}
private static void swap(String arr[],int i, int j){
String temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
}


运行结果:



2、一个子串在整串中出现的次数 “nbaernbatynbauinbaopnba”

思路:

①要找的子串是否存在,如果存在获取其出现的位置,这个可以使用indexOf完成。

②如果找到了,那么就记录出现的位置并在剩余的字符串中继续查找该子串,而剩余字符串的起始位是出现位置+子串的长度。

③以此类推,通过循环完成查找,如果找不到就是-1,并且每次找到用计数器记录。

代码:

public class StringTest{
public static void main(String[] args){
String str = "nbaernbatynbauinbaopnba";
String key = "nba";
int count = getKeyStringCount(str,key);
System.out.println( "count = " + count);
}
public static int getKeyStringCount(String str,String key){
//1、定义计数器
int count = 0;
//2、定义变量记录key出现的位置
int index = 0;
while((index = str.indexOf(key)) != -1){
str = str.substring(index + key.length());
count++;
}
return count;
}
}


运行结果:



**3、两个字符串中最大相同的子串

“qwerabcdtyuiop”

“xcabcdvbn”**

思路:

①既然取的是最大子串,先看短的那个字符串是否在长的那个字符串中。如果存在,短的那个字符串就是最大子串。

②如果不是,那么就将短的那个子串进行长度递减的方式去子串,去子串中判断是否存在。如果存在就已找到,就不用再找了。

public class StringTest{
public static void main(String[] args){
String s1 = "qwerabcdtyuiop";
String s2 = "xcabcdvbn";
String s = getMaxSubstring(s1,s2);
System.out.println( "s = " + s);
}
public static String getMaxSubstring(String s1,String s2){
String max = null,min = null;
max = (s1.length() > s2.length())?s1:s2;
min = max.equals(s1)?s2:s1;
for(int i = 0; i < min.length(); i++){
for(int a = 0,b = min.length() - i; b != min.length() + 1; a++,b++){
String sub = min.substring(a,b);
if(max.contains(sub))
return sub;
}
}
return null ;
}
}


运行结果



StringBuffer

StringBuffer是字符串缓冲区。

是一个容器。

特点:

1,长度是可变化的。

2,可以字节操作多个数据类型。

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

C create U update R read D delete

1,存储。

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

StringBuffer insert(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)

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

StringBuffer是线程同步。

StringBuilder是线程不同步。

以后开发,建议使用StringBuilder

升级三个因素:

1,提高效率。

2,简化书写。

3,提高安全性。

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

byte Byte

short short

int Integer

long Long

boolean Boolean

float Float

double Double

char Character

基本数据类型对象包装类的最常见作用,

就是用于基本数据类型和字符串类型之间做转换

基本数据类型转成字符串。

基本数据类型+”“

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

如: Integer.toString(34);//将34整数变成”34”;

字符串转成基本数据类型。

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();

十进制转成其他进制。

toBinaryString();

toHexString();

toOctalString();

其他进制转成十进制。

parseInt(string,radix);

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

Integer x = 4;//自动装箱。//new Integer(4)
x = x    /* x.intValue() */ + 2;//x+2:  x 进行自动拆箱。变成成了int类型。和2进行加法运算。
//再将和进行装箱赋给x。

Integer a = 127;
Integer b = 127;
sop("a==b:"+(a==b));//结果为true。因为a和b指向了同一个Integer对象。
//因为当数值在byte范围内容,对于新特性,如果该数值已经存在,则不会在开辟新的空间。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: