10月27日Java整理

实验一:凯撒密码

import java.util.Scanner;

//zhanxinwu,October,25,2016

public class Addmi {

public static void main(String[] args) {

// TODO 自动生成的方法存根

int m,i;

System.out.println("请输入你想加密的字符串:");

Scanner h=new Scanner(System.in);

String  s=h.nextLine();

m=s.length();

String output = "";

char c;

for ( i = 0; i < m; i++)

{

c= s.charAt(i);

if (c >= ‘a‘ && c <= ‘w‘) // 如果字符串中的某个字符是小写字母

{

c=(char)(c+3);

}

else if (c>= ‘A‘ && c<= ‘W‘) // 如果字符串中的某个字符是大写字母

{

c=(char)(c+3);

}

else if(c==‘x‘)

{

c=‘a‘;

}

else if(c==‘y‘)

{

c=‘b‘;

}

else if(c==‘z‘)

{

c=‘c‘;

}

else if(c==‘X‘)

{

c=‘A‘;

}

else if(c==‘Y‘)

{

c=‘B‘;

}

else if(c==‘Z‘)

{

c=‘C‘;

}

output+= c;// 将加密后的字符连成字符串

}

System.out.println(s+"加密后"+output);

}

}

实验二:动手动脑

public class StringPool {

public static void main(String args[])

{

String s0="Hello";

String s1="Hello";

String s2="He"+"llo";

System.out.println(s0==s1);//true

System.out.println(s0==s2);//true

System.out.println(new String("Hello")==new String("Hello"));//false new开辟的内存的空间不一样

}

}

实验运行结果:

实验结果分析:Hollow不管是s1还是s2都是一个存储地址。分开合并的也是java编译器自动合并,然而new开辟的是两个存储空间所以最后是false。

在Java中,内容相同的字串常量(“Hello”)只保存一份以节约内存,所以s0,s1,s2实际上引用的是同一个对象。

编译器在编译s2一句时,会去掉“+”号,直接把两个字串连接起来得一个字串(“Hello”)。这种优化工作由Java编译器自动完成。

当直接使用new关键字创建字符串对象时,虽然值一致(都是“Hello”),但仍然是两个独立的对象。

实验三:

public class StringEquals {

/**

* @param args the command line arguments

*/

public static void main(String[] args) {

String s1=new String("Hello");

String s2=new String("Hello");

System.out.println(s1==s2);

System.out.println(s1.equals (s2));

String s3="Hello";

String s4="Hello";

System.out.println(s3==s4);

System.out.println(s3.equals(s4));

}

}

实验结果运行图:

运行结果解释:第一个s1和s2是两个new的地址而“=”是判断地址是否相同的,第一个所以false,equals()函数是判断值相等的所以二,四结果都为true,而s3和s4都是在临时区的位置也喜爱你相同,所以也为true。

实验四:String类的方法可以连续调用

//zhanxinwu,October,27,2016

public class StringContest {

public static void main(String[] args) {

// TODO Auto-generated method stub

String str = "abc";

String result = str.trim().toUpperCase().concat("defg");

System.out.println(result);

}

}

实验运行结构:

实验五:

整理String类的Length()、charAt()、 getChars()、replace()、 toUpperCase()、 toLowerCase()、trim()、toCharArray()

1、String对象的初始化

由于String对象特别常用,所以在对String对象进行初始化时,Java提供了一种简化的特殊语法,格式如下:

String s = “abc”;

s = “Java语言”;

其实按照面向对象的标准语法,其格式应该为:

String s = new String(“abc”);

s = new String(“Java语言”);

只是按照面向对象的标准语法,在内存使用上存在比较大的浪费。例如String s = new String(“abc”);实际上创建了两个String对象,一个是”abc”对象,存储在常量空间中,一个是使用new关键字为对象s申请的空间。

其它的构造方法的参数,可以参看String类的API文档。

2、字符串的常见操作

a、charAt方法

该方法的作用是按照索引值(规定字符串中第一个字符的索引值是0,第二个字符的索引值是1,依次类推),获得字符串中的指定字符。例如:

String s = “abc”;

char c = s.chatAt(1);

则变量c的值是’b’。

b、compareTo方法

该方法的作用是比较两个字符串的大小,比较的原理是依次比较每个字符的字符编码。首先比较两个字符串的第一个字符,如果第一个字符串的字符编码大于第二个的字符串的字符编码,则返回大于0的值,如果小于则返回小于0的值,如果相等则比较后续的字符,如果两个字符串中的字符编码完全相同则返回0。

