javaSE第十二天

时间:2023-03-09 09:06:54
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 类型?

原因是:'a' 和 97 其实都可以代表'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

次,应该换一种提示

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

 

取到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"

* 结果:

*

* 分析:

*         前提:字符串要存在

*         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"

* 结果:

*

* 分析:

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

*

*         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) {

        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;

    }

}