《数组字符串及容器类.ppt》由会员分享,可在线阅读,更多相关《数组字符串及容器类.ppt(45页珍藏版)》请在三一办公上搜索。
1、第6章 数组、字符串及容器类,数组类型属于复合数据类型,它是由类型相同的元素组成的有序的数据集合。因此数组最主要的特点是:(1)元素类型相同;(2)元素有序;(3)所有元素公用一个名称。另外,根据组织数组的结构不同,数组可以分为一维数组、二维数组、,依此类推。,第6章 数组、字符串及容器类,6.1一维数组6.2多维数组6.3字符串处理 6.4数组与容器的比较 6.5容器6.6迭代器6.7容器的分类法6.8总结6.9习题,6.1一维数组,一维数组的声明 一维数组的初始化 一维数组的引用,一维数组的声明,数组声明的语法格式有以下两种:arraytype array-name;或arraytype
2、array-name;例如:int month_days;或int month_days;,一维数组的初始化,静态初始化是在定义数组的同时对数组元素进行初始化:String strName=“I”,”like”,”Java!”;String strName=“I”,”like”,”Java!”;数组的动态初始化:数组名=new数组元素类型长度;即:array-name=new typearraySize;P124,一维数组的引用,所谓数组元素的引用,指的是如何在程序中引用初始化后的数组元素,引用的方式为arrayNameindex,其中index为数组的下标,可以是整型常数、变量和表达式,范围
3、是从0开始,一直到数组的长度减一。例如:int a=1,2,3,4,5;a0=1;a1=2;a2=3;a3=4;a4=5;p125,6.2多维数组,二维数组的声明 二维数组的初始化 二维数组的引用,二维数组的声明,二维数组和一维数组一样,也必须先声明再创建,声明和创建也可以合在一条语句中完成。二维数组声明的格式为:数组元素类型 数组名;或数组元素类型 数组名;,二维数组的初始化,二维数组的初始化也分为静态初始化和动态初始化两种。所谓静态初始化,就是在定义二维数组的同时为数组分配了空间,如下:int int_array=1,1,1,2,2,2,3,3,3;对于二维数组的动态初始化,可以有两种方法
4、:(1)直接为每一维分配空间,格式如下:arrayName=new typearrayLen1 arrayLen2;(2)从最高维开始,分别为每一维分配空间,格式如下:arrayName=new type arrayLen1;,二维数组的引用,对二维数组中元素的引用格式如下:arrayNameindex1index2;其中arrayName代表二维数组的名称,index1和index2是下标,与一维数组一样,这两个下标可以是常数、变量和表达式,如int_array 12、int_array a1、int_array a*20,而且每一维的下标都是从0开始,一直到该维长度减一。p129页,6.3
5、字符串处理,生成字符串访问字符串 修改字符串 其他操作,生成字符串,1.构造String实例对象的方法 构造String实例对象的方法主要有三种:(1)采用双引号将Java字符序列括起来,既通过构造字符串直接量的方式构造String实例对象。例如:String s1=”abcd”;(2)采用new运算符 例如:String s1=new String();(3)通过运算符”+”或其他成员方法生成String实例对象。例如:String s1=”abcd”+”1234”;,生成字符串,2.StringBuffer类的主要构造方法(1)public StringBuffer()创建一个空的Stri
6、ngBuffer类;(2)public StringBuffer(int length)创建一个大小为length的StringBuffer类;(3)public StringBuffer(String str)按str创建一个动态可变的StringBuffer类。,访问字符串,所谓访问字符串,就是获得字符串的长度,得到某个字符或子串在字符串中的索引位置获得到指定位置的字符或字串。1.String类的常用方法 2.StringBuffer类的常用方法,修改字符串,在对字符串的操作中,经常会对给定的字符串进行一些修改操作,在本小节中,我们将对类String和StringBuffer中提供的一些字
7、符串修改方法进行介绍,主要是介绍String类提供的几种方法。,其他操作,这里将介绍一些与字符串有关的其他方法,例如:1.startsWith(String preString)和endWith(String endString)2.startsWith(String preString,int offsetInd)3.equals()和equalsIgnoreCase(),6.4数组与容器类的比较,数组与容器类的区别 类,数组与容器类的区别,(1)效率(2)类型(3)持有基本类型的能力,数组与容器类的区别,数组的简单实例:实际上我们无论使用哪种数组,数组的标识符都只是一个引用,可以作为数组初
8、始化的一部分隐式的创建这个对象,或用new表达式显式的来创建。length方法表示数组对象能够存储多少元素,“”操作符是访问数组对象的唯一一种方式。,数组与容器类的区别,基本类型的容器:数组可以保存对象的引用,也可以直接保存基本类型,而容器类只能保存对象的引用。当然容器中可以使用包装类,如Integer,Byte,Double等,用来代替基本类型的值。但是相对于基本数据类型,包装类使用起来不是很方便。,类,填充数组 复制数组 比较数组 比较数组元素 binarySearch()的用法,6.5容器,容器类简介容器的填充容器的缺点,容器类简介,Java2容器类类库的用途是“保存对象”,它分为两类:
9、Collection:一组独立的元素,通常这些元素都服从某种规则。List必须保持元素特定的顺序,而Set不能有重复元素。Map:一组成对的“键值对”对象,即其元素是成对的对象。,容器的填充,Collections也有一个非常实用的static方法集,其中有一个fill()方法,该方法的作用也是用同一个对象的引用来填充容器,并只对List对象起作用,而对Set或Map不起作用。,容器的缺点,(1)我们将对象的引用加入容器时就丢失了类型的信息,也就是说对于放入容器的对象就没有类型限制了,即便是我们刻意保持容器的类型,别人也可以轻易的对其进行修改。(2)由于丢失了类型信息,容器只能认为它保存的是O
10、bject类型的引用。因此在使用容器中的元素之前一定要做类型转换。,6.6迭代器,迭代器是一种设计模式,它是一个对象,它可以遍历并选择序列中的对象,而开发人员不需要了解该序列的底层结构。迭代器通常被称为“轻量级”对象,因为创建它的代价小。Java中的Iterator功能比较简单,并且只能单向移动:(1)iterator()方法:要求容器返回一个Iterator。第一次调用Iterator的next()方法,它将返回序列中的第一个元素;(2)next()方法:获得序列中的下一个元素;(3)hasNext()方法:检查序列中是否还有元素;(4)remove()方法:将迭代器新返回的元素删除。,6.
11、7容器的分类法,6.7.1Collection 接口 接口 接口 接口 集合类对equals()和hashCode()方法的要求,6.7.1Collection 接口,Collection类的方法 boolean add(Object obj)boolean remove(Object obj)int size()boolean isEmpty()boolean contains(Object obj)Iterator iterator()boolean containsAll(Collection c)boolean addAll(Collection c)void clear()void
12、removeAll(Collection c)void retainAll(Collection c),接口,(1)面向位置的操作包括插入某个元素或者Collection的功能,还包括获取、除去或更改元素的功能。在 List 中搜索元素可以从列表的头部或尾部开始,如果找到元素,将报告元素所在的位置。(2)List 接口不但能以位置序列迭代的遍历整个列表,而且还能处理集合的子集。,接口,LinkedList的主要方法 void addFirst(Object obj)void addLast(Object obj)Object getFirst()Object getLast()Object r
13、emoveFirst()Object removeLast()LinkedList()LinkedList(Collection c),接口,ArrayList类的主要方法 void ensureCapacity(int minCapacity)void trimToSize(),接口,Set 接口继承 Collection 接口,而且它不允许集合中存在重复项,每个具体的 Set 实现类依赖添加的对象的 equals()方法来检查独一性。Set接口没有引入新方法,所以Set就是一个Collection,只不过其行为不同。,接口,SortedSet类的主要方法 Comparator compar
14、ator()Object first()Object last()SortedSet subSet(Object beginElement,Object endElement)SortedSet headSet(Object endElement)SortedSet tailSet(Object beginElement),接口,HashSet类的主要方法 HashSet()HashSet(Collection c)HashSet(int initCapacity)HashSet(int initCapacity,float loadFactor),接口,TreeSet类的主要方法 TreeS
15、et()TreeSet(Collection c)TreeSet(Comparator c)TreeSet(SortedSet s),接口,LinkedHashSet类的主要方法 LinkedHashSet()LinkedHashSet(Collection c)LinkedHashSet(int initCapacity)LinkedHashSet(int initCapacity,float loadFactor),接口,Map接口的主要方法 Object put(Object key,Object value)Object remove(Object key)void putAll(Ma
16、p t)void clear()Object get(Object key)boolean containsKey(Object key)boolean containsValue(Object value)int size()boolean isEmpty()Set keySet()Collection values(),集合类对equals()和hashCode()方法的要求,为了保证Java集合正常工作,有些Java集合类HashSet、TreeSet、HashMap、TreeMap对存放的对象有特殊的要求。另外,要了解重写hashCode()的重要性。,6.8总结,本章主要介绍了一维数
17、组、二维数组以及字符串的处理,其中对一维数组和二维数组主要介绍了它们如何声明,如何初始化以及如何引用。另外我们对字符串处理的介绍,主要包括字符串的生成,访问,修改和其他相关操作。最后我们介绍了数组与容器类比较,然后着重介绍的就是容器类的内容,同时,对Java集合类中非常重要的两个方法:equals()和hashCode()方法进行了说明。,练习(1),1.定义一个长度为10的整数数组,然后将1120分别赋给数组元素,计算该数组中下标为偶数的元素的和。2.写一个方法,完成替换字符串中的子串的功能。3.写一个程序,用来计算单词在一个文本文件中的重复出现的次数。4.Java数组的特点是什么?如何创建
18、和使用对象数组。5.编写一个程序,使用二维数组来求解线性方程组。,练习(2),6.阅读下面的程序,看看是否存在问题,若存在问题,在不改变程序结构的基础上修改存在的错误,使其能够编译运行。/第6章习题6,Example6_6.java class Example6_6 public static void main(String args)aArray=“I like Java!”,”Java is a language”.”We should learn it well!”;for(i=0;i=aArray.length;i+)System.out.prinln(aArrayi);System
19、.out.prinln(aArrayi.toLowerCase();System.out.prinln(aArrayi.toUpperCase();,练习(3),7.用键盘输入一个字符串,编写程序统计此字符串中字母、空格和数字的个数。8.编写程序,完成打印输出杨辉三角,要求格式如下:1 1 2 1 1 3 3 1 1 4 6 4 1 1 5 10 10 5 1 1 6 15 20 15 6 11 7 21 35 35 21 7,练习(4),9.编写程序,利用LinkedList来实现堆栈的操作。10.编写程序,利用LinkedList来实现队列的操作。,练习(5),11.使用Interator类,把学习成绩存放在一个键表中,并用两种方法实现遍历链表,同时比较遍历速度(即用Iteratorlei和不使用这个类)。12.使用堆栈结构输出的若干项,其中=2+2,且=2,=6。,下课!,
链接地址:https://www.31ppt.com/p-6297464.html