javaSE第十二天

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了javaSE第十二天相关的知识,希望对你有一定的参考价值。

第十二天????64

1. Scanner的使用(了解)????64

(1)在JDK5以后出现的用于键盘录入数据的类。????64

(2)构造方法:????64

(4)要掌握的两个方法????65

(5)需要注意的小问题????65

2. String类的概述和使用(掌握)????65

(1)多个字符组成的一串数据。????65

(2)构造方法:????65

(3)字符串的特点????65

(4)字符串的面试题(看程序写结果)????66

(5)字符串的功能(自己补齐方法中文意思)????67

(6)字符串的案例????68

A:模拟用户登录????68

B:字符串遍历????69

C:统计字符串中大写,小写及数字字符的个数????70

D:把字符串的首字母转成大写,其他小写????71

E:把int数组拼接成一个指定格式的字符串????72

F:字符串反转????74

G:统计大串中小串出现的次数????75

?

第十二天

?

1. Scanner的使用(了解)
????(1)JDK5以后出现的用于键盘录入数据的类。
????(2)构造方法:

System类下有一个静态的字段:

public static final InputStream in; //标准的输入流,对应着键盘录入

InputStream is = System.in;

????????A:讲解了System.in这个东西。

????????????它其实是标准的输入流,对应于键盘录入

????????B:构造方法

????????????InputStream is = System.in;????????????

????????????public Scanner(InputStream source)

????????C:常用的格式

????????????Scanner sc = new Scanner(System.in);

????(3)基本方法格式:

????????A:hasNextXxx() 判断是否是某种类型的

格式:public boolean hasNextXxx()

????????B:nextXxx()????返回某种类型的元素

格式:public Xxx nextXxx()

?

举例:用int 类型的方法举例

public boolean hasNext()

public int nextInt()

????(4)要掌握的两个方法

A: public int nextInt():获取一个int类型的数据

???? B: public String nextLine() :获取一个String类型的值

????(5)需要注意的小问题

????????A:同一个Scanner对象,先获取数值,再获取字符串会出现一个小问题。

????????B:解决方案:

????????????a:重新定义一个Scanner对象

????????????b:把所有的数据都用字符串获取,然后再进行相应的转换

????????????

2. String类的概述和使用(掌握)
????(1)多个字符组成的一串数据。

????????其实它可以和字符数组进行相互转换。

????(2)构造方法:

A: public String():空构造

????????B: public String(byte bytes[]):把字节数组转成字符串

C: public String(byte bytes[], int offset, int length)

把字节数组的一部分转成字符串

????????D: public String(char value[]) :把字符数组转成字符串

E: public String(char value[], int offset, int count)

把字符数组的一部分转成字符串

????????F: public String(String original) :把字符串常量值转成字符串

????????下面的这一个虽然不是构造方法,但是结果也是一个字符串对象

????????G: String s = "hello";

?

????????

????(3)字符串的特点

????????A:字符串一旦被赋值,就不能改变(因为字符串为常量)。

????????????注意:这里指的是字符串的内容不能改变,而不是引用不能改变(也就是说引用可以被改变)。

????????B:字面值作为字符串对象和通过构造方法创建对象的不同

?

面试题?

????????????String s = new String("hello");String s = "hello";的区别?

答:前者会创建2个或者1对象,后者创建1个或者0个对象

????(4)字符串的面试题(看程序写结果)

????????A:==和equals()

????????????

String s1 = new String("hello");

????????String s2 = new String("hello");

????????System.out.println(s1 == s2);// false

????????System.out.println(s1.equals(s2));// true

?

????????String s3 = new String("hello");

????????String s4 = "hello";

????????System.out.println(s3 == s4);// false

????????System.out.println(s3.equals(s4));// true

?

????????String s5 = "hello";

????????String s6 = "hello";

????????System.out.println(s5 == s6);// true

????????System.out.println(s5.equals(s6));// true

?

????????B:字符串的拼接