例如:

String s = “abc”;

String s1 = “abd”;

int value = s.compareTo(s1);

则value的值是小于0的值,即-1。

在String类中还存在一个类似的方法compareToIgnoreCase,这个方法是忽略字符的大小写进行比较,比较的规则和compareTo一样。例如:

String s = “aBc”;

String s1 = “ABC”;

int value = s. compareToIgnoreCase (s1);

则value的值是0,即两个字符串相等。

c、concat方法

该方法的作用是进行字符串的连接,将两个字符串连接以后形成一个新的字符串。例如:

String s = “abc”;

String s1 = “def”;

String s2 = s.concat(s1);

则连接以后生成的新字符串s2的值是”abcdef”,而字符串s和s1的值不发生改变。如果需要连接多个字符串,可以使用如下方法:

String s = “abc”;

String s1 = “def”;

String s2 = “1234”;

String s3 = s.concat(s1).concat(s2);

则生成的新字符串s3的值为”abcdef1234”。

其实在实际使用时,语法上提供了一种更简单的形式,就是使用“+”进行字符串的连接。例如:

String s = “abc” + “1234”;

则字符串s的值是”abc1234”,这样书写更加简单直观。

而且使用“+”进行连接,不仅可以连接字符串,也可以连接其他类型。但是要求进行连接时至少有一个参与连接的内容是字符串类型。而且“+”匹配的顺序是从左向右,如果两边连接的内容都是基本数字类型则按照加法运算,如果参与连接的内容有一个是字符串才按照字符串进行连接。

例如:

int a = 10;

String s = “123” + a + 5;

则连接以后字符串s的值是“123105”,计算的过程为首先连接字符串”123”和变量a的值,生成字符串”12310”,然后使用该字符串再和数字5进行连接生成最终的结果。

而如下代码:

int a = 10;

String s = a + 5 + “123”;

则连接以后字符串s的值是”15123”,计算的过程为首先计算a和数字5,由于都是数字型则进行加法运算或者数字值15,然后再使用数字值15和字符串”123”进行连接获得最终的结果。

而下面的连接代码是错误的:

int a = 12;

String s = a + 5 + ‘s’;

因为参与连接的没有一个字符串,则计算出来的结果是数字值,在赋值时无法将一个数字值赋值给字符串s。

d、endsWith方法

该方法的作用是判断字符串是否以某个字符串结尾,如果以对应的字符串结尾,则返回true。

例如:

String s = “student.doc”;

boolean b = s.endsWith(“doc”);

则变量b的值是true。

e、equals方法

该方法的作用是判断两个字符串对象的内容是否相同。如果相同则返回true,否则返回false。例如:

String s = “abc”;

String s1 = new String(“abc”);

boolean b = s.equals(s1);

而使用“==”比较的是两个对象在内存中存储的地址是否一样。例如上面的代码中,如果判断:

boolean b = (s == s1);

则变量b的值是false,因为s对象对应的地址是”abc”的地址,而s1使用new关键字申请新的内存,所以内存地址和s的”abc”的地址不一样,所以获得的值是false。

在String类中存在一个类似的方法equalsIgnoreCase,该方法的作用是忽略大小写比较两个字符串的内容是否相同。例如:

String s = “abc”;

String s1 =”ABC”;

boolean b = s. equalsIgnoreCase (s1);

则变量b的值是true。

f、getBytes方法

该方法的作用是将字符串转换为对应的byte数组,从而便于数据的存储和传输。例如:

String s = “计算机”;

byte[] b = s.getBytes();   //使用本机默认的字符串转换为byte数组

byte[] b = s.getBytes(“gb2312”); //使用gb2312字符集转换为byte数组

在实际转换时,一定要注意字符集的问题,否则中文在转换时将会出现问题。

g、indexOf方法

该方法的作用是查找特定字符或字符串在当前字符串中的起始位置,如果不存在则返回-1。例如:

String s = “abcded”;

int index = s.indexOf(‘d’);

int index1 = s.indexOf(‘h’);

则返回字符d在字符串s中第一次出现的位置,数值为3。由于字符h在字符串s中不存在,则index1的值是-1。

当然,也可以从特定位置以后查找对应的字符,例如:

int index = s.indexOf(‘d’,4);

则查找字符串s中从索引值4(包括4)以后的字符中第一个出现的字符d,则index的值是5。

由于indexOf是重载的,也可以查找特定字符串在当前字符串中出现的起始位置,使用方式和查找字符的方式一样。

