Java Day31

项目完善

使用接口指定规范,完成数据展示过滤功能
例如:
只要学生成绩50分以上
只要学生年龄16岁以下…
方法名要求
accept

(eg 分数低于60,年龄大于16,只要更改实现类中的比较内容,即可更改最后过滤之后得到的符合条件的学生,StudentManager中的过滤方法内容不用更改,即可提高复用度)
分析需要完成的方法
该方法是在遍历展示学生数据的过程中完成的。存在一个判断
for(遍历保存数据的数组) {
if (条件过滤) {
展示
}
}

返回值类型:
	boolean
方法名:
	accept
形式参数列表:
	一个Student学生类对象

interface StudentFilter {
boolean accept(Student stu);
}


```java
package com.qfedu.student.system.filter;

import com.qfedu.student.system.entity.Student;

public interface StudentFilter {
	/**
	 * 判断一个Student类对象是否能够满足条件,满足条件返回true,否则返回false
	 * 条件判断由接口实现类完成
	 * 
	 * @param student Student类对象
	 * @return 满足条件返回true,不满足返回false
	 */
	boolean accept(Student student);
}

package com.qfedu.student.system.filter.impl;

import com.qfedu.student.system.entity.Student;
import com.qfedu.student.system.filter.StudentFilter;

public class StudentFilterImpl implements StudentFilter {

@Override
public boolean accept(Student student) {
	return student.getScore() > 50 && student.getAge() > 100;
}

}


```java
/**
	 * 展示学生信息,但是要求学生信息必须满足过滤器要求
	 * 
	 * @param filter StudentFilter过滤器接口,这里要求传入的是 StudentFilter接口实现类对象
	 */
	public void filterStudentInfo(StudentFilter filter) {
		for (int i = 0; i < size; i++) {
			// 调用接口中的accept方法,约束展示的内容,实际执行该方法的是
			// StudentFilter实现类对象
			if (filter.accept(allStus[i])) {
				System.out.println(allStus[i]);
			}
		}
	}

完成数据的字符串处理过程

程序数据==> 字符串

/**

  • 获取Student类对象中数据的字符串形式
  • @return Student信息字符串
    */
    public String getStudentData() {
    return id + “,” + name + “,” + age + “,” + gender + “,” + score;
    }

字符串 ==> 程序数据

字符串
11,骚磊,166,男,60
==> Student 对象

  1. split(",")
    ==> String类型的数组{“11”, “骚磊”, “166”, “男”, “60”}
  2. id age score ==> int类型
  3. 包装类
    Byte Short Integer Long Float Double Character Boolean
    【解析方法】
    存在将字符串数据 ==> 对应类型的方法。

方法
放在那里???那里类内???
目前该方法存放在Student类内,暂时存放,后期考虑完成一个数据处理类(DAO)
方法权限修饰符
public √
private 不可以
是否需要使用static修饰
成员方法
需要通过类对象来进行操作解析完成
该方法使用场景是在代码的启动阶段从文件中读取字符串数据之后,解析字符
串内容
静态成员方法 √
通过类名直接调用,做成一个工具方法,操作更加方便,摆脱类对象约束
返回值类型:
Student
方法名:
parseStudent
形式参数列表:
String str

方法声明:
public static Student parseStudent(String str);

/**                                                   
 * 解析学生信息字符串,转换成一个Student类对象返回                        
 *                                                    
 * @param str 包含Student信息指定格式字符串                      
 * @return Student类对象                                 
 */                                                   
public static Student parseStudent(String str) {      
	// "11,骚磊,166,男,60"                               
	                                                  
	// 1. split 按照逗号分隔                                
	String[] split = str.split(",");                  
	                                                  
	// {"11","骚磊","166","男","60"}                     
	// Integer.parseInt(String str) 字符串 ==> int类型数据   
	int id = Integer.parseInt(split[0]);              
	String name = split[1];                           
	int age = Integer.parseInt(split[2]);             
	char gender = split[3].charAt(0);                 
	int score = Integer.parseInt(split[4]);           
	                                                  
	/*                                                
	Float.parseFloat(s)                               
	Double.parseDouble(s)                             
	Boolean.parseBoolean(s)                           
	*/                                                
	                                                  
	return new Student(id, name, age, gender, score); 
}                

集合
目前代码中对于多个数据处理过程中,我们采用的方式是数组方式。
数组操作存在的问题:
1. 复用度差!!!
目前对于数据操作有且只能支持一个数据类型,一旦需要操作其他类型,全部
重构,从头来过
2. 空间固定!!!
数组的空间一旦在创建过程中确定,空间无法修改。
3. 方法较少!!!
add remove modify get 。。。
自己写的!!!方法自己实现,体验不好!!!Java中对于数组操作没有提供
太多的有效方法

