项目和集合

1项目


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

1.1.1对于数据处理的基本理念 

程序数据 ==> 字符串 ==> 文件

文件 ==> 字符串 ==> 程序数据

1.1.2程序数据 ==> 字符串

Student [ id = 11 , name = 骚磊 , age = 16, gender =  男, score = 60]

数据 

11 骚磊 16 男 60

每一个数据都有对应的指向性

数据对应的名称不需要保存

但是要约束好数据的存储和解析规范(规范化数据传输格式)

保存数据

11 骚磊 16 男 60 ==> 11 ,骚磊,16 ,男,60 ==> String + 万嫩胶水

public String getStudentData() {

return id + "," +name + "," + age + "," + gender + "," + score;

}

1.1.3字符串 ==> 程序数据

字符串

    11,骚磊 ,16,男,60

==> Student 对象

1spit(“,”)

==> String 类型的数组{“11”,“骚磊”,“16”,“男”,“60”}

2id age score ==> int类型

3包装类

Byte Short Integer Long Float Double Character Boolean

【解析方法】

    存在将字符串数据 ==> 对应类型的方法

方法

    目前该方法存在Student类内,暂时存放,后期考虑完成一个数据处理类(DAO)

方法权限修饰符

public

静态成员方法

通过类名的直接调用,做成一个工具方法,操作更加便捷,摆脱类对象约束

返回值类型

Student 

方法名

parseStudent

形式参数列表

String str

方法声明

public static Student parseStudent(String str);

2集合【重点】

2.1集合概述

1代码复用

集合创建采用了泛型模式,可以用户指定任意类型操作!!!既满足普适性,又满足数据类型一致化要求

2空间在合理范围以内自行扩展,不需要考虑容量问题

3方法很多!!!操作性很好!!!

2.2集合架构【重点】

inerface Collection java中所有集合的总接口

--| interface List List 接口,数据存储可重复,有序。

------| class ArrayList 

重点 可变长数组

——————| class Vetor  

重点 双向链表模式

-------------| interface Set Set 接口,数据村塾不可以重复,无序

-----------| HashSet  

底层存储数据的结构是一个哈希表,存储效率,查询效率极高!!

---------| TreeSet 底层存储数据的结构是一个平衡二叉树结构,要求数据必须有比较方式!!

2.3Collection接口下的常用方法【重点】

    boolean add(E e)

添加当前集合约束的指定数据类型到当期集合中

    boolean addAll(Collection < ?extends E> c);

添加另一个集合到当前集合中,要求添加集合中保存的元素必须是当前集合中保存

boolean remove (Object obj);

删除集合中的指定元素,删除成功返回true ,未找到指定元素,无法删除返回false,并且在多个元素的情况下,删除找到的第一个元素

boolean removeAll(Collection<?>c);

在当前集合中删除两个集合的交集

boolean retainAll(Collection c);

在当前集合中保留两个集合的交集

void clear ();

清空整个集合中的所有元素

int size ();

有效元素个数

boolean contains(Object obj);

判断指定元素是否在当前集合中存在

boolean containsAll(Collection c);

判断传入的参数集合是不是当前集合的子集合

Object [] toArray();

返回集合中所有保存元素的Object类型数组

2.4泛型上限

package com.qfenrxs;

import java.util.ArrayList;

import java.util.Collection;

class Animal {}

class Dog extends Animal {}

class Cat extends Animal {}

class Flower {}

public class Demo3 {

public static void main(String[] args) {

Collection c1 = new ArrayList();

Collection c2 = new ArrayList();

Collection c3 = new ArrayList();

Collection c4 = new ArrayList();

Collection c5 = new ArrayList();

c1.addAll(c1);

c1.addAll(c2);

c1.addAll(c3);

System.out.println(c1);

}

}

2.5 ?泛型通配符

boolean removeAll(Collection c);

在当前集合中删除两个集合的交集

boolean retainAll(Collection c);

在当前集合中保留两个集合的交集

boolean containsAll(Collections  c);

判断传入参数集合是不是当前集合的子集合

?在当前情况下描述的场景为,不限制传入参数Collection集合中的保存元素

只要求参数类型是Collection

2.6集合使用迭代器

2.6.1迭代器描述和操作模式


迭代器是操作集合中元素第二种方式【增强for循环】

迭代器的获取通过集合对象得到对应当前集合的迭代器

获取迭代器的方法

Interator iterator ();

获取迭代器对象,泛型对应具体数据类型和集合中约束的泛型具体数据类型一致

迭代器操作使用到的方法

boolean hasNext();

判断当前集合中是否可以继续得到元素继续遍历

E next();

1获取迭代器当前指向的元素

2将迭代器指向下一个元素

void remo();

删除通过next方法获取到元素

【注意事项】

1remove放啊发只能删除next方法获取到元素

2remove方法只能在next方法之后执行且不能跨过一个next执行

3没有next 不能使用remove

2.6.2使用迭代器操作集合

package com.qfenrxs;

import java.util.ArrayList;

import java.util.Collection;

import java.util.Iterator;

public class Demo2 {

public static void main(String[] args) {

Collection c = new ArrayList();

c.add("11");

c.add("22");

c.add("33");

c.add("44");

c.add("55");

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

}

}

package com.qfenrxs;

import java.util.ArrayList;

import java.util.Collection;

import java.util.Iterator;

public class Demo1 {

public static void main(String[] args) {

Collection c = new ArrayList();

c.add("12");

c.add("22");

c.add("11");

c.add("112");

System.out.println(c);

Iterator 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()执行");

iterator.remove();

System.out.println(c);

}

}

2.6.3迭代器和集合引用数据类型变量冲突问题【难】

package com.qfenrxs;

import java.util.ArrayList;

import java.util.Collection;

import java.util.Iterator;

public class Demo4 {

public static void main(String[] args) {

Collection c = new ArrayList();

c.add("111");

c.add("222");

c.add("333");

c.add("444");

c.add("555");

Iterator iterator = c.iterator();

while (iterator.hasNext()) {

String string =  iterator.next();

System.out.println(string);

/*

* 对于集合在内存中占用的空间而言

* 1集合对应的引用数据类型变量可以操作对应空间

*

* 2迭代器可以操作对应的空间

*

* 对于集合和迭代器来说【集合在内存中占用的空间】在操作共享资源过程中,需要考虑资源的冲突问题

*

*/

c.remove("222");

}

}

}

你可能感兴趣的:(项目和集合)