另外一个类似的方法是lastIndexOf方法,其作用是从字符串的末尾开始向前查找第一次出现的规定的字符或字符串,例如:

String s = “abcded”;

int index = s. lastIndexOf(‘d’);

则index的值是5。

h、length方法

该方法的作用是返回字符串的长度,也就是返回字符串中字符的个数。中文字符也是一个字符。例如:

String s = “abc”;

String s1 = “Java语言”;

int len = s.length();

int len1 = s1.length();

则变量len的值是3,变量len1的值是6。

i、replace方法

该方法的作用是替换字符串中所有指定的字符,然后生成一个新的字符串。经过该方法调用以后,原来的字符串不发生改变。例如:

String s = “abcat”;

String s1 = s.replace(‘a’,’1’);

该代码的作用是将字符串s中所有的字符a替换成字符1,生成的新字符串s1的值是”1bc1t”,而字符串s的内容不发生改变。

如果需要将字符串中某个指定的字符串替换为其它字符串,则可以使用replaceAll方法,例如:

String s = “abatbac”;

String s1 = s.replaceAll(“ba”,”12”);

该代码的作用是将字符串s中所有的字符串”ab”替换为”12”,生成新的字符串”a12t12c”,而字符串s的内容也不发生改变。

如果只需要替换第一个出现的指定字符串时,可以使用replaceFirst方法,例如:

String s = “abatbac”;

String s1 = s. replaceFirst (“ba”,”12”);

该代码的作用是只将字符串s中第一次出现的字符串”ab”替换为字符串”12”,则字符串s1的值是”a12tbac”,字符串s的内容也不发生改变。

j、split方法

该方法的作用是以特定的字符串作为间隔,拆分当前字符串的内容,一般拆分以后会获得一个字符串数组。例如:

String s = “ab,12,df”;

String s1[] = s.split(“,”);

该代码的作用是以字符串”,”作为间隔,拆分字符串s,从而得到拆分以后的字符串数字s1,其内容为:{“ab”,”12”,”df”}。

该方法是解析字符串的基础方法。

如果字符串中在内部存在和间隔字符串相同的内容时将拆除空字符串,尾部的空字符串会被忽略掉。例如:

String s = “abbcbtbb”;

String s1[] = s.split(“b”);

则拆分出的结果字符串数组s1的内容为:{“a”,””,”c”,”t”}。拆分出的中间的空字符串的数量等于中间间隔字符串的数量减一个。例如:

String s = “abbbcbtbbb”;

String s1[] = s.split(“b”);

则拆分出的结果是:{“a”,””,””,”c”,”t”}。最后的空字符串不论有多少个,都会被忽略。

如果需要限定拆分以后的字符串数量,则可以使用另外一个split方法,例如:

String s = “abcbtb1”;

String s1[] = s.split(“b”,2);

该代码的作用是将字符串s最多拆分成包含2个字符串数组。则结果为:{“a”,”cbtb1”}。

如果第二个参数为负数,则拆分出尽可能多的字符串,包括尾部的空字符串也将被保留。

k、startsWith方法

该方法的作用和endsWith方法类似,只是该方法是判断字符串是否以某个字符串作为开始。例如:

String s = “TestGame”;

boolean b = s.startsWith(“Test”);

则变量b的值是true。

l、substring方法

该方法的作用是取字符串中的“子串”,所谓“子串”即字符串中的一部分。例如“23”是字符串“123”的子串。

字符串“123”的子串一共有6个:”1”、”2”、”3”、”12”、”23”、”123”。而”32”不是字符串”123”的子串。

例如:

String s = “Test”;

String s1 = s.substring(2);

则该代码的作用是取字符串s中索引值为2(包括)以后的所有字符作为子串,则字符串s1的值是”st”。

如果数字的值和字符串的长度相同,则返回空字符串。例如:

String s = “Test”;

String s1 = s.substring(4);

则字符串s1的值是””。

如果需要取字符串内部的一部分,则可以使用带2个参数的substring方法,例如:

String s = “TestString”;

String s1 = s.substring(2,5);

则该代码的作用是取字符串s中从索引值2(包括)开始,到索引值5(不包括)的部分作为子串,则字符串s1的值是”stS”。

下面是一个简单的应用代码,该代码的作用是输出任意一个字符串的所有子串。代码如下:

String s = “子串示例”;

int len = s.length(); //获得字符串长度

for(int begin = 0;begin < len – 1;begin++){ //起始索引值

for(int end = begin + 1;end <= len;end++){ //结束索引值

System.out.println(s.substring(begin,end));

}

}