以上问题集合都可以解决!!!
1. 复用性,没有问题!!!
集合创建采用了泛型模式,可以用户指定任意类型操作!!!既满足普适性,又满足数据类型一致化要求
2. 空间在合理范围以内自行扩展,不需要考虑容量问题
3. 方法很多!!!操作性很好!!!

集合架构

interface Collection Java中所有集合的总接口
–| interface List List接口,数据存储可重复,有序。
----| class ArrayList
重点 可变长数组
----| class LinkedList
重点 双向链表模式
----| class Vector
线程安全的可变长数组
–| interface Set Set接口,数据存储不可以重复,无序
----| HashSet
底层存储数据的结构是一个哈希表,存储效率,查询效率极高!!!
----| TreeSet
底层存储数据的结构是一个平衡二叉树结构,要求数据必须有比较方式!!!

 Collection接口下的常用方法

增:
boolean add(E e)
添加当前集合约束的指定数据类型到当前集合中

boolean addAll(Collection<? extends E> c);
	添加另一个集合到当前集合中,要求添加集合中保存的元素必须是当前集合中保存
	元素本身或者其子类对象 【泛型的上限】
	class Dog extends Animal
	class Cat extends Animal
	class Tiger extends Animal

删:
boolean remove(Object obj);
删除集合中的指定元素,删除成功返回true,未找到指定元素,无法删除返回
false,并且在多个元素的情况下,删除找到的第一个元素。

boolean removeAll(Collection<?> c);
	在当前集合中删除两个集合的交集
	
boolean retainAll(Collection<?> c);
	在当前集合中保留两个集合的交集
	
void clear();
	清空整个集合中的所有元素

查:
int size();
有效元素个数

boolean isEmpty();
	判断当前集合是否为空,是否存在有效元素

boolean contains(Object obj);
	判断指定元素是否在当前集合中存在

boolean containsAll(Collection<?> c);
	判断传入的参数集合是不是当前集合的子集合

Object[] toArray();
	返回集合中所有保存元素的Object类型数组

集合使用迭代器

迭代器是操作集合中元素的第二种方式,后期可以延展使用到很多地方,并且存在一个升级版内容。【增强for循环】
迭代器和集合本身有着密切关系,首先迭代器的获取,就是通过集合对象得到对应当前集合的迭代器。
获取迭代器方法:
	Iterator<E> iterator();
		获取迭代器对象,泛型对应的具体数据类型和集合中约束的泛型具体数据类型
		一致。
迭代器操作使用到的方法:
	boolean hasNext();
		判断当前集合中是否可以继续得到元素,继续遍历。
	E next();
		1. 获取迭代器当前指向的元素
		2. 将迭代器指向下一个元素
	void remove();
		删除通过next方法获取到元素
		【注意事项】
			1. remove方法只能删除next方法获取到元素
			2. remove方法只能在next方法之后执行,且不能跨过一个next执行
			3. 没有next不能使用remove

package com.qfedu.b_iterator;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;

/*
 * 迭代器操作
 */
public class Demo1 {
	public static void main(String[] args) {
		Collection<String> c = new ArrayList<String>();
		
		c.add("雪花纯生");
		c.add("修道院啤酒");
		c.add("1664");
		c.add("泰山精酿");
		c.add("时光精酿");
		
		System.out.println(c);
		
		/*
		 * 获取对应当前集合的迭代器对象
		 * 集合中保存元素是什么类型,迭代器操作元素就是什么类型
		 * 
		 * 迭代器在获取的过程中,默认指向集合中的第一个元素
		 */
		Iterator<String> iterator = c.iterator();
		
		System.out.println("hasNext()方法演示:" + iterator.hasNext());
		System.out.println("next()方法演示:" + iterator.next());
		System.out.println("next()方法演示:" + iterator.next());
		
		System.out.println("remove()执行");
		// 指向迭代器remove方法
		iterator.remove();
		// iterator.remove();
		
		System.out.println(c);
	}
}

package com.qfedu.b_iterator;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;

public class Demo2 {
	public static void main(String[] args) {
		Collection<String> c = new ArrayList<String>();

		c.add("雪花纯生");
		c.add("修道院啤酒");
		c.add("1664");
		c.add("泰山精酿");
		c.add("时光精酿");

		/*
		 * 获取当前集合的迭代器对象
		 */
		Iterator<String> iterator = c.iterator();
		
		while (iterator.hasNext()) {
			String string = iterator.next();
			System.out.println(string);
			
			iterator.remove();
		}
		
		System.out.println(c);
		System.out.println(c.isEmpty());
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值