教学课件第4章数组与字符串

上传人:工**** 文档编号:569436033 上传时间:2024-07-29 格式:PPT 页数:81 大小:444.97KB
返回 下载 相关 举报
教学课件第4章数组与字符串_第1页
第1页 / 共81页
教学课件第4章数组与字符串_第2页
第2页 / 共81页
教学课件第4章数组与字符串_第3页
第3页 / 共81页
教学课件第4章数组与字符串_第4页
第4页 / 共81页
教学课件第4章数组与字符串_第5页
第5页 / 共81页
点击查看更多>>
资源描述

《教学课件第4章数组与字符串》由会员分享,可在线阅读,更多相关《教学课件第4章数组与字符串(81页珍藏版)》请在金锄头文库上搜索。

1、电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社第4章 数组与字符串学习目标 本章要点上机练习 习 题电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社学习目标 数组与字符串是Java语言中非常重要且功能强大的对象,其作用渗透到程序设计的各个方面,是读者继续深入学习必不可少的基本知识。本章主要介绍了数组的概念,以及数组函数和向量类,讲解了数组和向量类的使用,还介绍了字符串String类和StringBuffer类,通过示例详细讲解了字符串的常用方法。让读者熟练掌握数组和字符串的特点与使用方法。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社本章要点 一维数组和

2、多维数组的概念数组的声明、创建和初始化数组函数的使用String类和StringBuffer类字符串字符串的常用方法电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社数 组数组作为一种符合数据类型广泛应用于数据运算和图形程序设计中。一维数组与多维数组 数组函数的使用 向量类 应用举例数组与向量类的使用 电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社一维数组与多维数组数组有一维和多维两种形式,下面将详细介绍两种数组的使用方法。一维数组的声明 一维数组的创建 数组的初始化 多维数组 电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社一维数组的声明数组是具有相同类型

3、的元素按照顺序组成的一种复合数据类型。通过一个整数下标,可以访问其中的每一个值,下标从0开始排序,如果一个数组的长度为4,那么各元素序号为0、1、2和3。但是在Java中定义数组时候,不允许直接指定数组的大小。 电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社一维数组的声明根据这个定义,可以得出数组的特点:数组的所有元素是同一类型,各个元素是有顺序的,每个元素通过数组名和数组下标来表示。一维数组的声明格式为:Type arrayName ; 或者 type arrayName; 电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社一维数组的声明其中,type为该数组的数据类

4、型,可以声明任何类型的数组简单类型或类类型。ArrayName为数组名。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社一维数组的声明上述这种将方括号置于变量名之后可以声明数组的格式,是用于C、C+和Java编程语言的标准格式。有些观点认为这种格式会使声明的格式复杂难懂,因而,Java编程语言允许一种替代的格式,该格式中的方括号位于变量名的左边。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社一维数组的声明这样的结果可以认为类型部分在左,而变量名在右,上述两种格式并存,可以选择任何一种作为习惯的方式。当数组声明的方括号在左边时,该方括号可应用于所有位于其右的变量。电脑基

5、础实例上机系列丛书Java程序设计教程 清华大学出版社一维数组的创建 Java中所有数据类型都在定义时自动为其分配内存空间,但数组必须在声明后再经过创建数组这一步骤才能使用。创建数组是指在声明数组之后为数组分配内存空间,同时对数组元素进行初始化。创建数组有两种方式:电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社一维数组的创建1)使用关键字new创建数组使用关键字new来为一个已经声明的数组分配实际的内存空间。其格式如下:arrayName = new typearraySize ;这里,arraySize是指明数组的实际长度。电脑基础实例上机系列丛书Java程序设计教程 清华大学

6、出版社一维数组的创建char array1 = new char 20;这条语句相当于以下两条语句char array1;array1= new char 20;而对于类类型数组的创建要多理解电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社一维数组的创建2)直接指定初始值的方式创建数组除使用关键字new创建数组以外,还可以以赋值的形式创建数组。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社一维数组的创建其格式如下:int I=1,2,3,4,5;这条语句定义了一个包含5个元素的整型数组,同时又指定了元素的初始值,并为其创建了5个元素的存储区。电脑基础实例上机系列丛书J