在该代码中,循环变量begin代表需要获得的子串的起始索引值,其变化的区间从第一个字符的索引值0到倒数第二个字符串的索引值len -2,而end代表需要获得的子串的结束索引值,其变化的区间从起始索引值的后续一个到字符串长度。通过循环的嵌套,可以遍历字符串中的所有子串。

m、toCharArray方法

该方法的作用和getBytes方法类似,即将字符串转换为对应的char数组。例如:

String s = “abc”;

char[] c = s.toCharArray();

则字符数组c的值为:{‘a’,’b’,’c’}。

n、toLowerCase方法

该方法的作用是将字符串中所有大写字符都转换为小写。例如:

String s = “AbC123”;

String s1 = s.toLowerCase();

则字符串s1的值是”abc123”,而字符串s的值不变。

类似的方法是toUpperCase,该方法的作用是将字符串中的小写字符转换为对应的大写字符。例如:

String s = “AbC123”;

String s1 = s. toUpperCase ();

则字符串s1的值是”ABC123”,而字符串s的值也不变。

o、trim方法

该方法的作用是去掉字符串开始和结尾的所有空格,然后形成一个新的字符串。该方法不去掉字符串中间的空格。例如:

String s = “   abc abc 123 “;

String s1 = s.trim();

则字符串s1的值为:” abc abc 123”。字符串s的值不变。

p、valueOf方法

该方法的作用是将其它类型的数据转换为字符串类型。需要注意的是,基本数据和字符串对象之间不能使用以前的强制类型转换的语法进行转换。

另外,由于该方法是static方法,所以不用创建String类型的对象即可。例如:

int n = 10;

String s = String.valueOf(n);

则字符串s的值是”10”。虽然对于程序员来说,没有发生什么变化,但是对于程序来说,数据的类型却发生了变化。

介绍一个简单的应用,判断一个自然数是几位数字的逻辑代码如下:

int n = 12345;

String s = String.valueOf(n);

int len = s.length();

则这里字符串的长度len,就代表该自然数的位数。这种判断比数学判断方法在逻辑上要简单一些。

实验一:凯撒密码

import java.util.Scanner;

//zhanxinwu,October,25,2016

public class Addmi {

public static void main(String[] args) {

// TODO 自动生成的方法存根

int m,i;

System.out.println("请输入你想加密的字符串:");

Scanner h=new Scanner(System.in);

String  s=h.nextLine();

m=s.length();

String output = "";

char c;

for ( i = 0; i < m; i++)

{

c= s.charAt(i);

if (c >= ‘a‘ && c <= ‘w‘) // 如果字符串中的某个字符是小写字母

{

c=(char)(c+3);

}

else if (c>= ‘A‘ && c<= ‘W‘) // 如果字符串中的某个字符是大写字母

{

c=(char)(c+3);

}

else if(c==‘x‘)

{

c=‘a‘;

}

else if(c==‘y‘)

{

c=‘b‘;

}

else if(c==‘z‘)

{

c=‘c‘;

}

else if(c==‘X‘)

{

c=‘A‘;

}

else if(c==‘Y‘)

{

c=‘B‘;

}

else if(c==‘Z‘)

{

c=‘C‘;

}

output+= c;// 将加密后的字符连成字符串

}

System.out.println(s+"加密后"+output);

}

}

实验二:动手动脑

public class StringPool {

public static void main(String args[])

{

String s0="Hello";

String s1="Hello";

String s2="He"+"llo";

System.out.println(s0==s1);//true

System.out.println(s0==s2);//true

System.out.println(new String("Hello")==new String("Hello"));//false new开辟的内存的空间不一样

}

}

实验运行结果:

实验结果分析:Hollow不管是s1还是s2都是一个存储地址。分开合并的也是java编译器自动合并,然而new开辟的是两个存储空间所以最后是false。

在Java中,内容相同的字串常量(“Hello”)只保存一份以节约内存,所以s0,s1,s2实际上引用的是同一个对象。

编译器在编译s2一句时,会去掉“+”号,直接把两个字串连接起来得一个字串(“Hello”)。这种优化工作由Java编译器自动完成。

当直接使用new关键字创建字符串对象时,虽然值一致(都是“Hello”),但仍然是两个独立的对象。

实验三:

public class StringEquals {

/**

* @param args the command line arguments

*/

public static void main(String[] args) {

String s1=new String("Hello");

String s2=new String("Hello");

System.out.println(s1==s2);

System.out.println(s1.equals (s2));

String s3="Hello";

String s4="Hello";

System.out.println(s3==s4);

System.out.println(s3.equals(s4));

}

}