说明:

  1. 字符串如果是变量相加,先开空间,在进行拼接
  2. 字符串如果是常量相加,是先加,然后在常量池中找,如果找到就直接返回,否则,就创建并返回

?

String s1 = "hello";

????????String s2 = "world";

????????String s3 = "helloworld";

????????System.out.println(s3 == s1 + s2);// false

????????System.out.println(s3.equals((s1 + s2)));// true

?

????????System.out.println(s3 == "hello" + "world");// false 这个我们错了,应该是true

????????System.out.println(s3.equals("hello" + "world"));// true

?

?

????(5)字符串的功能(自己补齐方法中文意思)

????????

A:判断功能

1:public boolean equals(Object anObject) :比较字符串的内容是否相同(区分大小写

2:public boolean equalsIgnoreCase(String anotherString) :比较字符串内容是否相同(忽略大小写

???? 3:public boolean contains(String str) :判断大字符串中是否包含小字符串

4:public boolean startsWith(String str) :判断字符串是否以某个指定的字符串开头

5:public boolean endsWith(String str) :判断字符串是否以某个指定的字符串结尾

???? 6:public boolean isEmpty() :判断字符串是否为空

注意:

字符串内容为空和字符串对象为空的区别?

a: 字符串内容为空:表示字符串对象存在,但是没有数据

如:String str = "";

b: 字符串对象为空:表示字符串对象不存在

如:String str = null;

?

???? B:获取功能

???? 1:public int length() :获取字符串的长度

???? ???? 2:public char charAt(int index) :获取指定索引位置的字符

???? ???? 3:public int indexOf(int ch):返回指定字符在此字符串中第一次出现处的索引

为什么这里是int 类型,而不是 char 类型?

原因是:a97 其实都可以代表a

4:public int indexOf(String str)返回指定字符串在此字符串中第一次出现处的索引

5:public int indexOf(int ch,int fromIndex)

返回指定字符在此字符串中从指定位置后第一次出现处的索引

6:public int indexOf(String str,int fromIndex)

返回指定字符串在此字符串中从指定位置后第一次出现处的索引

7:public String substring(int start):从指定位置开始截取字符串,默认截取到末尾

8:public String substring(int start,int end)

从指定位置开始到指定位置结束截取字符串,包头不包尾????????????????????????????????????????????????

?

????????C:转换功能

????????????1:public byte[] getBytes() :把字符串转换为字节数组

????????????2:public char[] toCharArray() :把字符串转换为字符数组

????????????3:public static String valueOf(char[] chs) :把字符数组转换成字符串

????????????4:public static String valueOf(int i) :把int类型的数据转换成字符串

注意:String 类的 valueOf() 方法可以把任意类型的数据转成字符串

????????????5:public String toLowerCase() :把字符串转成小写(原串不变)

????????????6:public String toUpperCase() :把字符串转成大写(原串不变)

????????????7:public String concat(String str) :把字符串进行拼接

?

????????D:其他功能

????????????a:替换功能

????????????1:public String replace(char old,char newChar)

????????????2:public String replace(String oldString, String newString)

????????????b:去空格功能

????????????????public String trim()

????????????c:按字典比较功能

????????????????public int compareTo(String str)

????????????????public int compareToIgnoreCase(String str)

?

?

????(6)字符串的案例

????????A:模拟用户登录

import java.util.Scanner;

/*

* 模拟登录,给三次机会,并提示还有几次。

*

* 分析:

* ????????A:定义用户名和密码。已存在的。

* ????????B:键盘录入用户名和密码。

* ????????C:比较用户名和密码。

* ????????????如果都相同,则登录成功

* ????????????如果有一个不同,则登录失败

* ????????D:给三次机会,用循环改进,最好用for循环。

*/

class StringTest {

????public?static?void main(String[] args) {

????????// 定义用户名和密码。已存在的。

????????String username = "admin";

????????String password = "admin";

?

????????// 给三次机会,用循环改进,最好用for循环。

????????for (int?x = 0; x < 3; x++) {

????????????// x=0,1,2

????????????// 键盘录入用户名和密码。

????????????Scanner sc = new Scanner(System.in);

????????????System.out.println("请输入用户名:");

????????????String name = sc.nextLine();

????????????System.out.println("请输入密码:");

????????????String pwd = sc.nextLine();

?

????????????// 比较用户名和密码。

????????????if (name.equals(username) && pwd.equals(password)) {

????????????????// 如果都相同,则登录成功

????????????????System.out.println("登录成功");

????????????????break;

????????????} else {

????????????????// 如果有一个不同,则登录失败

????????????????// 2,1,0

????????????????// 如果是第0次,应该换一种提示

????????????????if ((2 - x) == 0) {

????????????????????System.out.println("帐号被锁定,请与班长联系");

????????????????} else {

????????????????????System.out.println("登录失败,你还有" + (2 - x) + "次机会");

????????????????}

????????????}

????????}

????}

}

?

????????B:字符串遍历

/*

* 需求:遍历获取字符串中的每一个字符

*

* 分析:

* ????????A:如何能够拿到每一个字符呢?

* ????????????char charAt(int index)

* ????????B:我怎么知道字符到底有多少个呢?

* ????????????int length()

*/

class StringTest {

????public?static?void main(String[] args) {

????????// 定义字符串

????????String s = "helloworld";

?

????????// 原始版本

????????// System.out.println(s.charAt(0));

????????// System.out.println(s.charAt(1));

????????// System.out.println(s.charAt(2));

????????// System.out.println(s.charAt(3));

????????// System.out.println(s.charAt(4));

????????// System.out.println(s.charAt(5));

????????// System.out.println(s.charAt(6));

????????// System.out.println(s.charAt(7));

????????// System.out.println(s.charAt(8));

????????// System.out.println(s.charAt(9));

?

????????// 只需要我们从0取到9

????????// for (int x = 0; x < 10; x++) {

????????// System.out.println(s.charAt(x));

????????// }

?

????????// 如果长度特别长,我不可能去数,所以我们要用长度功能

????????for (int?x = 0; x < s.length(); x++) {

????????????// char ch = s.charAt(x);

????????????// System.out.println(ch);

????????????// 仅仅是输出,我就直接输出了

????????????System.out.println(s.charAt(x));

????????}

????}

}

?

????????C:统计字符串中大写,小写及数字字符的个数

/*

* 需求:统计一个字符串中大写字母字符,小写字母字符,数字字符出现的次数。(不考虑其他字符)

* 举例:

* ????????"Hello123World"

* 结果:

* ????????大写字符:2

* ????????小写字符:8

* ????????数字字符:3

*

* 分析:

* ????????前提:字符串要存在

* ????????A:定义三个统计变量

* ????????????bigCount=0

* ????????????smallCount=0

* ????????????numberCount=0

* ????????B:遍历字符串,得到每一个字符。

* ????????????length()charAt()结合

* ????????C:判断该字符到底是属于那种类型的

* ????????????大:bigCount++

* ????????????小:smallCount++

* ????????????数字:numberCount++

*

* ????????????这道题目的难点就是如何判断某个字符是大的,还是小的,还是数字的。

* ????????????ASCII码表:

* ????????????????0????48

* ????????????????A????65

* ????????????????a????97

* ????????????虽然,我们按照数字的这种比较是可以的,但是想多了,有比这还简单的

* ????????????????char ch = s.charAt(x);

*

* ????????????????if(ch>=‘0‘ && ch<=‘9‘) numberCount++

* ????????????????if(ch>=‘a‘ && ch<=‘z‘) smallCount++

* ????????????????if(ch>=‘A‘ && ch<=‘Z‘) bigCount++

*????????D:输出结果。

*

* 练习:把给定字符串的方式,改进为键盘录入字符串的方式。

*/

class StringTest2 {

????public?static?void main(String[] args) {

????????// 定义一个字符串

????????String s = "Hello123World";

?

????????// 定义三个统计变量

????????int?bigCount = 0;

????????int?smallCount = 0;

????????int?numberCount = 0;

?

????????// 遍历字符串,得到每一个字符。

????????for (int?x = 0; x < s.length(); x++) {

????????????char?ch = s.charAt(x);

?

????????????// 判断该字符到底是属于那种类型的

????????????if (ch >= ‘a‘ && ch <= ‘z‘) {

????????????????smallCount++;

????????????} else?if (ch >= ‘A‘ && ch <= ‘Z‘) {

????????????????bigCount++;

????????????} else?if (ch >= ‘0‘ && ch <= ‘9‘) {

????????????????numberCount++;

????????????}

????????}

?

????????// 输出结果。

????????System.out.println("大写字母" + bigCount + "");

????????System.out.println("小写字母" + smallCount + "");

????????System.out.println("数字" + numberCount + "");

????}

}

?

????????D:把字符串的首字母转成大写,其他小写

/*

* 需求:把一个字符串的首字母转成大写,其余为小写。(只考虑英文大小写字母字符)

* 举例:

* ????????helloWORLD

* 结果:

* ????????Helloworld

*

* 分析:

* ????????A:先获取第一个字符

* ????????B:获取除了第一个字符以外的字符

* ????????C:A转成大写

* ????????D:B转成小写

* ????????E:C拼接D

*/

class StringTest {

????public?static?void main(String[] args) {

????????// 定义一个字符串

????????String s = "helloWORLD";

?

????????// 先获取第一个字符

????????String s1 = s.substring(0, 1);

????????// 获取除了第一个字符以外的字符

????????String s2 = s.substring(1);

????????// A转成大写

????????String s3 = s1.toUpperCase();

????????// B转成小写

????????String s4 = s2.toLowerCase();

????????// C拼接D

????????String s5 = s3.concat(s4);

????????System.out.println(s5);

?

????????// 优化后的代码

????????// 链式编程

????????String result = s.substring(0, 1).toUpperCase().concat(s.substring(1).toLowerCase());

????????System.out.println(result);

????}

}

?

????????E:把int数组拼接成一个指定格式的字符串

/*

* 需求:把数组中的数据按照指定个格式拼接成一个字符串

* 举例:

* ????????int[] arr = {1,2,3};????

* 输出结果:

*????????"[1, 2, 3]"

* 分析:

* ????????A:定义一个字符串对象,只不过内容为空

* ????????B:先把字符串拼接一个"["

* ????????C:遍历int数组,得到每一个元素

* ????????D:先判断该元素是否为最后一个

* ????????????是:就直接拼接元素和"]"

* ????????????不是:就拼接元素和逗号以及空格

* ????????E:输出拼接后的字符串

*

* 把代码用功能实现。

*/

class StringTest2 {

????public?static?void main(String[] args) {

????????// 前提是数组已经存在

????????int[] arr = { 1, 2, 3 };

?

????????// 写一个功能,实现结果

????????String result = arrayToString(arr);

????????System.out.println("最终结果是:" + result);

????}

?

????/*

???? * 两个明确: 返回值类型:String 参数列表:int[] arr

???? */

????public?static String arrayToString(int[] arr) {

????????// 定义一个字符串

????????String s = "";

?

????????// 先把字符串拼接一个"["

????????s += "[";

?

????????// 遍历int数组,得到每一个元素

????????for (int?x = 0; x < arr.length; x++) {

????????????// 先判断该元素是否为最后一个

????????????if (x == arr.length - 1) {

????????????????// 就直接拼接元素和"]"

????????????????s += arr[x];

????????????????s += "]";

????????????} else {

????????????????// 就拼接元素和逗号以及空格

????????????????s += arr[x];

????????????????s += ", ";

????????????}

????????}

?

????????return?s;

????}

}

?

????????F:字符串反转

import java.util.Scanner;

?

/*

* 字符串反转

* 举例:键盘录入"abc"????????

* 输出结果:"cba"

*

* 分析:

* ????????A:键盘录入一个字符串

* ????????B:定义一个新字符串

* ????????C:倒着遍历字符串,得到每一个字符

* ????????????a:length()charAt()结合

* ????????????b:把字符串转成字符数组

* ????????D:用新字符串把每一个字符拼接起来

* ????????E:输出新串

*/

class StringTest3 {

????public?static?void main(String[] args) {

????????// 键盘录入一个字符串

????????Scanner sc = new Scanner(System.in);

????????System.out.println("请输入一个字符串:");

????????String line = sc.nextLine();

?

????????/*

???????? * // 定义一个新字符串 String result = "";

???????? *

???????? * // 把字符串转成字符数组 char[] chs = line.toCharArray();

???????? *

???????? * // 倒着遍历字符串,得到每一个字符 for (int x = chs.length - 1; x >= 0; x--) { //

???????? * 用新字符串把每一个字符拼接起来 result += chs[x]; }

???????? *

???????? * // 输出新串 System.out.println("反转后的结果是:" + result);

???????? */

?

????????// 改进为功能实现

????????String s = myReverse(line);

????????System.out.println("实现功能后的结果是:" + s);

????}

?

????/*

???? * 两个明确: 返回值类型:String 参数列表:String

???? */

????public?static String myReverse(String s) {

????????// 定义一个新字符串

????????String result = "";

?

????????// 把字符串转成字符数组

????????char[] chs = s.toCharArray();

?

????????// 倒着遍历字符串,得到每一个字符

????????for (int?x = chs.length - 1; x >= 0; x--) {

????????????// 用新字符串把每一个字符拼接起来

????????????result += chs[x];

????????}

????????return?result;

????}

}

?

????????G:统计大串中小串出现的次数

/*

* 统计大串中小串出现的次数

* 举例:

* ????????在字符串"woaijavawozhenaijavawozhendeaijavawozhendehenaijavaxinbuxinwoaijavagun"

* 结果:

* ????????java出现了5

*

* 分析:

* ????????前提:是已经知道了大串和小串。

*

* ????????A:定义一个统计变量,初始化值是0

* ????????B:先在大串中查找一次小串第一次出现的位置

* ????????????a:索引是-1,说明不存在了,就返回统计变量

* ????????????b:索引不是-1,说明存在,统计变量++

* ????????C:把刚才的索引+小串的长度作为开始位置截取上一次的大串,

????????????????返回一个新的字符串,并把该字符串的值重新赋值给大串

* ????????D:回到B

*/

class StringTest5 {

????public?static?void main(String[] args) {

????????// 定义大串

????????String maxString = "woaijavawozhenaijavawozhendeaijavawozhendehenaijavaxinbuxinwoaijavagun";

????????// 定义小串

????????String minString = "java";

?

????????// 写功能实现

????????int?count = getCount(maxString, minString);

????????System.out.println("Java在大串中出现了:" + count + "");

????}

?

????/*

???? * 两个明确: 返回值类型:int 参数列表:两个字符串

???? */

????public?static?int getCount(String maxString, String minString) {

????????// 定义一个统计变量,初始化值是0

????????int?count = 0;

?

????????/*

???????? * // 先在大串中查找一次小串第一次出现的位置 int index = maxString.indexOf(minString); //

???????? * 索引不是-1,说明存在,统计变量++ while (index != -1) { count++; //

???????? * 把刚才的索引+小串的长度作为开始位置截取上一次的大串, 返回一个新的字符串,并把该字符串的值重新赋值给大串 // int

???????? * startIndex = index + minString.length(); // maxString =

???????? * maxString.substring(startIndex); maxString =

???????? * maxString.substring(index + minString.length()); // 继续查 index =

???????? * maxString.indexOf(minString); }

???????? */

?

????????int?index;

????????// 先查,赋值,判断

????????while ((index = maxString.indexOf(minString)) != -1) {

????????????count++;

????????????maxString = maxString.substring(index + minString.length());

????????}

?

????????return?count;

????}

}

?

?

以上是关于javaSE第十二天的主要内容,如果未能解决你的问题,请参考以下文章

javaSE第二十二天

javaSE第十三天

javaSE第十五天

javaSE第十八天

javaSE第十六天

javaSE第十七天