7、ava程序设计教程 清华大学出版社一维数组的创建【例4-1】 一维数组的声明和创建(光盘:源文件第4章例4-1.txt)。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社数组的初始化 数组初始化是保证系统安全的基础,变量绝不能在未初始化的状态下使用。当创建一个数组时,即为数组分配了内存空间,每个元素都被初始化,数值类型的数组元素被自动初始化为0,布尔类型的数组元素被自动初始化为false,引用类型的数组元素被自动初始化为null。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社数组的初始化对数组的初始化也可以在定义数组的同时进行。另一方面,数组元素的范围也是非常重要的,

8、用来指示单个数组元素的下标必须总是从0开始,且保持在合法范围之内大于或等于0,且小于数组长度。任何访问在上述界限之外的数组元素的行为都会引起运行时出错。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社数组的初始化【例4-2】 用冒泡排序法将数组中的元素按从小到大的顺序排列(光盘:源文件第4章例4-2.txt)。冒泡排序法将数组中两个相邻的元素进行比较,并总是将小的元素交换到前面。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社例4-2运行结果电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社多维数组 Java并不直接支持多维数组,所以多维数组的声明是通过对一维

9、数组的嵌套来完成的,即使用“数组的数组”的方式来声明多维数组。这里我们首先来看二维数组。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社多维数组1)二维数组一个二维数组的声明格式为:type arrayName ;其中,type可以是最低一维数组的类型,arrayName是数组名,最右边的方括号代表最低一维。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社多维数组与一维数组一样,多维数组对数组元素没有分配任何的空间,在声明后,必须使用关键字new来为其分配内存空间,然后才能访问里面的元素。多维数组有以下方法来分配空间。电脑基础实例上机系列丛书Java程序设计教程 清华大

10、学出版社多维数组直接分配每一维的空间。必须从最高维开始,由高到低,分别为每一维分配内存空间。2)多维数组Java采用“数组的数组”声明多维数组,使处理多维数组更灵活。多维数组可以不是矩形电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社多维数组显然,这种多维数组是“不整齐”的,所以在声明和创建多维数组时候,不一定要指定每一维的元素个数。上述数组yanghui的高维各元素由于包含不同个数的低维元素,所以右边的方括号中实际无法确定某个数值。 电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社多维数组因此,在多维数组的声明和创建时候,数组最前面的一维或多维必须指定元素的个数,后面

11、的方括号中可以不指定元素个数。以下写法是允许的:int arrayDim=new int3电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社多维数组但以下语句是错误的:int arrayDim =new int3int arrayDim =new int2int arrayDim =new int电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社多维数组【例4-3】 二维数组的使用矩阵相乘(光盘:源文件第4章例4-3.txt)。矩阵A(m,n)和B(n,1)相乘得到矩阵C(m,1),矩阵C的每个元素为Cij=aik*bkj(i=1,2,.,m,j=1,2.,n)电脑基础实例

12、上机系列丛书Java程序设计教程 清华大学出版社例4-3运行结果电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社数组函数的使用 在系统中很多关于数组的函数可以直接调用,下面将介绍几种常用的数组函数。数组复制System.arraycopy()数组排序Arrays.sort() 电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社数组复制System.arraycopy()Java语言在System类中提供了一种特殊的方法复制数组,该方法被称作arraycopy()。数组复制的基本格式为:public static void arraycopy(Object src, int

13、 srcPos, Object dest, int destPos, int length) 电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社数组复制System.arraycopy()【例4-4】 数组的复制,将数组a1的前4个元素赋给数组b1(光盘:源文件第4章例4-4.txt)。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社数组排序Arrays.sort() ArraysSort()将数组中的元素按从小到大的顺序排列,结果仍然放在源数组中。【例4-5】 将数组a1按升序排列,并显示排序结果(光盘:源文件第4章例4-5.txt)。电脑基础实例上机系列丛书Java程

14、序设计教程 清华大学出版社类“test4_5”运行结果电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社向量类 向量类Vector是Java.util包提供的一个工具类,它是允许不同类型元素共存的变长数组,具有比数组更强大的功能。每个向量类的对象都可以表达一个完整的数据系列,同时,向量类还封装了许多有用的方法来操作和处理这些数据。向量类对象所表达的序列元素的个数是可变的,可以使用向量类实现变长数组。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社向量类向量类可为工作的各种元素类型的动态数组提供方法,如类继承关系。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社