实验结果运行图:

运行结果解释:第一个s1和s2是两个new的地址而“=”是判断地址是否相同的,第一个所以false,equals()函数是判断值相等的所以二,四结果都为true,而s3和s4都是在临时区的位置也喜爱你相同,所以也为true。

实验四:String类的方法可以连续调用

//zhanxinwu,October,27,2016

public class StringContest {

public static void main(String[] args) {

// TODO Auto-generated method stub

String str = "abc";

String result = str.trim().toUpperCase().concat("defg");

System.out.println(result);

}

}

实验运行结构:

实验五:

整理String类的Length()、charAt()、 getChars()、replace()、 toUpperCase()、 toLowerCase()、trim()、toCharArray()

1、String对象的初始化

由于String对象特别常用,所以在对String对象进行初始化时,Java提供了一种简化的特殊语法,格式如下:

String s = “abc”;

s = “Java语言”;

其实按照面向对象的标准语法,其格式应该为:

String s = new String(“abc”);

s = new String(“Java语言”);

只是按照面向对象的标准语法,在内存使用上存在比较大的浪费。例如String s = new String(“abc”);实际上创建了两个String对象,一个是”abc”对象,存储在常量空间中,一个是使用new关键字为对象s申请的空间。

其它的构造方法的参数,可以参看String类的API文档。

2、字符串的常见操作

a、charAt方法

该方法的作用是按照索引值(规定字符串中第一个字符的索引值是0,第二个字符的索引值是1,依次类推),获得字符串中的指定字符。例如:

String s = “abc”;

char c = s.chatAt(1);

则变量c的值是’b’。

b、compareTo方法

该方法的作用是比较两个字符串的大小,比较的原理是依次比较每个字符的字符编码。首先比较两个字符串的第一个字符,如果第一个字符串的字符编码大于第二个的字符串的字符编码,则返回大于0的值,如果小于则返回小于0的值,如果相等则比较后续的字符,如果两个字符串中的字符编码完全相同则返回0。

例如:

String s = “abc”;

String s1 = “abd”;

int value = s.compareTo(s1);

则value的值是小于0的值,即-1。

在String类中还存在一个类似的方法compareToIgnoreCase,这个方法是忽略字符的大小写进行比较,比较的规则和compareTo一样。例如:

String s = “aBc”;

String s1 = “ABC”;

int value = s. compareToIgnoreCase (s1);

则value的值是0,即两个字符串相等。

c、concat方法

该方法的作用是进行字符串的连接,将两个字符串连接以后形成一个新的字符串。例如:

String s = “abc”;

String s1 = “def”;

String s2 = s.concat(s1);

则连接以后生成的新字符串s2的值是”abcdef”,而字符串s和s1的值不发生改变。如果需要连接多个字符串,可以使用如下方法:

String s = “abc”;

String s1 = “def”;

String s2 = “1234”;

String s3 = s.concat(s1).concat(s2);

则生成的新字符串s3的值为”abcdef1234”。

其实在实际使用时,语法上提供了一种更简单的形式,就是使用“+”进行字符串的连接。例如:

String s = “abc” + “1234”;

则字符串s的值是”abc1234”,这样书写更加简单直观。

而且使用“+”进行连接,不仅可以连接字符串,也可以连接其他类型。但是要求进行连接时至少有一个参与连接的内容是字符串类型。而且“+”匹配的顺序是从左向右,如果两边连接的内容都是基本数字类型则按照加法运算,如果参与连接的内容有一个是字符串才按照字符串进行连接。

例如:

int a = 10;

String s = “123” + a + 5;

则连接以后字符串s的值是“123105”,计算的过程为首先连接字符串”123”和变量a的值,生成字符串”12310”,然后使用该字符串再和数字5进行连接生成最终的结果。

而如下代码:

int a = 10;

String s = a + 5 + “123”;

则连接以后字符串s的值是”15123”,计算的过程为首先计算a和数字5,由于都是数字型则进行加法运算或者数字值15,然后再使用数字值15和字符串”123”进行连接获得最终的结果。

而下面的连接代码是错误的:

int a = 12;

String s = a + 5 + ‘s’;

因为参与连接的没有一个字符串,则计算出来的结果是数字值,在赋值时无法将一个数字值赋值给字符串s。

d、endsWith方法

该方法的作用是判断字符串是否以某个字符串结尾,如果以对应的字符串结尾,则返回true。

