十五、今日内容介绍

1、Object

2、String

3、StringBuilder

=第一节课开始=======================

01API概念

* A:API(Application Programming Interface)
* 应用程序编程接口
* B:Java API
* 就是Java提供给我们使用的类,这些类将底层的实现封装了起来,
* 我们不需要关心这些类是如何实现的,只需要学习这些类如何使用。
* C: 演示查看Object类中的相关方法

02Object类概述

* A:Object类概述
* 类层次结构的根类
* 所有类都直接或者间接的继承自该类
* Object中描述的所有方法子类都可以使用
* 所有类在创建对象的时候,最终找的父类就是Object。
* B:构造方法
* public Object()
* 回想面向对象中为什么说:
* 子类的构造方法默认访问的是父类的无参构造方法

03equals方法比较内存地址

* A:equals方法比较内存地址
* a: Object类中的equals方法
* 用于比较两个对象是否相同,Object类中就是使用两个对象的内存地址在比较。
* Object类中的equals方法内部使用的就是==比较运算符。 * b: 案例代码 public class Person extends Object{
private String name;
private int age; public Person(){} public Person(String name, int age) {
this.name = name;
this.age = age;
}
/*
* 将父类的equals方法写过来,重写父类的方法
* 但是,不改变父类方法的源代码, 方法equals 比较两个对象的内存地址
*
*/
public boolean equals(Object obj){
return this == obj;
} public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
//测试代码
public class TestEquals {
public static void main(String[] args) {
//Person类继承Object类,继承下来了父类的方法equals
Person p1 = new Person("李四",20);
Person p2 = new Person("张三",20);

				//Person对象p1,调用父类的方法equals,进行对象的比较
boolean b = p1.equals(p1);
System.out.println(b); }
}

04重写equals方法

* A: 重写equals方法
* a: 开发中要比较两个对象是否相同,经常会根据对象中的属性值进行比较
* b: 在开发经常需要子类重写equals方法根据对象的属性值进行比较。
* c: ==号和equals方法的区别
* ==是一个比较运算符号,既可以比较基本数据类型,也可以比较引用数据类型,基本数据类型比较的是值,引用数据类型比较的是地址值
* equals方法是一个方法,只能比较引用数据类型,所有的对象都会继承Object类中的方法,如果没有重写Object类中的equals方法,
equals方法和==号比较引用数据类型无区别,重写后的equals方法比较的是对象中的属性
* d: 案例代码
public class Person extends Object{
private String name;
private int age; public Person(){} public Person(String name, int age) {
this.name = name;
this.age = age;
}
/*
* 重写父类的方法toString()
* 没有必要让调用者看到内存地址
* 要求: 方法中,返回类中所有成员变量的值
*/
public String toString(){
return name + age;
}

			/*
* 将父类的equals方法写过来,重写父类的方法
* 但是,不改变父类方法的源代码, 方法equals 比较两个对象的内存地址
*
* 两个对象,比较地址,没有意义
* 比较两个对象的成员变量,age
* 两个对象变量age相同,返回true,不同返回false
*
* 重写父类的equals,自己定义自己对象的比较方式
*/
public boolean equals(Object obj){
if( this == obj){
return true;
} //对参数obj,非null判断
if( obj == null){
return false;
} if( obj instanceof Person){
// 参数obj接受到是Person对象,才能转型
// 对obj参数进行类型的向下转型,obj转成Person类型
Person p = (Person)obj;
return this.age == p.age;
}
return false;
} public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
//测试代码
public class TestEquals {
public static void main(String[] args) {
//Person类继承Object类,继承下来了父类的方法equals
Person p1 = new Person("李四",20);
Person p2 = new Person("张三",20);

				//Person对象p1,调用父类的方法equals,进行对象的比较
boolean b = p1.equals(p1);
System.out.println(b); }
}

05重写toString方法

* A: 重写toString方法
* a: 为什么要重写toString方法
* toString方法返回该对象的字符串表示,其实该字符串内容就是对象的类型+@+内存地址值。
* 由于toString方法返回的结果是内存地址,而在开发中,经常需要按照对象的属性得到相应的字符串表现形式,因此也需要重写它。
* Object类中的toString的核心代码
getClass().getName() + "@" + Integer.toHexString(hashCode())
* 由于默认情况下的数据对我们来说没有意义,一般建议重写该方法。
* b: 案例核心代码(重写Person类中的toString方法)
/*
* 重写父类的方法toString()
* 没有必要让调用者看到内存地址
* 要求: 方法中,返回类中所有成员变量的值
*/
public String toString(){
return name + age;
}
//Eclipse中自动生成的toString
@Override
public String toString() {
return "Person [name=" + name + ", age=" + age + "]";
}
//测试代码
public class TestToString {
public static void main(String[] args) {
//调用Person类的方法toString()
//输出语句中,写的是一个对象,默认调用对象的toString方法
Person p = new Person("张三",20);
String s = p.toString();
System.out.println(p);
System.out.println(s);
/*
* System.out.println(p);
* System.out.println(p.toString());
*/ /*Random r = new Random();
System.out.println(r.toString()); Scanner sc = new Scanner(System.in);
System.out.println(sc.toString());*/
}
}

======第二节课开始=

06String类的概念和不变性

* A: String类的概念和不变性
* a:String类
* API中的String类的描述,发现String 类代表字符串
* Java 程序中的所有字符串字面值(如 "abc" )都作为此类的实例实现。
* 字符串是常量,在创建之后不能更改
* 其实就是说一旦这个字符串确定了,那么就会在内存区域中就生成了这个字符串。字符串本身不能改变,但str变量中记录的地址值是可以改变的。
* 源码分析,String类底层采用的是字符数组:
private final char value[]
private 修饰说明value只能在String类内部使用,而且又没有提供get方法,所以外部无法获取value数组,就无法改变数组中元素的值
final修饰说明value是常量,一旦创建,就不能被改变,value一旦被初始化成某个数组,将永远指向这个数组,不可能再指向其它的数组了 * b: 案例代码
/*
* String类特点:
* 一切都是对象,字符串事物 "" 也是对象
* 类是描述事物,String类,描述字符串对象的类
* 所有的 "" 都是String类的对象
*
* 字符串是一个常量,一旦创建,不能改变
*/
public class StringDemo {
public static void main(String[] args) {
//引用变量str执行内存变化
//定义好的字符串对象,不变
String str = "itcast";
System.out.println(str);
str = "itheima";
System.out.println(str);

			}
}

07String类创建方式和比较

* A: String类创建方式和比较
* a: 创建对象的数量比较
* String s3 = "abc";
* 在内存中只有一个对象。这个对象在字符串常量池中

 * String s4 = new String("abc");

* 在内存中有两个对象。一个new的对象在堆中,一个字符串本身对象,在字符串常量池中

* b: 案例代码

public class StringDemo2 {

public static void main(String[] args) {

//字符串定义方式2个, 直接= 使用String类的构造方法

String str1 = new String("abc");

String str2 = "abc";

System.out.println(str1);

System.out.println(str2);

				System.out.println(str1==str2);//引用数据类型,比较对象的地址 false
System.out.println(str1.equals(str2));//true
}
}

08String类构造方法

* A: String类构造方法
* a: 常见构造方法
* public String():空构造
* public String(byte[] bytes):把字节数组转成字符串
* public String(byte[] bytes,int index,int length):把字节数组的一部分转成字符串
* public String(String original):把字符串常量值转成字符串
* b: 案例代码
public class StringDemo3 {
public static void main(String[] args) {
function_1();
}
/*
* 定义方法,String类的构造方法
* String(byte[] bytes) 传递字节数组
* 字节数组转成字符串
* 通过使用平台的默认字符集解码指定的 byte 数组,构造一个新的 String。
* 平台 : 机器操作系统
* 默认字符集: 操作系统中的默认编码表, 默认编码表GBK
* 将字节数组中的每个字节,查询了编码表,得到的结果
* 字节是负数,汉字的字节编码就是负数, 默认编码表 ,一个汉字采用2个字节表示
*
* String(byte[] bytes, int offset, int length) 传递字节数组
* 字节数组的一部分转成字符串
* offset 数组的起始的索引
* length 个数,转几个 , 不是结束的索引
*/
public static void function(){
byte[] bytes = {97,98,99,100};
//调用String类的构造方法,传递字节数组
String s = new String(bytes);
System.out.println(s); byte[] bytes1 ={65,66,67,68,69};
//调用String构造方法,传递数组,传递2个int值
String s1 = new String(bytes1,1,3);
System.out.println(s1);
}
}

09String类构造方法_2

* A: String类构造方法
* a: 常见构造方法
* public String(char[] value):把字符数组转成字符串
* public String(char[] value,int index,int count):把字符数组的一部分转成字符串
* B: 案例代码
/*
* String类构造方法
* String类的构造方法,重载形式
*
*/
public class StringDemo3 {
public static void main(String[] args) {
function_1();
}
/*
* String(char[] value) 传递字符数组
* 将字符数组,转成字符串, 字符数组的参数,不查询编码表
*
* String(char[] value, int offset, int count) 传递字符数组
* 将字符数组的一部分转成字符串
* offset 数组开始索引
* count 个数
*/
public static void function_1(){
char[] ch = {'a','b','c','d','e','f'};
//调用String构造方法,传递字符数组
String s = new String(ch);
System.out.println(s); String s1 = new String(ch,1,4);
System.out.println(s1);
}
}

10String类的其他方法

​ * A:String类的其他方法

​ * a: 方法介绍

​ * int length(): 返回字符串的长度

​ * String substring(int beginIndex,int endIndex): 获取字符串的一部分

​ * String substring(int beginIndex): 获取字符串的一部分

​ * boolean startsWith(String prefix): 判断一个字符串是不是另一个字符串的前缀,开头

​ * boolean endsWith(String prefix): 判断一个字符串是不是另一个字符串的后缀,结尾

​ * boolean contains (String s): 判断一个字符串中,是否包含另一个字符串

​ * int indexOf(char ch): 查找一个字符,在字符串中第一次出现的索引,被查找的字符不存在,返回-1

​ * byte[] getBytes(): 将字符串转成字节数组,此功能和String构造方法相反,byte数组相关的功能,查询编码表

​ * char[] toCharArray(): 将字符串转成字符数组,功能和构造方法相反

​ * boolean equals(Object obj): 方法传递字符串,判断字符串中的字符是否完全相同,如果完全相同返回true

​ * boolean equalsIgnoreCase(String s): 传递字符串,判断字符串中的字符是否相同,忽略大小写

	* b: 案例代码

		public class StringDemo4 {
public static void main(String[] args) {
function_9();
}
/*
* boolean equals(Object obj)
* 方法传递字符串,判断字符串中的字符是否完全相同,如果完全相同返回true
*
* boolean equalsIgnoreCase(String s)
* 传递字符串,判断字符串中的字符是否相同,忽略大小写
*/
public static void function_9(){
String str1 = "Abc";
String str2 = "abc";
//分别调用equals和equalsIgnoreCase
boolean b1 = str1.equals(str2);
boolean b2 = str1.equalsIgnoreCase(str2);
System.out.println(b1);
System.out.println(b2);
} /*
* char[] toCharArray() 将字符串转成字符数组
* 功能和构造方法相反
*/
public static void function_8(){
String str = "itcast";
//调用String类的方法toCharArray()
char[] ch = str.toCharArray();
for(int i = 0 ; i < ch.length ; i++){
System.out.println(ch[i]);
}
} /*
* byte[] getBytes() 将字符串转成字节数组
* 此功能和String构造方法相反
* byte数组相关的功能,查询编码表
*/
public static void function_7(){
String str = "abc";
//调用String类方法getBytes字符串转成字节数组
byte[] bytes = str.getBytes();
for(int i = 0 ; i < bytes.length ; i++){
System.out.println(bytes[i]);
}
} /*
* int indexOf(char ch)
* 查找一个字符,在字符串中第一次出现的索引
* 被查找的字符不存在,返回-1
*/
public static void function_6(){
String str = "itcast.cn";
//调用String类的方法indexOf
int index = str.indexOf('x');
System.out.println(index);
} /*
* boolean contains (String s)
* 判断一个字符串中,是否包含另一个字符串
*/
public static void function_5(){
String str = "itcast.cn";
//调用String类的方法contains
boolean b =str.contains("ac");
System.out.println(b);
} /*
* boolean endsWith(String prefix)
* 判断一个字符串是不是另一个字符串的后缀,结尾
* Demo.java
* .java
*/
public static void function_4(){
String str = "Demo.java";
//调用String类方法endsWith
boolean b = str.endsWith(".java");
System.out.println(b);
} /*
* boolean startsWith(String prefix)
* 判断一个字符串是不是另一个字符串的前缀,开头
* howareyou
* hOw
*/
public static void function_3(){
String str = "howareyou";
//调用String类的方法startsWith
boolean b = str.startsWith("hOw");
System.out.println(b);
} /*
* String substring(int beginIndex,int endIndex) 获取字符串的一部分
* 返回新的字符串
* 包含头,不包含尾巴
*
* String substring(int beginIndex)获取字符串的一部分
* 包含头,后面的字符全要
*/
public static void function_2(){
String str = "howareyou";
//调用String类方法substring获取字符串一部分
str= str.substring(1, 5);
System.out.println(str); String str2 = "HelloWorld";
str2 = str2.substring(1);
System.out.println(str2);
} /*
* int length() 返回字符串的长度
* 包含多少个字符
*/
public static void function(){
String str = "cfxdf#$REFewfrt54GT";
//调用String类方法length,获取字符串长度
int length = str.length();
System.out.println(length);
}
}

11String类练习

* A: 获取指定字符串中,大写字母、小写字母、数字的个数
* a: 题目分析
* 为了统计大写字母、小写字母、数字的个数。创建3个计数的变量。
* 为了获取到字符串中的每个字符,进行字符串的遍历,得到每个字符。
* 对得到的字符进行判断,如果该字符为大写字母,则大写字母个数+1;如果该字符为小写字母,则小写字母个数+1;如果该字符为数字,则数字个数+1。
* 显示大写字母、小写字母、数字的个数 * b: 解题步骤
* 略
* 案例代码
public class StringTest {
public static void main(String[] args) {
getCount("A%A3eBr1FFy");
} /*
* 获取指定字符串中,大写字母、小写字母、数字的个数。
* 思想:
* 1. 计数器,就是int变量,满足一个条件 ++
* 2. 遍历字符串, 长度方法length() + charAt() 遍历
* 3. 字符判断是大写,是小写,还是数字
*/
public static void getCount(String str){
//定义三个变量,计数
int upper = 0;
int lower = 0;
int digit = 0;
//对字符串遍历
for(int i = 0 ; i < str.length() ; i++){
//String方法charAt,索引,获取字符
char c = str.charAt(i);
//利用编码表 65-90 97-122 48-57
if(c >='A' && c <=90){
upper++;
}else if( c >= 97 && c <= 122){
lower++;
}else if( c >= 48 && c <='9'){
digit++;
}
}
System.out.println(upper);
System.out.println(lower);
System.out.println(digit);
}
}

12String类练习_2

* A: 将字符串中,第一个字母转换成大写,其他字母转换成小写,并打印改变后的字符串。
* a: 题目分析
* 把字符串分为两个部分,第一部分为字符串中第一个字母,第二部分为剩下的字符串。
* 把第一部分字符串转换成大写字母,把第二部分字符串转换成小写字母
* 把两部分字符串连接在一起,得到一个完整的字符串
* b: 解题步骤
* 略
* C: 案例代码
public class StringTest {
public static void main(String[] args) { System.out.println(toConvert("aBc5%4dEF")); } /*
* 将字符串的首字母转成大写,其他内容转成小写
* 思想:
* 获取首字母, charAt(0) substring(0,1)
* 转成大写 toUpperCase()
*
* 获取剩余字符串, substring(1) toLowerCase()
*/
public static String toConvert(String str){
//定义变量,保存首字母,和剩余字符
String first = str.substring(0,1);
String after = str.substring(1);
//调用String类方法,大写,小写转换
first = first.toUpperCase();
after = after.toLowerCase();
return first+after;
}
}

13String类练习_3

* A: 查询大字符串中,出现指定小字符串的次数
* a: 题目分析
* 在大串中,查找小串出现的位置,出现了就次数+1
* 在上次小串出现位置的后面继续查找,需要更改大串的内容为上次未查询到的字符串。
* 回到第一步,继续查找小串出现的位置,直到大串中查询不到小串为止
* b: 解题步骤
* 略
* C: 案例代码
package cn.itcast.demo02; public class StringTest {
public static void main(String[] args) {
System.out.println(getStringCount("hellojava,nijavahaojava,javazhenbang", "java"));
}
/*
* 获取一个字符串中,另一个字符串出现的次数
* 思想:
* 1. indexOf到字符串中到第一次出现的索引
* 2. 找到的索引+被找字符串长度,截取字符串
* 3. 计数器++
*/
public static int getStringCount(String str, String key){
//定义计数器
int count = 0;
//定义变量,保存indexOf查找后的索引的结果
int index = 0;
//开始循环找,条件,indexOf==-1 字符串没有了
while(( index = str.indexOf(key) )!= -1){
count++;
//获取到的索引,和字符串长度求和,截取字符串
str = str.substring(index+key.length());
}
return count;
}
}

==============第三节课开始=

14StringBuffer特点可变字符数组

* A:StringBuffer类概述
* 通过JDK提供的API,查看StringBuffer类的说明
* 线程安全的可变字符序列
* 底层采用字符数组实现,初始容量为16
* B:StringBuffer和String的区别
* String是一个不可变的字符序列
* StringBuffer是一个可变的字符序列

15StringBuffer类的方法

* A: StringBuffer类的方法
* a: 方法介绍
* StringBuffer append(), 将任意类型的数据,添加缓冲区
* append 返回值,写return this
* 调用者是谁,返回值就是谁
* delete(int start,int end): 删除缓冲区中字符
* 开始索引包含,结尾索引不包含
* insert(int index, 任意类型): 将任意类型数据,插入到缓冲区的指定索引上
* replace(int start,int end, String str): 将指定的索引范围内的所有字符,替换成新的字符串
* reverse(): 将缓冲区中的字符反转
* String toString(): 继承Object,重写toString()
* 将缓冲区中的所有字符,变成字符串
* b: 案例代码
public class StringBufferDemo {
public static void main(String[] args) {
function_5();
}
/*
* StringBuffer类的方法
* String toString() 继承Object,重写toString()
* 将缓冲区中的所有字符,变成字符串
*/
public static void function_5(){
StringBuffer buffer = new StringBuffer();
buffer.append("abcdef");
buffer.append(12345); //将可变的字符串缓冲区对象,变成了不可变String对象
String s = buffer.toString();
System.out.println(s);
} /*
* StringBuffer类的方法
* reverse() 将缓冲区中的字符反转
*/
public static void function_4(){
StringBuffer buffer = new StringBuffer();
buffer.append("abcdef"); buffer.reverse(); System.out.println(buffer);
} /*
* StringBuffer类方法
* replace(int start,int end, String str)
* 将指定的索引范围内的所有字符,替换成新的字符串
*/
public static void function_3(){
StringBuffer buffer = new StringBuffer();
buffer.append("abcdef"); buffer.replace(1, 4, "Q"); System.out.println(buffer);
} /*
* StringBuffer类方法 insert
* insert(int index, 任意类型)
* 将任意类型数据,插入到缓冲区的指定索引上
*/
public static void function_2(){
StringBuffer buffer = new StringBuffer();
buffer.append("abcdef"); buffer.insert(3, 9.5);
System.out.println(buffer);
} /*
* StringBuffer类方法
* delete(int start,int end) 删除缓冲区中字符
* 开始索引包含,结尾索引不包含
*/
public static void function_1(){
StringBuffer buffer = new StringBuffer();
buffer.append("abcdef"); buffer.delete(1,5);
System.out.println(buffer);
} /*
* StringBuffer类方法
* StringBuffer append, 将任意类型的数据,添加缓冲区
* append 返回值,写return this
* 调用者是谁,返回值就是谁
*/
public static void function(){
StringBuffer buffer = new StringBuffer();
//调用StringBuffer方法append向缓冲区追加内容
buffer.append(6).append(false).append('a').append(1.5);
System.out.println(buffer);
}
}

16StringBuilder类

​ * A:StringBuilder的概述

​ * 通过查看API了解一下StringBuilder类

​ * B:面试题

​ * String,StringBuffer,StringBuilder的区别

​ * StringBuffer和StringBuilder的区别

​ * StringBuffer是jdk1.0版本的,是线程安全的,效率低

​ * StringBuilder是jdk1.5版本的,是线程不安全的,效率高

		* String和StringBuffer,StringBuilder的区别
* String是一个不可变的字符序列
* StringBuffer,StringBuilder是可变的字符序列

17StringBuffer类案例拼接数组

* A: StringBuffer类案例拼接数组
* a: 题目分析
* 定义StringBuffer对象
* 遍历数组,按照格式要求拼接处新的字符串,追加到StringBuffer容器中
* 将StringBuffer中的内容以String的形式返回
* b: 解题步骤
* 略
* C: 案例代码
public class StringBufferTest {
public static void main(String[] args) {
int[] arr = {4,1,4,56,7,8,76};
System.out.println(toString(arr));
}
/*
* int[] arr = {34,12,89,68};将一个int[]中元素转成字符串
* 格式 [34,12,89,68]
* String s = "["
* 数组遍历
* s+= arr[i];
* s+"]"
* StringBuffer实现,节约内存空间, String + 在缓冲区中,append方法
*/
public static String toString(int[] arr){
//创建字符串缓冲区
StringBuffer buffer = new StringBuffer();
buffer.append("[");
//数组遍历
for(int i = 0 ; i < arr.length;i++){
//判断是不是数组的最后一个元素
if(i == arr.length-1){
buffer.append(arr[i]).append("]");
}else{
buffer.append(arr[i]).append(",");
}
}
return buffer.toString();
}
}

18总结

  • 把今天的知识点总结一遍。

API

api的概述: 就是java替我们写好的一些类,他封装了一些功能,我们仅仅只需要知道如何使用即可

Object

object的概述:
A、 object是所有的类父类
B、 object中的所有方法,子类都能使用(接口不是object的子类)

Object 类中常用方法

 A、equals()
底层调用其实就是== 方法
== 方法:
基本数据类: 比较的是内容(值)
引用数据类型:比较的是内存地址值
String 的equals比较的是内容

 B、String toString()
问题:为什么要重写toString()方法 答:打印时默认会调用toString()方法
因为toString()方法来源于object中,object中getClass.getName()+"@" +Integer.toHexString(hasCode() ) --->打印就是内存地址值
很多时候,我们不想看见内存地址值,想看到的是子类的特有属性值,这时就需要重写toString()方法

String

 在String 中认为都是对象,String str = "...";
所以str 是对象,""也是对象
String 是一个常量,其本质就是private final 修饰的字符数组 String的构造方法:
new String(byte [] bytes, int offset,int length);
offset: 数据解锁起始位置
length:需要解锁的位数

面试题

object类有哪些方法

final

   A、修饰类 : 不能被继承

   B、修饰方法 : 不能被重写

C、修饰变量 : 基本数据类型: 值不能改变

引用数据类型: 地址值不能改变

重写和重载

 重写:子类中出现和父类方法声明一模一样的方法,重写
重载:本类中出现方法名相同,但参数列表不同,注意:与返回值类型无关

封装

封装好处:
A、提高了代码的复用性
B、提高了代码的安全性
C、隐藏了对象实现的细节,仅仅对外提供方法

继承

A、提高了代码的复用性
B、提高了代码的可维护性
C、是类和类之间耦合起来了,这是多态的前提
继承的弊端:
开发的原则:高内聚,低耦合
内聚:完成一个功能的能力
耦合:类和类之间的关系
继承的注意事项:
1、 子类继承父类,只能继承父类中非private修饰的成员变量和方法
2、 简单说:子类有,父类有,找子类,子类没有,父类有,找父类

十六、今日内容介绍

1、正则表达式的定义及使用

2、Date类的用法

3、Calendar类的用法

==第一阶段

01正则表达式的概念和作用

* A: 正则表达式的概念和作用
* a: 正则表达式的概述
* 正则表达式也是一个字符串,用来定义匹配规则,在Pattern类中有简单的规则定义。
可以结合字符串类的方法使用。
* 简单记:正则表达式是具有特殊含义的字符串。
* b: 正则表达式的作用
* 比如注册邮箱,邮箱有用户名和密码,一般会对其限制长度,这个限制长度的事情就是正则表达式做的

02正则表达式语法规则

* A: 正则表达式语法规则
* a: 字符
* x 代表的是字符x
* \\ 代表的是反斜线字符'\'
* \t 代表的是制表符
* \n 代表的是换行符
* \r 代表的是回车符
* b: 字符类
* [abc] a、b 或 c(简单类)
* [^abc] 任何字符,除了 a、b 或 c(否定)
* [a-zA-Z] a到 z 或 A到 Z,两头的字母包括在内(范围)
* [0-9] 0到9的字符都包括
* [a-zA-Z_0-9] 代表的字母或者数字或者下划线(即单词字符)
* c: 预定义字符类
* . 任何字符。
* \d 数字:[0-9]
* \w 单词字符:[a-zA-Z_0-9]如"com.itheima.tests"/finish
* d: 边界匹配器
* ^ 代表的是行的开头
* $ 代表的是行的结尾
* \b 代表的是单词边界
* e: 数量词
* X? X,一次或一次也没有
* X* X,零次或多次
* X+ X,一次或多次
* X{n} X,恰好 n 次
* X{n,} X,至少 n 次
* X{n,m} X,至少 n 次,但是不超过 m 次

03正则表达式练习和相关的String类方法

* A: 正则表达式练习和相关的String类方法
* a: boolean matches(String 正则的规则)
* "abc".matches("[a]")
* 匹配成功返回true
* b: String[] split(String 正则的规则)
* "abc".split("a")
* 使用规则将字符串进行切割
* c: String replaceAll( String 正则规则,String 字符串)
* "abc0123".repalceAll("[\\d]","#")
* 按照正则的规则,替换字符串

04正则表达式匹配练习

* A: 正则表达式匹配练习
* a: 案例代码
public class RegexDemo {
public static void main(String[] args) {
checkTel();
} /*
* 检查手机号码是否合法
* 1开头 可以是34578 0-9 位数固定11位
*/
public static void checkTel(){
String telNumber = "1335128005";
//String类的方法matches
boolean b = telNumber.matches("1[34857][\\d]{9}");
System.out.println(b);
} /*
* 检查QQ号码是否合法
* 0不能开头,全数字, 位数5,10位
* 123456
* \\d \\D匹配不是数字
*/
public static void checkQQ(){
String QQ = "123456";
//检查QQ号码和规则是否匹配,String类的方法matches
boolean b = QQ.matches("[1-9][\\d]{4,9}");
System.out.println(b);
}
}

05正则表达式切割练习

* A: 正则表达式切割练习
* a: 案例代码
public class RegexDemo1 {
public static void main(String[] args) {
split_1();
split_2();
split_3(); } /*
* String类方法split对字符串进行切割
* 192.168.105.27 按照 点切割字符串
*/
public static void split_3(){
String ip = "192.168.105.27";
String[] strArr = ip.split("\\.");
System.out.println("数组的长度"+strArr.length);
for(int i = 0 ; i < strArr.length ; i++){
System.out.println(strArr[i]);
}
} /*
* String类方法split对字符串进行切割
* 18 22 40 65 按照空格切割字符串
*/
public static void split_2(){
String str = "18 22 40 65";
String[] strArr = str.split(" +");
System.out.println("数组的长度"+strArr.length);
for(int i = 0 ; i < strArr.length ; i++){
System.out.println(strArr[i]);
}
} /*
* String类方法split对字符串进行切割
* 12-25-36-98 按照-对字符串进行切割
*/
public static void split_1(){
String str = "12-25-36-98";
//按照-对字符串进行切割,String类方法split
String[] strArr = str.split("-");
System.out.println("数组的长度"+strArr.length);
for(int i = 0 ; i < strArr.length ; i++){
System.out.println(strArr[i]);
}
}
}

06正则表达式替换练习

​ * A: 正则表达式替换练习

​ * a: 案例代码

​ public class RegexDemo1 {

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

​ replaceAll_1();

​ }

			/*
* "Hello12345World6789012"将所有数字替换掉
* String类方法replaceAll(正则规则,替换后的新字符串)
*/
public static void replaceAll_1(){
String str = "Hello12345World6789012";
str = str.replaceAll("[\\d]+", "#");
System.out.println(str);
}
}

07正则表达式邮箱地址验证

* A: 正则表达式邮箱地址验证
* a: 案例代码
public class RegexDemo2 {
public static void main(String[] args) {
checkMail();
}
/*
* 检查邮件地址是否合法
* 规则:
* 1234567@qq.com
* mym_ail@sina.com
* nimail@163.com
* wodemail@yahoo.com.cn
*
* @: 前 数字字母_ 个数不能少于1个
* @: 后 数字字母 个数不能少于1个
* .: 后面 字母
*
*/
public static void checkMail(){
String email ="abc123@sina.com";
boolean b = email.matches("[a-zA-Z0-9_]+@[0-9a-z]+(\\.[a-z]+)+");
System.out.println(b);
}
}

08毫秒值概念

* A: 毫秒值概念
* a: 时间和日期类
* java.util.Date
* b: 毫秒概念
* 1000毫秒=1秒
* c: 毫秒的0点
* System.currentTimeMillis() 返回值long类型参数
* 获取当前日期的毫秒值 3742769374405
* 时间原点; 公元1970年1月1日,午夜0:00:00 英国格林威治 毫秒值就是0
* 时间2088年8月8日
* 时间和日期的计算,必须依赖毫秒值

09Date类的构造方法

* A: Date类的构造方法
* a: 空参构造
* public Date()
* b: 带参构造
* public Date(long times)

第二阶段======

10Date类的get和set方法

​ * A:Date类的get和set方法

​ * public long getTime()

​ * 将当前的日期对象,转为对应的毫秒值

​ * public void setTime(long times);

​ * 根据给定的毫秒值,生成对应的日期对象

11日期格式化SimpleDateFormat

* A: 日期格式化SimpleDateFormat
* a: 对日期进行格式化(自定义)
* 对日期格式化的类 java.text.DateFormat 抽象类, 普通方法,也有抽象的方法
* 实际使用是子类 java.text.SimpleDateFormat 可以使用父类普通方法,重写了抽象方法
* b: 对日期进行格式化的步骤
* 1: 创建SimpleDateFormat对象
* 在类构造方法中,写入字符串的日期格式 (自己定义)
* 2: SimpleDateFormat调用方法format对日期进行格式化
* public String format(Date date) 传递日期对象,返回字符串
* 日期模式:
* yyyy 年份
* MM 月份
* dd 月中的天数
* HH 0-23小时
* mm 小时中的分钟
* ss 秒
* yyyy年MM月dd日 HH点mm分钟ss秒 汉字修改,: - 字母表示的每个字段不可以随便写

12字符串转成日期对象

* A: 字符串转成日期对象
* a: 使用步骤
* 1: 创建SimpleDateFormat的对象
* 构造方法中,指定日期模式
* 2: 子类对象,调用方法 parse 传递String,返回Date
* 注意: 时间和日期的模式yyyy-MM-dd, 必须和字符串中的时间日期匹配

13Calendar类_1

* A: Calendar类_1
* a: 日历类(抽象类)
* java.util.Calendar
* b: 创建对象
* Calendar类写了静态方法 getInstance() 直接返回了子类的对象
* 不需要直接new子类的对象,通过静态方法直接获取

14Calendar类_2

* A: Calendar类_2
* a: 成员方法
* getTime() 把日历对象,转成Date日期对象
* get(日历字段) 获取指定日历字段的值
* b: 代码演示
Calendar c = Calendar.getInstance();
// 获取年份
int year = c.get(Calendar.YEAR);
// 获取月份
int month = c.get(Calendar.MONTH) + 1;
// 获取天数
int day = c.get(Calendar.DAY_OF_MONTH);
System.out.println(year + "年" + month + "月" + day + "日");

15Calendar类_3

* A: Calendar类_3
* a: 成员方法
* set(int field,int value) 设置指定的时间
* b: 代码演示
/*
* Calendar类的set方法 设置日历 set(int field,int value) field 设置的是哪个日历字段 value
* 设置后的具体数值
*
* set(int year,int month,int day) 传递3个整数的年,月,日
*/
public static void function_1() {
Calendar c = Calendar.getInstance();
// 设置,月份,设置到10月分
// c.set(Calendar.MONTH, 9); // 设置年,月,日
c.set(2099, 4, 1); // 获取年份
int year = c.get(Calendar.YEAR);
// 获取月份
int month = c.get(Calendar.MONTH) + 1;
// 获取天数
int day = c.get(Calendar.DAY_OF_MONTH);
System.out.println(year + "年" + month + "月" + day + "日");
}

16Calendar类_4

* A: Calendar类_4
* a: 成员方法
* add(int field, int value) 进行整数的偏移
* int get(int field) 获取指定字段的值
* b: 案例演示
/*
* Calendar类方法add 日历的偏移量,
* 可以指定一个日历中的字段,
* 进行整数的偏移 add(int field, int value)
*/
public static void function_2() {
Calendar c = Calendar.getInstance();
// 让日历中的天数,向后偏移280天
c.add(Calendar.DAY_OF_MONTH, -280);
// 获取年份
int year = c.get(Calendar.YEAR);
// 获取月份
int month = c.get(Calendar.MONTH) + 1;
// 获取天数
int day = c.get(Calendar.DAY_OF_MONTH);
System.out.println(year + "年" + month + "月" + day + "日");
}

17日期练习_活了多少天

* A: 日期练习_活了多少天
* a: 案例代码
/*
* 计算活了多少天
* 生日 今天的日期
* 两个日期变成毫秒值,减法
*/
public static void function() throws Exception {
System.out.println("请输入出生日期 格式 YYYY-MM-dd");
//获取出生日期,键盘输入
String birthdayString = new Scanner(System.in).next();
//将字符串日期,转成Date对象
//创建SimpleDateFormat对象,写日期模式
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
//调用方法parse,字符串转成日期对象
Date birthdayDate = sdf.parse(birthdayString); //获取今天的日期对象
Date todayDate = new Date(); //将两个日期转成毫秒值,Date类的方法getTime
long birthdaySecond = birthdayDate.getTime();
long todaySecond = todayDate.getTime();
long secone = todaySecond-birthdaySecond; if(secone < 0){
System.out.println("还没出生呢");
}
else{
System.out.println(secone/1000/60/60/24);
} }

18日期练习_闰年计算

* A: 日期练习_闰年计算
* a: 案例代码
/*
* 闰年计算
* 2000 3000
* 高级的算法: 日历设置到指定年份的3月1日,add向前偏移1天,获取天数,29闰年
*/
public static void function_1(){
Calendar c = Calendar.getInstance();
//将日历,设置到指定年的3月1日
c.set(2088, 2, 1);
//日历add方法,向前偏移1天
c.add(Calendar.DAY_OF_MONTH, -1);
//get方法获取天数
int day = c.get(Calendar.DAY_OF_MONTH);
System.out.println(day);
}

19总结

  • 把今天的知识点总结一遍。

十七、今日内容介绍

1、基本类型包装类

2、System类

3、Math类

4、Arrays类

5、大数据运算

=第一节课开始=======================

01基本数据类型对象包装类概述

 *A:基本数据类型对象包装类概述
*a.基本类型包装类的产生
在实际程序使用中,程序界面上用户输入的数据都是以字符串类型进行存储的。而程序开发中,我们需要把字符串数据,根据需求转换成指定的基本数据类型,如年龄需要转换成int类型,考试成绩需要转换成double类型等
*b.八种基本类型对应的包装类
char Character
int Integer
byte Byte
short Short
long Long
float Float
double Double
boolean Boolean

02Integer类parseInt方法

   *A:Integer类parseInt方法:
*a:parseInt()
int i = Integer.parseInt("12");
System.out.println(i/2);//6 *b:parseInt(String s, int radix)
/*
* Integer类静态方法parseInt(String s, int radix)
* radix基数,进制
* "110",2 含义 前面的数字是二进制的,但是方法parseInt运行结果都是十进制
* 指定进制的字符串转换为十进制的整数
*/
public static void function_1(){
int i = Integer.parseInt("110", 2);
System.out.println(i);
}

03Integer类int转成字符串

*A:Integer类int转成字符串:
*a:使用+与字符串拼接
int i = 3;
String s = i+"";
System.out.println(s+1);//"31" *b:toString(int ,int 进制),任意进制整数转成任意进制的字符串 (了解)
String s1 = Integer.toString(5,2);
System.out.println(s1);

04Integer类构造方法

 *A:Integer类构造方法
/*
* Integer类构造方法
* Integer (String s)
* 将数字格式的字符串,传递到Integer类的构造方法中
* 创建Integer对象,包装的是一个字符串
* 将构造方法中的字符串,转成基本数据类型,调用方法,非静态的, intValue()
*/
public static void function_3(){
Integer in = new Integer("100");
int i = in.intValue();
System.out.println(--i);//99
}

05Integer类其他方法

A:Integer类其他方法

/


* Integer类的3个静态方法

* 做进制的转换

* 十进制转成二进制 toBinarString(int)

* 十进制转成八进制 toOctalString(int)

* 十进制转成十六进制 toHexString(int)

* 三个方法,返回值都是以String形式出现

/

a:十进制转二,八,十六进制

public static void function_1(){

System.out.println(Integer.toBinaryString(99));

System.out.println(Integer.toOctalString(99));

System.out.println(Integer.toHexString(999));

}

b:获取int的最大值和最小值

/


* Integer类的静态成员变量

* MAX_VALUE

* MIN_VALUE

*/

public static void function(){

System.out.println(Integer.MAX_VALUE);

System.out.println(Integer.MIN_VALUE);

}

06自动装箱和自动拆箱

*A:自动装箱与自动拆箱:

//JDK1.5新特性

//自动装箱,拆箱的 好处: 基本类型和引用类直接运算

//自动装箱:使用Integer.valueOf(整数值)返回一个封装了该整数值的Integer对象

//自动拆箱:使用Integer对象.intValue()返回Integer对象中封装的整数值

public static void function(){

//引用类型 , 引用变量一定指向对象

//自动装箱, 基本数据类型1, 直接变成了对象

	Integer in = 1; // Integer in = new Integer(1)
//in 是引用类型,不能和基本类型运算, 自动拆箱,引用类型in,转换基本类型 //in+1 ==> in.inValue()+1 = 2
//in = 2 自动装箱
in = in + 1; System.out.println(in); }

07自动装箱和自动拆箱练习题

*A:自动装箱与自动拆箱:

Integer i = new Integer(1);

Integer j = new Integer(1);

System.out.println(i==j);// false 对象地址

System.out.println(i.equals(j));// true 继承Object重写equals,比较的对象数据

 	System.out.println("===================");

 	Integer a = 500;//Integer integer=Integer.valueOf(500)
//integer=new Integer(500);
Integer b = 500;
System.out.println(a==b);//false
System.out.println(a.equals(b));//true System.out.println("===================");

 	//数据在byte(-128~127)范围内,JVM不会从新new对象
Integer aa = 127; // Integer aa = new Integer(127)
Integer bb = 127; // Integer bb = aa;
System.out.println(aa==bb); //true
System.out.println(aa.equals(bb));//true

=第二节课开始============

08System类方法currentTimeMillis

A:System类方法currentTimeMillis():用于计算程序的执行时间

/


* 获取系统当前毫秒值

* static long currentTimeMillis()

* 对程序执行时间测试

*/

public static void function(){

long start = System.currentTimeMillis();//当前时间x-1970年1月1日零时零分零秒

for(int i = 0 ; i < 10000; i++){

System.out.println(i);

}

long end = System.currentTimeMillis();//当前时间y-1970年1月1日零时零分零秒

System.out.println(end - start);//当前时间y-当前时间x

}

09System类方法exit

 *A:System类方法exit()方法
/*
* 退出虚拟机,所有程序全停止
* static void exit(0)
*/
public static void function_1(){
while(true){
System.out.println("hello");
System.exit(0);//该方法会在以后的finally代码块中使用(讲到再说)
}
}

10System类方法gc

A:System类方法gc

public class Person {

public void finalize(){

System.out.println("垃圾收取了");

}

}

    /*
* JVM在内存中,收取对象的垃圾
* 当没有更多引用指向该对象时,会自动调用垃圾回收机制回收堆中的对象
* 同时调用回收对象所属类的finalize方法()
* static void gc()
*/
public static void function_2(){
new Person();
new Person();
new Person();
new Person();
new Person();
new Person();
new Person();
new Person();
System.gc();
}

11System类方法getProperties

A:System类方法getProperties(了解)

/*

* 获取当前操作系统的属性:例如操作系统名称,

* static Properties getProperties()

*/

public static void function_3(){

System.out.println( System.getProperties() );

}

12System类方法arraycopy

 A:System类方法arraycopy:
/*
* System类方法,复制数组
* arraycopy(Object src, int srcPos, Object dest, int destPos, int length)
* Object src, 要复制的源数组
* int srcPos, 数组源的起始索引
* Object dest,复制后的目标数组
* int destPos,目标数组起始索引
* int length, 复制几个
*/
public static void function_4(){
int[] src = {11,22,33,44,55,66};
int[] desc = {77,88,99,0}; System.arraycopy(src, 1, desc, 1, 2);//将src数组的1位置开始(包含1位置)的两个元素,拷贝到desc的1,2位置上
for(int i = 0 ; i < desc.length ; i++){
System.out.println(desc[i]);
}
}

第三节课开始======================

13Math类的方法_1

A:Math类中的方法

/*

  • static double sqrt(double d)

    返回参数的平方根

    */

    public static void function_4(){

    double d = Math.sqrt(-2);

    System.out.println(d);

    }
/*0
  • static double pow(double a, double b)

    a的b次方

    */

    public static void function_3(){

    double d = Math.pow(2, 3);

    System.out.println(d);

    }
/*
  • static double floor(double d)

    返回小于或者等于参数d的最大整数

    */

    public static void function_2(){

    double d = Math.floor(1.5);

    System.out.println(d);

    }
/*
  • static double ceil(double d)

    • 返回大于或者等于参数d的最小整数

      */

      public static void function_1(){

      double d = Math.ceil(5.1);

      System.out.println(d);

      }
/*
  • static int abs(int i)

    • 获取参数的绝对值

      */

      public static void function(){

      int i = Math.abs(0);

      System.out.println(i);

      }

14Math类的方法_2

A:Math类的方法_2

/*

  • static double round(doubl d)
  • 获取参数的四舍五入,取整数

    */

    public static void function_6(){

    double d = Math.round(5.4195);

    System.out.println(d);

    }

/*

  • static double random() 返回随机数 0.0-1.0之间
  • 来源,也是Random类

    */

    public static void function_5(){

    for(int i = 0 ; i < 10 ;i++){

    double d = Math.random();

    System.out.println(d);

    }

    }

15Arrays工具类

A:Arrays工具类:

public class ArraysDemo {

public static void main(String[] args) {

function_2();

int[] arr = {56,65,11,98,57,43,16,18,100,200};

int[] newArray = test(arr);

System.out.println(Arrays.toString(newArray));

}

/*

* 定义方法,接收输入,存储的是10个人考试成绩

* 将最后三个人的成绩,存储到新的数组中,返回新的数组

*/

public static int[] test(int[] arr){

//对数组排序

Arrays.sort(arr);

//将最后三个成绩存储到新的数组中

int[] result = new int[3];

//成绩数组的最后三个元素,复制到新数组中

// System.arraycopy(arr, 0, result, 0, 3);

for(int i = 0 ; i < 3 ;i++){

result[i] = arr[i];

}

return result;

}

	/*
* static String toString(数组)
* 将数组变成字符串
*/
public static void function_2(){
int[] arr = {5,1,4,6,8,9,0};
String s = Arrays.toString(arr);
System.out.println(s);
} /*
* static int binarySearch(数组, 被查找的元素)
* 数组的二分搜索法
* 返回元素在数组中出现的索引
* 元素不存在, 返回的是 (-插入点-1)
*/
public static void function_1(){
int[] arr = {1,4,7,9,11,15,18};
int index = Arrays.binarySearch(arr, 10);
System.out.println(index);
} /*
* static void sort(数组)
* 对数组升序排列
*/
public static void function(){
int[] arr = {5,1,4,6,8,9,0};
Arrays.sort(arr);
for (int i = 0; i < arr.length; i++) {
System.out.println(arr[i]);
}
}
}

16数组复制练习

A:数组复制练习:

public static void main(String[] args) {

int[] arr = {56,65,11,98,57,43,16,18,100,200};

int[] newArray = test(arr);

System.out.println(Arrays.toString(newArray));

}

/


* 定义方法,接收输入,存储的是10个人考试成绩

* 将最后三个人的成绩,存储到新的数组中,返回新的数组

*/

public static int[] test(int[] arr){

//对数组排序

Arrays.sort(arr);

//将最后三个成绩存储到新的数组中

int[] result = new int[3];

//成绩数组的最后三个元素,复制到新数组中

//System.arraycopy(arr, 0, result, 0, 3);

for(int i = 0 ; i < 3 ;i++){

result[i] = arr[i];

}

return result;

}

第四节课开始========

17BigInteger类概述和构造方法

A:BigInteger类概述和构造方法

public static void main(String[] args) {

function();

}

/*

  • BigInteger类的构造方法

    传递字符串,要求数字格式,没有长度限制

    */

    public static void function(){

    BigInteger b = new BigInteger("8465846668464684562385634168451684568645684564564");

    System.out.println(b);

    BigInteger b1 = new BigInteger("5861694569514568465846668464684562385634168451684568645684564564");

    System.out.println(b1);

    }

18BigInteger类四则运算

A:BigInteger类四则运算

public static void main(String[] args) {

function_1();

}

/*

* BigInteger对象的四则运算

* 调用方法计算,计算结果也只能是BigInteger对象

*/

public static void function_1(){

BigInteger b1 = new BigInteger("5665464516451051581613661405146");

BigInteger b2 = new BigInteger("965855861461465516451051581613661405146");

	 //计算 b1+b2对象的和,调用方法 add
BigInteger bigAdd = b1.add(b2);//965855867126930032902103163227322810292
System.out.println(bigAdd); //计算b1-b2对象的差,调用方法subtract
BigInteger bigSub = b1.subtract(b2);
System.out.println(bigSub); //计算b1*b2对象的乘积,调用方法multiply
BigInteger bigMul = b1.multiply(b2);
System.out.println(bigMul); //计算b2/b1对象商,调用方法divied
BigInteger bigDiv = b2.divide(b1);
System.out.println(bigDiv);
}

19员工案例的子类的编写

A:BigDecimal类概述

/*
* 计算结果,未知
* 原因: 计算机二进制中,表示浮点数不精确造成
* 超级大型的浮点数据,提供高精度的浮点运算, BigDecimal
System.out.println(0.09 + 0.01);//0.09999999999999999
System.out.println(1.0 - 0.32);//0.6799999999999999
System.out.println(1.015 * 100);//101.49999999999999
System.out.println(1.301 / 100);//0.013009999999999999
*/

20BigDecimal类实现加法减法乘法

A:BigDecimal类实现加法减法乘法

/*

  • BigDecimal实现三则运算

        • */

          public static void function(){

          BigDecimal b1 = new BigDecimal("0.09");

          BigDecimal b2 = new BigDecimal("0.01");

          //计算b1+b2的和,调用方法add

          BigDecimal bigAdd = b1.add(b2);

          System.out.println(bigAdd);

    BigDecimal b3 = new BigDecimal("1");

    BigDecimal b4 = new BigDecimal("0.32");

    //计算b3-b2的差,调用方法subtract

    BigDecimal bigSub = b3.subtract(b4);

    System.out.println(bigSub);

    BigDecimal b5 = new BigDecimal("1.015");

    BigDecimal b6 = new BigDecimal("100");

    //计算b5*b6的成绩,调用方法 multiply

    BigDecimal bigMul = b5.multiply(b6);

    System.out.println(bigMul);

    }

21BigDecimal类实现除法

 A:BigDecimal类实现除法
/*
* BigDecimal实现除法运算
* divide(BigDecimal divisor, int scale, int roundingMode)
* int scale : 保留几位小数
* int roundingMode : 保留模式
* 保留模式 阅读API文档
* static int ROUND_UP 向上+1
* static int ROUND_DOWN 直接舍去
* static int ROUND_HALF_UP >= 0.5 向上+1
* static int ROUND_HALF_DOWN > 0.5 向上+1 ,否则直接舍去
*/
public static void function_1(){
BigDecimal b1 = new BigDecimal("1.0301");
BigDecimal b2 = new BigDecimal("100");
//计算b1/b2的商,调用方法divied
BigDecimal bigDiv = b1.divide(b2,2,BigDecimal.ROUND_HALF_UP);//0.01301
System.out.println(bigDiv);
}

十八、今日内容介绍

1、集合

2、Iterator迭代器

3、增强for循环

4、泛型

=第一节课开始=======================

01集合使用的回顾

 *A:集合使用的回顾
*a.ArrayList集合存储5个int类型元素
public static void main(String[] args) {
ArrayList<Integer> list = new ArrayList<Integer>();
list.add(111);
list.add(222);
list.add(333);
list.add(444);
list.add(555);
for(int i=0; i<list.size(); i++){
System.out.println(list.get(i));
}
} *b.ArrayList集合存储5个Person类型元素
public static void main(String[] args) {
ArrayList<Person> list = new ArrayList<Person>();
list.add(new Person(“小强”));
list.add(new Person(“老王”));
list.add(new Person(“小虎”));
list.add(new Person(“小泽”));
list.add(new Person(“小红”));
for(int i=0; i<list.size(); i++){
Person p = list.get(i);
System.out.println(p);
}
}

02集合的学习目标

   集合,集合是java中提供的一种容器,可以用来存储多个数据。
在前面的学习中,我们知道数据多了,可以使用数组存放或者使用ArrayList集合进行存放数据。那么,集合和数组既然都是容器,它们有啥区别呢?
 数组的长度是固定的。集合的长度是可变的。
 集合中存储的元素必须是引用类型数据

03集合继承关系图

A:集合继承关系图
a:ArrayList的继承关系:
查看ArrayList类发现它继承了抽象类AbstractList同时实现接口List,而List接口又继承了Collection接口。Collection接口为最顶层集合接口了。
源代码:
interface List extends Collection {
}
public class ArrayList extends AbstractList implements List{
} b:集合继承体系
这说明我们在使用ArrayList类时,该类已经把所有抽象方法进行了重写。那么,实现Collection接口的所有子类都会进行方法重写。
 Collecton接口常用的子接口有:List接口、Set接口
 List接口常用的子类有:ArrayList类、LinkedList类
 Set接口常用的子类有:HashSet类、LinkedHashSet类 Collection 接口
|
----------------------------------------------------------------
| |
List接口 Set接口
| |

| | | |

ArrayList类 LinkedList类 HashSet类 LinkedHashSet类

04集合Collection的方法

A:集合Collection的方法
/*
* Collection接口中的方法
* 是集合中所有实现类必须拥有的方法
* 使用Collection接口的实现类,程序的演示
* ArrayList implements List
* List extends Collection
* 方法的执行,都是实现的重写
*/
public class CollectionDemo {
public static void main(String[] args) {
function_2();
} /* Collection接口方法
* Object[] toArray() 集合中的元素,转成一个数组中的元素, 集合转成数组
* 返回是一个存储对象的数组, 数组存储的数据类型是Object
*/
private static void function_2() {
Collection<String> coll = new ArrayList<String>();
coll.add("abc");
coll.add("itcast");
coll.add("itheima");
coll.add("money");
coll.add("123"); Object[] objs = coll.toArray();
for(int i = 0 ; i < objs.length ; i++){
System.out.println(objs[i]);
}
}
/*
* 学习Java中三种长度表现形式
* 数组.length 属性 返回值 int
* 字符串.length() 方法,返回值int
* 集合.size()方法, 返回值int
*/ /*
* Collection接口方法
* boolean contains(Object o) 判断对象是否存在于集合中,对象存在返回true
* 方法参数是Object类型
*/
private static void function_1() {
Collection<String> coll = new ArrayList<String>();
coll.add("abc");
coll.add("itcast");
coll.add("itheima");
coll.add("money");
coll.add("123"); boolean b = coll.contains("itcast");
System.out.println(b);
} /*
* Collection接口的方法
* void clear() 清空集合中的所有元素
* 集合容器本身依然存在
*/
public static void function(){
//接口多态的方式调用
Collection<String> coll = new ArrayList<String>();
coll.add("abc");
coll.add("bcd");
System.out.println(coll); coll.clear(); System.out.println(coll); }
}

05集合Collection的remove方法

A:05集合Collection的remove方法

/*

* Collection接口方法

* boolean remove(Object o)移除集合中指定的元素

*/

private static void function_3(){

Collection coll = new ArrayList();

coll.add("abc");

coll.add("money");

coll.add("itcast");

coll.add("itheima");

coll.add("money");

coll.add("123");

System.out.println(coll);

  boolean b = coll.remove("money");
System.out.println(b);
System.out.println(coll);
}

=第二节课开始=======================

06迭代器的概述

A:迭代器概述:

a:java中提供了很多个集合,它们在存储元素时,采用的存储方式不同。

我们要取出这些集合中的元素,可通过一种通用的获取方式来完成。

b:Collection集合元素的通用获取方式:在取元素之前先要判断集合中有没有元素,

如果有,就把这个元素取出来,继续在判断,如果还有就再取出出来。一直把集合中的所有元素全部取出。这种取出方式专业术语称为迭代。

c:每种集合的底层的数据结构不同,例如ArrayList是数组,LinkedList底层是链表,但是无论使用那种集合,我们都会有判断是否有元素

以及取出里面的元素的动作,那么Java为我们提供一个迭代器定义了统一的判断元素和取元素的方法

07迭代器的实现原理

A:迭代器的实现原理

/


* 集合中的迭代器:

* 获取集合中元素方式

* 接口 Iterator : 两个抽象方法

* boolean hasNext() 判断集合中还有没有可以被取出的元素,如果有返回true

* next() 取出集合中的下一个元素

*

* Iterator接口,找实现类.

* Collection接口定义方法

* Iterator iterator()

* ArrayList 重写方法 iterator(),返回了Iterator接口的实现类的对象

* 使用ArrayList集合的对象

* Iterator it =array.iterator(),运行结果就是Iterator接口的实现类的对象

* it是接口的实现类对象,调用方法 hasNext 和 next 集合元素迭代

*/

08迭代器的代码实现

*A:迭代器的代码实现

public class IteratorDemo {

public static void main(String[] args) {

Collection coll = new ArrayList();

coll.add("abc1");

coll.add("abc2");

coll.add("abc3");

coll.add("abc4");

//迭代器,对集合ArrayList中的元素进行取出

      //调用集合的方法iterator()获取出,Iterator接口的实现类的对象
Iterator<String> it = coll.iterator();
//接口实现类对象,调用方法hasNext()判断集合中是否有元素
//boolean b = it.hasNext();
//System.out.println(b);
//接口的实现类对象,调用方法next()取出集合中的元素
//String s = it.next();
//System.out.println(s); //迭代是反复内容,使用循环实现,循环的条件,集合中没元素, hasNext()返回了false
while(it.hasNext()){
String s = it.next();
System.out.println(s);
}



    }
}

09迭代器的执行过程

A:迭代器的执行过程

a:迭代器的原理:

while(it.hasNext()) {

System.out.println(it.next());

}

   //cursor记录的索引值不等于集合的长度返回true,否则返回false
public boolean hasNext() {
return cursor != size; //cursor初值为0 } //next()方法作用:
//①返回cursor指向的当前元素
//②cursor++
public Object next() {
int i = cursor;
cursor = i + 1;
return elementData[lastRet = i]; }
b:for循环迭代写法:
for (Iterator<String> it2 = coll.iterator(); it2.hasNext(); ) {
System.out.println(it2.next());
}

10集合迭代中的转型

A:集合迭代中的转型

a:在使用集合时,我们需要注意以下几点:

 集合中存储其实都是对象的地址。

 集合中可以存储基本数值吗?jdk1.5版本以后可以存储了。

因为出现了基本类型包装类,它提供了自动装箱操作(基本类型对象),这样,集合中的元素就是基本数值的包装类对象。

b:存储时提升了Object。取出时要使用元素的特有内容,必须向下转型。
Collection coll = new ArrayList();
coll.add("abc");
coll.add("aabbcc");
coll.add("shitcast");
Iterator it = coll.iterator();
while (it.hasNext()) {
//由于元素被存放进集合后全部被提升为Object类型
//当需要使用子类对象特有方法时,需要向下转型
String str = (String) it.next();
System.out.println(str.length());
}
注意:如果集合中存放的是多个对象,这时进行向下转型会发生类型转换异常。

c:Iterator接口也可以使用<>来控制迭代元素的类型的。代码演示如下:
Collection<String> coll = new ArrayList<String>();
coll.add("abc");
coll.add("aabbcc");
coll.add("shitcast");
Iterator<String> it = coll.iterator();
while (it.hasNext()) {
String str = it.next();
//当使用Iterator<String>控制元素类型后,就不需要强转了。获取到的元素直接就是String类型
System.out.println(str.length());
}

=第三节课开始============

11增强for循环遍历数组

A:增强for循环遍历数组

a:格式:

/


* JDK1.5新特性,增强for循环

* JDK1.5版本后,出现新的接口 java.lang.Iterable

* Collection开是继承Iterable

* Iterable作用,实现增强for循环

*

* 格式:

* for( 数据类型 变量名 : 数组或者集合 ){

* sop(变量);

* }

*/

public static void function_1(){

//for对于对象数组遍历的时候,能否调用对象的方法呢

String[] str = {"abc","itcast","cn"};

for(String s : str){

System.out.println(s.length());

}

}

  /*
* 实现for循环,遍历数组
* 好处: 代码少了,方便对容器遍历
* 弊端: 没有索引,不能操作容器里面的元素
*/
public static void function(){
int[] arr = {3,1,9,0};
for(int i : arr){
System.out.println(i+1);
}
System.out.println(arr[0]);
}

12增强for循环遍历集合

  A:增强for循环遍历集合
/*
* 增强for循环遍历集合
* 存储自定义Person类型
*/
public static void function_2(){
ArrayList<Person> array = new ArrayList<Person>();
array.add(new Person("a",20));
array.add(new Person("b",10));
for(Person p : array){
System.out.println(p);// System.out.println(p.toString());
}
}

13泛型的引入

A:泛型的引入

在前面学习集合时,我们都知道集合中是可以存放任意对象的,

只要把对象存储集合后,那么这时他们都会被提升成Object类型。

当我们在取出每一个对象,并且进行相应的操作,这时必须采用类型转换。比如下面程序:

public class GenericDemo {

public static void main(String[] args) {

List list = new ArrayList();

list.add("abc");

list.add("itcast");

list.add(5);//由于集合没有做任何限定,任何类型都可以给其中存放

//相当于:Object obj=new Integer(5);

    Iterator it = list.iterator();
while(it.hasNext()){
//需要打印每个字符串的长度,就要把迭代出来的对象转成String类型
String str = (String) it.next();//String str=(String)obj;
//编译时期仅检查语法错误,String是Object的儿子可以向下转型
//运行时期String str=(String)(new Integer(5))
//String与Integer没有父子关系所以转换失败
//程序在运行时发生了问题java.lang.ClassCastException
System.out.println(str.length());
}
}
}

14泛型的定义和使用

A:泛型的定义和使用

/*

* JDK1.5 出现新的安全机制,保证程序的安全性

* 泛型: 指明了集合中存储数据的类型 <数据类型>

*/

public class GenericDemo {
public static void main(String[] args) {
function();
} public static void function(){
Collection<String> coll = new ArrayList<String>();
coll.add("abc");
coll.add("rtyg");
coll.add("43rt5yhju");
// coll.add(1); Iterator<String> it = coll.iterator();
while(it.hasNext()){
String s = it.next();
System.out.println(s.length());
}
}
}

15Java中的伪泛型

 A:Java中的伪泛型:
泛型只在编译时存在,编译后就被擦除,在编译之前我们就可以限制集合的类型,起到作用
例如:ArrayList<String> al=new ArrayList<String>();
编译后:ArrayList al=new ArrayList();

第四节课开始======================

16泛型类

A:泛型类:

a:定义格式:

修饰符 class 类名<代表泛型的变量> { }

  例如,API中的ArrayList集合:
class ArrayList<E>{
public boolean add(E e){ }
public E get(int index){ }
} b:使用格式:
创建对象时,确定泛型的类型 例如,ArrayList<String> list = new ArrayList<String>();
此时,变量E的值就是String类型
class ArrayList<String>{
public boolean add(String e){ }
public String get(int index){ }
} 例如,ArrayList<Integer> list = new ArrayList<Integer>();
此时,变量E的值就是Integer类型
class ArrayList<Integer>{
public boolean add(Integer e){ }
public Integer get(int index){ }
}

17泛型的方法

A:泛型的方法

a:定义格式:修饰符 <代表泛型的变量> 返回值类型 方法名(参数){ }

b:泛型方法的使用:

1:例如,API中的ArrayList集合中的方法:

public T[] toArray(T[] a){ }

//该方法,用来把集合元素存储到指定数据类型的数组中,返回已存储集合元素的数组

  使用格式:调用方法时,确定泛型的类型
例如:
ArrayList<String> list = new ArrayList<String>();
String[] arr = new String[100];
String[] result = list.toArray(arr);
此时,变量T的值就是String类型。变量T,可以与定义集合的泛型不同
public <String> String[] toArray(String[] a){ }
 例如:
ArrayList<String> list = new ArrayList<String>();
Integer[] arr = new Integer[100];
Integer [] result = list.toArray(arr); 此时,变量T的值就是Integer类型。变量T,可以与定义集合的泛型不同
public <Integer> Integer[] toArray(Integer[] a){ }

18泛型的接口

A:泛型的接口:

/*

* 带有泛型的接口

*

* public interface List {

* abstract boolean add(E e);

* }

*

* 实现类,先实现接口,不理会泛型

* public class ArrayList implements List{

* }

* 调用者 : new ArrayList() 后期创建集合对象的时候,指定数据类型

*

*

* 实现类,实现接口的同时,也指定了数据类型

* public class XXX implements List{

* }

* new XXX()

*/

public class GenericDemo2 {

 }

19泛型的好处

A:泛型的好处

a:将运行时期的ClassCastException,转移到了编译时期变成了编译失败。

b:避免了类型强转的麻烦。

演示下列代码:

public class GenericDemo {

public static void main(String[] args) {

List list = new ArrayList();

list.add("abc");

list.add("itcast");

//list.add(5);//当集合明确类型后,存放类型不一致就会编译报错

//集合已经明确具体存放的元素类型,那么在使用迭代器的时候,迭代器也同样会知道具体遍历元素类型

    Iterator<String> it = list.iterator();
while(it.hasNext()){
String str = it.next();
System.out.println(str.length()); //当使用Iterator<String>
//控制元素类型后,就不需要强转了。获取到的元素直接就是String类型
}
}
}

20泛型的通配符

A:泛型的通配符

/*

* 泛型的通配符

*/

public class GenericDemo {

public static void main(String[] args) {

ArrayList array = new ArrayList();

  HashSet<Integer> set = new HashSet<Integer>();

  array.add("123");
array.add("456"); set.add(789);
set.add(890); iterator(array);
iterator(set);
}
/*
* 定义方法,可以同时迭代2个集合
* 参数: 怎么实现 , 不能写ArrayList,也不能写HashSet
* 参数: 或者共同实现的接口
* 泛型的通配,匹配所有的数据类型 ?
*/
public static void iterator(Collection<?> coll){
Iterator<?> it = coll.iterator();
while(it.hasNext()){
//it.next()获取的对象,什么类型
System.out.println(it.next());
}
}

}

21泛型的限定

A:泛型的限定

/*

* 将的酒店员工,厨师,服务员,经理,分别存储到3个集合中

* 定义方法,可以同时遍历3集合,遍历三个集合的同时,可以调用工作方法

*/

import java.util.ArrayList;

import java.util.Iterator;

public class GenericTest {

public static void main(String[] args) {

//创建3个集合对象

ArrayList cs = new ArrayList();

ArrayList fwy = new ArrayList();

ArrayList jl = new ArrayList();

  //每个集合存储自己的元素
cs.add(new ChuShi("张三", "后厨001"));
cs.add(new ChuShi("李四", "后厨002")); fwy.add(new FuWuYuan("翠花", "服务部001"));
fwy.add(new FuWuYuan("酸菜", "服务部002")); jl.add(new JingLi("小名", "董事会001", 123456789.32));
jl.add(new JingLi("小强", "董事会002", 123456789.33));

// ArrayList arrayString = new ArrayList();

iterator(jl);

iterator(fwy);

iterator(cs);

}
/*
* 定义方法,可以同时遍历3集合,遍历三个集合的同时,可以调用工作方法 work
* ? 通配符,迭代器it.next()方法取出来的是Object类型,怎么调用work方法
* 强制转换: it.next()=Object o ==> Employee
* 方法参数: 控制,可以传递Employee对象,也可以传递Employee的子类的对象
* 泛型的限定 本案例,父类固定Employee,但是子类可以无限?
* ? extends Employee 限制的是父类, 上限限定, 可以传递Employee,传递他的子类对象
* ? super Employee 限制的是子类, 下限限定, 可以传递Employee,传递他的父类对象
*/
public static void iterator(ArrayList<? extends Employee> array){ Iterator<? extends Employee> it = array.iterator();
while(it.hasNext()){
//获取出的next() 数据类型,是什么Employee
Employee e = it.next();
e.work();
}
}

}

最新文章

  1. NTFS交换数据流隐写的应用
  2. windows常用快捷键
  3. git远程仓库
  4. 【转】oracle回闪操作
  5. SQLServer数据库表架构和数据保存成sql文件
  6. [DFNews] GetData也出取证软件了
  7. SQLite(快速上手版)笔记
  8. java版本的学生管理系统
  9. Android TextView换行问题
  10. DB2 的create or update方法
  11. Linux资源控制-CPU和内存【转】
  12. Android画柱状图,圆形图和折线图的demo
  13. node.js在windows下的学习笔记(1)---安装node.js
  14. [topcoder]NinePuzzle
  15. java websocket工具
  16. JAVA File转Byte[]
  17. 在Magento产品页面的使用jqZoom
  18. PHP中使用CURL(三)
  19. MySQL的常见存储引擎介绍与参数设置调优
  20. BZOJ2738矩阵乘法——整体二分+二维树状数组

热门文章

  1. tensorflow2.0学习笔记第一章第二节
  2. 00-01.Kali Linux 2020.1修改root用户密码
  3. 谈谈Spring中的对象跟Bean,你知道Spring怎么创建对象的吗?
  4. 基于使用ISCSI存储的ibmmq通过heartbeat实现HA方案以及碰到的问题总结
  5. 写了个全局变量的bug,被同事们打脸!!!
  6. TCP 三次握手的意义
  7. 【转载】图解NumPy
  8. OO第一单元——谜之随性总结
  9. cb01a_c++_数据结构_顺序容器_STL_deque类
  10. upd套接字服务器与客户端交互C++代码示范