15、向量类向量类的构造函数 向量类的变量 向量类的基本方法 电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社向量类的构造函数向量类有如下3种构造函数。public Vector():构造一个空向量。public Vector(int initialCapacity):构造一个具有存储容量的空向量。public Vector(int initialCapacity,int capacityInctrment):构造具有存储容量和增加量的空向量。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社向量类的变量向量类包含如下3种变量。protected int capacityInc

16、rement:增加量,如为0,则每次需要增加时,缓冲区的大小成倍。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社向量类的变量protected int elementCount:缓冲区中元素的数量。rotected Object elementData:元素被贮存的缓冲区。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社向量类的基本方法 下面是向量类中的一些方法,可以参照Java API查看该方法的描述。public final int size():返回向量中元素的数量。public final boolean contains(Object elem):如果指定对

17、象是收集的值,返回真。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社向量类的基本方法public final int indexOf (Object elem):从起始位置搜索指定的对象,然后将一个索引返回到其中(或,如果元素未找到为-1)。public finalsynchronized Object elementAt (int index):在指定的索引中返回元素。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社向量类的基本方法public final synchronized void setElementAt (int index):在指定索引中以指定对象替

18、代指定元素。public final synchronized void removeElementAt (int index):删除指定索引中的元素。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社向量类的基本方法public final synchronized void addElement (Object obj):附加指定对象作为向量的最后元素。public final synchronized void insertElementAt (Object obj,int index):插入指定对象作为指定索引中的一个元素,上移具有同等或更大索引的所有元素。电脑基础实例上机系

19、列丛书Java程序设计教程 清华大学出版社应用举例数组与向量类的使用 【例4-6】 Vector类的使用(光盘:源文件第4章应用举例MyVector.txt)。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社字 符 串 Java语言将字符串作为对象来处理,字符串及相关操作都被封装在Java.lang包中的String类和StringBuffer类之中。String类 StringBuffer类 字符串的常用方法 应用举例字符串操作的综合应用 电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社String类 String类用于比较两个字符串、查找串中的字符及子串、字符串与其

20、他类型的转换,String类对象的内容初始化后不能改变。String类构造函数 字符串的创建 电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社String类构造函数String类有许多构造函数,下面将介绍主要的5个。public String(String value):生成一个空串。public String(char value):生成一个字符数组。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社String类构造函数public String(char value, int startIndex, int numChars):生成一个字符串,这个字符串从字符数组v

21、alue中提取,即从value数组的startIndex位置开始提取字符,共提取numChars个字符组成一个字符串。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社String类构造函数public String(byte ascii,int hiByte):以字节数组形式生成一个字符串,数组中存放字符串中各字符对应的ASCII码。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社String类构造函数public String(byte ascii, int hiByte, int startIndex, int numChars):以字节数组形式生成一个字符串,这个

22、字符串从字节数组ascii的startIndex位置开始提取字符,共提取numChars个字符组成一个字符串。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社字符串的创建 String类不能派生子类,也就是说String类不能被其他类继承,另外,即使程序中不使用new关键字,Java编译器也能从String类生成一个对象。String s=”Hello world!”;电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社字符串的创建该语句中没有使用new关键字,但是仍然生成了一个字符串对象s。这也是String类的特点。在Java语言中,可以隐式或显式地创建字符串对象。电脑

23、基础实例上机系列丛书Java程序设计教程 清华大学出版社字符串的创建1)隐式地创建字符串对象对于隐式地创建字符串对象,可以使用双引号来设置一个String语句,Java将自动创建字符串对象。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社字符串的创建2)显式地创建字符串对象3)使用已创建的字符串创建另一个字符串4)由字符数组创建一个字符串对象5)提取字符数组的部分字符创建一个字符串对象电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社StringBuffer类 StringBuffer类用于内容可以改变的字符串,可将其他类型的数据增加、插入到字符串中,也可翻转字符串的内容

24、。通过类StringBuffer的构造方法可生成可变的字符串对象。格式如下:电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社StringBuffer类Sing strObj = new StringBuffer();String strObj = new StringBuffer(int num);String strObj = new StringBuffer(String str);参数num为字符串缓冲区的初始长度,参数str给出字符串的初始值。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社字符串的常用方法 下面分别对字符串的常用方法进行介绍。Length方法