例如:

String s = “student.doc”;

boolean b = s.endsWith(“doc”);

则变量b的值是true。

e、equals方法

该方法的作用是判断两个字符串对象的内容是否相同。如果相同则返回true,否则返回false。例如:

String s = “abc”;

String s1 = new String(“abc”);

boolean b = s.equals(s1);

而使用“==”比较的是两个对象在内存中存储的地址是否一样。例如上面的代码中,如果判断:

boolean b = (s == s1);

则变量b的值是false,因为s对象对应的地址是”abc”的地址,而s1使用new关键字申请新的内存,所以内存地址和s的”abc”的地址不一样,所以获得的值是false。

在String类中存在一个类似的方法equalsIgnoreCase,该方法的作用是忽略大小写比较两个字符串的内容是否相同。例如:

String s = “abc”;

String s1 =”ABC”;

boolean b = s. equalsIgnoreCase (s1);

则变量b的值是true。

f、getBytes方法

该方法的作用是将字符串转换为对应的byte数组,从而便于数据的存储和传输。例如:

String s = “计算机”;

byte[] b = s.getBytes();   //使用本机默认的字符串转换为byte数组

byte[] b = s.getBytes(“gb2312”); //使用gb2312字符集转换为byte数组

在实际转换时,一定要注意字符集的问题,否则中文在转换时将会出现问题。

g、indexOf方法

该方法的作用是查找特定字符或字符串在当前字符串中的起始位置,如果不存在则返回-1。例如:

String s = “abcded”;

int index = s.indexOf(‘d’);

int index1 = s.indexOf(‘h’);

则返回字符d在字符串s中第一次出现的位置,数值为3。由于字符h在字符串s中不存在,则index1的值是-1。

当然,也可以从特定位置以后查找对应的字符,例如:

int index = s.indexOf(‘d’,4);

则查找字符串s中从索引值4(包括4)以后的字符中第一个出现的字符d,则index的值是5。

由于indexOf是重载的,也可以查找特定字符串在当前字符串中出现的起始位置,使用方式和查找字符的方式一样。

另外一个类似的方法是lastIndexOf方法,其作用是从字符串的末尾开始向前查找第一次出现的规定的字符或字符串,例如:

String s = “abcded”;

int index = s. lastIndexOf(‘d’);

则index的值是5。

h、length方法

该方法的作用是返回字符串的长度,也就是返回字符串中字符的个数。中文字符也是一个字符。例如:

String s = “abc”;

String s1 = “Java语言”;

int len = s.length();

int len1 = s1.length();

则变量len的值是3,变量len1的值是6。

i、replace方法

该方法的作用是替换字符串中所有指定的字符,然后生成一个新的字符串。经过该方法调用以后,原来的字符串不发生改变。例如:

String s = “abcat”;

String s1 = s.replace(‘a’,’1’);

该代码的作用是将字符串s中所有的字符a替换成字符1,生成的新字符串s1的值是”1bc1t”,而字符串s的内容不发生改变。

如果需要将字符串中某个指定的字符串替换为其它字符串,则可以使用replaceAll方法,例如:

String s = “abatbac”;

String s1 = s.replaceAll(“ba”,”12”);

该代码的作用是将字符串s中所有的字符串”ab”替换为”12”,生成新的字符串”a12t12c”,而字符串s的内容也不发生改变。

如果只需要替换第一个出现的指定字符串时,可以使用replaceFirst方法,例如:

String s = “abatbac”;

String s1 = s. replaceFirst (“ba”,”12”);

该代码的作用是只将字符串s中第一次出现的字符串”ab”替换为字符串”12”,则字符串s1的值是”a12tbac”,字符串s的内容也不发生改变。

j、split方法

该方法的作用是以特定的字符串作为间隔,拆分当前字符串的内容,一般拆分以后会获得一个字符串数组。例如:

String s = “ab,12,df”;

String s1[] = s.split(“,”);

该代码的作用是以字符串”,”作为间隔,拆分字符串s,从而得到拆分以后的字符串数字s1,其内容为:{“ab”,”12”,”df”}。

该方法是解析字符串的基础方法。

如果字符串中在内部存在和间隔字符串相同的内容时将拆除空字符串,尾部的空字符串会被忽略掉。例如:

String s = “abbcbtbb”;

String s1[] = s.split(“b”);

则拆分出的结果字符串数组s1的内容为:{“a”,””,”c”,”t”}。拆分出的中间的空字符串的数量等于中间间隔字符串的数量减一个。例如:

String s = “abbbcbtbbb”;

String s1[] = s.split(“b”);

则拆分出的结果是:{“a”,””,””,”c”,”t”}。最后的空字符串不论有多少个,都会被忽略。

如果需要限定拆分以后的字符串数量,则可以使用另外一个split方法,例如:

String s = “abcbtb1”;

String s1[] = s.split(“b”,2);

该代码的作用是将字符串s最多拆分成包含2个字符串数组。则结果为:{“a”,”cbtb1”}。

如果第二个参数为负数,则拆分出尽可能多的字符串,包括尾部的空字符串也将被保留。

k、startsWith方法

该方法的作用和endsWith方法类似,只是该方法是判断字符串是否以某个字符串作为开始。例如:

String s = “TestGame”;

boolean b = s.startsWith(“Test”);

则变量b的值是true。

l、substring方法

该方法的作用是取字符串中的“子串”,所谓“子串”即字符串中的一部分。例如“23”是字符串“123”的子串。

字符串“123”的子串一共有6个:”1”、”2”、”3”、”12”、”23”、”123”。而”32”不是字符串”123”的子串。

例如:

String s = “Test”;

String s1 = s.substring(2);

则该代码的作用是取字符串s中索引值为2(包括)以后的所有字符作为子串,则字符串s1的值是”st”。

如果数字的值和字符串的长度相同,则返回空字符串。例如:

String s = “Test”;

String s1 = s.substring(4);

则字符串s1的值是””。

如果需要取字符串内部的一部分,则可以使用带2个参数的substring方法,例如:

String s = “TestString”;

String s1 = s.substring(2,5);

则该代码的作用是取字符串s中从索引值2(包括)开始,到索引值5(不包括)的部分作为子串,则字符串s1的值是”stS”。

下面是一个简单的应用代码,该代码的作用是输出任意一个字符串的所有子串。代码如下:

String s = “子串示例”;

int len = s.length(); //获得字符串长度

for(int begin = 0;begin < len – 1;begin++){ //起始索引值

for(int end = begin + 1;end <= len;end++){ //结束索引值

System.out.println(s.substring(begin,end));

}

}

在该代码中,循环变量begin代表需要获得的子串的起始索引值,其变化的区间从第一个字符的索引值0到倒数第二个字符串的索引值len -2,而end代表需要获得的子串的结束索引值,其变化的区间从起始索引值的后续一个到字符串长度。通过循环的嵌套,可以遍历字符串中的所有子串。

m、toCharArray方法

该方法的作用和getBytes方法类似,即将字符串转换为对应的char数组。例如:

String s = “abc”;

char[] c = s.toCharArray();

则字符数组c的值为:{‘a’,’b’,’c’}。

n、toLowerCase方法

该方法的作用是将字符串中所有大写字符都转换为小写。例如:

String s = “AbC123”;

String s1 = s.toLowerCase();

则字符串s1的值是”abc123”,而字符串s的值不变。

类似的方法是toUpperCase,该方法的作用是将字符串中的小写字符转换为对应的大写字符。例如:

String s = “AbC123”;

String s1 = s. toUpperCase ();

则字符串s1的值是”ABC123”,而字符串s的值也不变。

o、trim方法

该方法的作用是去掉字符串开始和结尾的所有空格,然后形成一个新的字符串。该方法不去掉字符串中间的空格。例如:

String s = “   abc abc 123 “;

String s1 = s.trim();

则字符串s1的值为:” abc abc 123”。字符串s的值不变。

p、valueOf方法

该方法的作用是将其它类型的数据转换为字符串类型。需要注意的是,基本数据和字符串对象之间不能使用以前的强制类型转换的语法进行转换。

另外,由于该方法是static方法,所以不用创建String类型的对象即可。例如:

int n = 10;

String s = String.valueOf(n);

则字符串s的值是”10”。虽然对于程序员来说,没有发生什么变化,但是对于程序来说,数据的类型却发生了变化。

介绍一个简单的应用,判断一个自然数是几位数字的逻辑代码如下:

int n = 12345;

String s = String.valueOf(n);

int len = s.length();

则这里字符串的长度len,就代表该自然数的位数。这种判断比数学判断方法在逻辑上要简单一些。

时间: 2024-08-09 07:15:58

10月27日Java整理的相关文章

10月27日全球域名商解析新增量TOP20:爱名网第三

IDC评述网(idcps.com)10月30日报道:根据DailyChanges公布的最新数据显示,在2015年10月27日,全球域名解析新增量二十强排名顺序,环比上期10月20日,有所变动.其中,爱名网以新增量12,053个升至第3,排名环比上升4位.另外,DOMAINCONTROL.COM蝉联冠军,新增量高达30,954个.下面,请看IDC评述网整理的具体数据分析. (图1)全球域名解析商(国际域名)解析新增量Top20分布图 如图1所示,10月27日全球域名解析新增量前五位分别是DOMAI

10月27日中国域名商解析量TOP14:万网蝉联冠军

IDC评述网(idcps.com)10月29日报道:根据DailyChanges公布的实时数据显示,截止至2015年10月27日,国内域名解析量十四强名单顺序,与上期10月20日对比,无任何变动.中国万网继续称王,环比净增78,776个,域名解析量升至3,541,426个.值得一提的是,易名中国发展依旧迅猛,环比净增163,002个,涨幅为十四强之首.接下来,请看IDC评述网整理的具体数据情况. (图1)中国域名解析商(国际域名)解析量排行榜TOP14分布图 通过图1,截止至2015年10月27

10月27日全球域名商解析量TOP21:易名中国升至十三

IDC评述网(idcps.com)10月29日报道:根据DailyChanges公布的实时数据显示,截至2015年10月27日,全球域名解析量前二十一位名单,环比上期10月20日,发生明显变化.其中,易名中国以域名解析量1,275,807个跃居第13名,排名上升5位,环比净增163,002个,涨幅约增大82%,幅度明显.下面,IDC评述网将对具体数据进行整理与分析. (图1)全球域名解析商(国际域名)解析量排行榜TOP21分布图 观察图1,可获悉在全球域名解析量二十一强比拼中,DOMAINCON

中级学员:2015年10月27日作业

中级学员:2015年10月27日作业一.项目收尾管理1.项目收尾包括哪三方面内容?2.项目总结的意义;3.项目总结会包括哪些内容:4.项目评估包括哪些方面:5.项目审计的定义.6.一般项目人员转移的流程:二.知识产权管理1.著作权由哪3个要素组成:2.认定职务作品,考虑的前提有哪2个:三.法律法规和标准规范1.标准名称由哪4个要素组成:2.政府采购法,包括哪六种采购方法,以及每种的前提条件:3.教材中,把标准分为基础标准.开发标准.??标准和??标准.四.请背诵教材P180页项目管理知识体系,并

2016 10月15日java的动手动脑

(1) 编写一个方法,使用以上算法生成指定数目(比如1000个)的随机整数. 源程序: //随机数的产生 //zhanxinwu,October,15,2016 public class Recur { private static final int N = 10; private static final int LEFT = 40; private static final int RIGHT = 100; private static long x0 = 1L; private long

2016年10月27日--css样式表

CSS样式表 样式表分类 1.内联样式表 和html联合显示,控制精确,但是可重用性差,冗余多. !doctype html> <html> <head> <meta charset="UTF-8"> <title>css内嵌样式</title> </head> <body> <style type="text/css"> #div{width:100px;heig

2016年10月27日--格式布局

格式布局 1.position:fixed 相对于浏览器窗口来对元素进行定位 position:fixed <html> <head> <style type="text/css"> p.one { position:fixed; left:5px; top:5px; } p.two { position:fixed; top:30px; right:5px; } </style> </head> <body> &

2015年10月27日 json数据小谈

说来惭愧,第一次见json数据格式还是几个月前实习,当时是在由于公司使用cloudstack做云基础平台的开发,由于cloudstack配合kvm时,其做快照的方式因为要将快照做完后再拷贝到二级存储之类的,很慢,然后我就被拉去做第一个吃螃蟹的人了:修改cloudstack的api,让其直接调用底层rbd方式做快照,结果遇到了很多问题,在其日志中看到了这种堆在一起就像乱码的东西,还不知道其叫json(好了,这是背景)!那时也没有理解太多,只知道怎么看它! 最近使用的次数多了,才慢慢有了一些想法!j

10月27日总结

1.重构,基本上没什么进展.预计今天晚些时候能完成第一次大折腾. 2. 储存图片的文件服务,目前暂定为支持外链的OpenDrive,其具有每天1G流量的限制,但对于我这样的个人网站而言已经足够了,如果以后有发展,再考虑其他更好的. 3.计划明天或晚些时候,第一次大折腾结束的时候重新默写一遍正则,复习js,jquery对数组和字符串的处理. 4.今晚10点钟左右的时候出发,看看附近有没有网吧.以后要习惯本地解决好问题,上网一次查找的日子.