25、Equals方法 equalslgnorCase方法 toUpperCase和toLowerCase方法 电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社字符串的常用方法Replace方法Contact方法 compareTo和compareTolgnoreCase方法 Substring方法 public int indexOf方法 电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社Length方法使用String类中的length()方法可以获取一个字符串的长度。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社Equals方法字符串对象调用String类中

26、的public Boolean equals(String s)方法,比较当前字符串对象的实体是否与参数指定的字符串s的实体相同。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社equalslgnorCase方法比较当前字符串对象与参数指定的字符串是否相同,比较时可以忽略大小写。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社toUpperCase和toLowerCase方法 将字符串中的字母全部转化为大写、小写字母。toUpperCase()可将参数中的字母全部转化为大写,toLowerCase()可将参数中的字母全部转化为小写。电脑基础实例上机系列丛书Java程序设

27、计教程 清华大学出版社Replace方法 Replace可将给定字符串中出现的所有特定字符oldChar替换成指定字符newChar,形成新的字符串。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社Contact方法 contact(String otherStr)可将当前字符串和给定字符串otherStr字符串连接起来,形成新的字符串。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社compareTo和compareTolgnoreCase方法 字符串对象可以使用String类中的public compareTo(String s)方法按字典顺序与参数s指定的字符串比

28、较大小。如果当前字符串与s相同,该方法返回0;如果当前字符串对象大于s,该方法返回正值;如果小于s,该方法返回负值。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社compareTo和compareTolgnoreCase方法按字典顺序比较两个字符串还可以使用public compareTolgnoreCase(String s)方法,该方法可以忽略大小写。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社Substring方法 substring(int beginIndex)可从开始位置beginIndex开始一直取值到最后一个字符,形成新的字符串。subString

29、(int beginIndex, int endIndex)从开始位置beginIndex开始一直取到结束位置endIndex的字符,形成新的字符串。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社public int indexOf方法 要搜索指定字符串出现的位置,通常有以下几种方法。public int indexOf(String s):字符串调用该方法从当前字符串的头开始检索字符串s,并返回首次出现s的位置。如果没有检索到字符串s,该方法返回值为-1。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社public int indexOf方法public int i

30、ndexOf(String s,int starpoint):字符串调用该方法从当前字符串的starpoint处开始检索字符串s,并返回首次出现s的位置。如果没有检索到字符串s,该方法返回值为-1。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社public int indexOf方法public int lastIndexOf(String s):字符串调用该方法从当前字符串的头开始检索字符串s,并返回最后出现s的位置。如果没有检索到字符串s,该方法返回值为-1。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社public int indexOf方法public in

31、t lastIndexOf(String s,int starpoint):字符串调用该方法从当前字符串的starpoint处开始检索字符串s,并返回最后出现s的位置。如果没有检索到字符串s,该方法返回值为-1。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社应用举例字符串操作的综合应用 本节应用实例将通过两个小实例来巩固字符串的综合应用方法。compareTo的使用 toUpperCase和toLowerCase的使用 电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社compareTo的使用下面练习字符串方法compareTo的使用(光盘:源文件第4章应用举例comp

32、areTo1.txt)。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社toUpperCase和toLowerCase的使用 下面将练习字符串方法toUpperCase、toLowerCase的使用,(光盘:源文件第4章应用举例charactor1.txt)。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社上 机 练 习 本节上机练习将通过数组的定义和使用,创建向量类两个练习,巩固本章所学的知识点。数组的定义和使用 创建向量类 电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社数组的定义和使用 本次练习熟悉数组的定义和使用,将12个二进制数放入数组中,并通过数

33、组对它们进行位运算的操作,并将结果逐行显示出来(光盘:源文件第4章上机练习1.txt)。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社类“Test_shuzu”运行结果电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社创建向量类 本次练习将通过创建一个向量类的实例展示了数组与向量类的使用(光盘:源文件第4章上机练习2.txt)。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社习 题 (1)自行设计一个向量的例子,并编程实现它。(2)编程计算从5到10的平方值,并将结果存入一个数组中。(3)设定一个含有大小写字母的字符串,先将所有的大写字母输出,再将所有小写字母输出。电脑基础实例上机系列丛书Java程序设计教程 清华大学出版社习 题(4)设置m=“HelloJava”,请写出下列方法的值。m.length( )m.contact(“mickle”)m.substring(2,5);m.replace(J,a);(5)设定10个字符串,打印出以字母“b”开头的字符串。

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > 工作计划

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号