ImageVerifierCode 换一换
格式:PPT , 页数:59 ,大小:522KB ,
资源ID:12707692      下载积分:14 金币
快捷注册下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/12707692.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请

   平台协调中心        【在线客服】        免费申请共赢上传

权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:0574-28810668;投诉电话:18658249818。

注意事项

本文(Java编程思想第四版第五章初始化与清理.ppt)为本站上传会员【精****】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

Java编程思想第四版第五章初始化与清理.ppt

1、第五章 初始化与清理,初始化,清理,数组的初始化和枚举类型,一、用构造器确保初始化,1,、为什么要引入,构造器(,constructor,),?,假设没有构造器,那么我们用户就要,自己去完成,初始化工作,但用户可能不知道如何初始化,甚至,会忘记初始化,一、用构造器确保初始化,2,、构造器如何取名?,C+,语言采用的解决方案看来最简单,而且最符合逻辑,所以在,Java,中也是,采用了这种方案,构造器采用与类相同的名称,一、用构造器确保初始化,3,、构造器的种类,无参的构造器(习惯称为,默认构造器,),带参的构造器,一、用构造器确保初始化,4,、构造器的特点,构造器是一种特殊类型的方法,因为,它

2、没有返回值,分析:与返回值为,void,(空)的区别,,后者仍有可能以其它形式返回某些值,二、方法重载,1,、,方法重载,的概念,方法名相同,而,参数类型列表,不同,也就是依靠,参数的个数、类型和顺序,的不同加以区分(后者不推荐使用),三、默认构造器,如果你写的类没有构造器,那么编译器,会,自动帮你创建一个默认构造器,(无参,构造器),如果已经定义了一个构造器(无论是否,有参数),编译器就不会帮你自动创建,默认构造器,典例,1,:,P83,代码,class Bird,public class DefaultConstructor,public static void main,(,String

3、 args,),Bird b=,new Bird,(),/Default!,表达式,new Bird,()将调用默认构造器,即使你,并没有明确定义它,典例,2,:,P83,代码,Bird class Bird2,Bird2,(,int i,),Bird2,(,double d,),public class NoSynthesis,public static void main,(,String args,),/!Bird2 b=,new Bird2,();,/,为什么出错?,Bird2 b2=new Bird2,(,1,);,Bird2 b3=new Bird2,(,1.0,);,四、,thi

4、s,关键字,1,、,this,关键字的含义,概念:,指向对象本身的引用,问题:为什么需要,this,关键字?,class Banana,void peel,(,int i,),/*.*/,public class BananaPeel,public static void main,(,String args,),Banana a=new Banana,();,Banana b=new Banana,(),;,a.peel,(,1,),;,b.peel,(,2,),;,仔细分析以上代码在内存中执行的情况,首先,我们知道:编译器只为每个对象的,数据,成员,分配存储空间,而不为,成员函数,分配空间

5、成员函数将随着整个类的装载而装载,为什么?所有对象的成员函数都是一样的,,所以没必要为成员函数分配空间,于是产生了一个有意思的问题:,成员函数是怎么知道它究竟被哪个对象调用的?,答案是:通过,this,关键字(,编译器自动完成,),编译器将,a.peel,(,1,)理解为,Banana.peel,(,a,,,1,),/,即将当前所操作对象的引用作为,第一个参数,传递,给,peel,(),四、,this,关键字,2,、,我们如何使用,this,关键字?,返回当前对象的引用,典例分析,P84,代码,public class Leaf,int i=0,;,Leaf,Increment,(),i+

6、return this,;,void print,System.out.println,(“,i=”+i,);,public static void main,(,String args,),Leaf x=new Leaf,();,x.increment,(),.increment,(),.increment,(),.print,(),;,四、,this,关键字,在构造器中调用构造器,为避免重复代码,往往使用,this,关键字,分析,P86,代码,public class Flower,int petalCount=0,;,String s=“initial value”,;,Flowe

7、r,(,int petalCount,),/*.*/,Flower,(,String ss,),/*.*/,Flower,(,int petalCount,,,String s,),this,(,petalCount,),;,this.s=s,;,/Another use of this,.,五、清理:终结处理和垃圾回收,1,、,C+,的,析构函数(,destructor,),什么时候调用析构函数?,当对象脱离其作用域时,(如对象所在的,函数已调用完毕),系统自动调用析构,函数,五、清理:终结处理和垃圾回收,析构函数的作用是什么?,析构函数往往用来做,清理善后,的工作,例如:在建立对象时用,n

8、ew,开辟了一片,内存空间,应在退出前在析构函数中用,delete,释放,五、清理:终结处理和垃圾回收,是否每一个类都具有析构函数?,如果用户没有编写析构函数,编译系统,会,自动生成一个缺省的析构函数,,而它,也不进行任何操作,五、清理:终结处理和垃圾回收,2,、,垃圾回收器,的作用,Java,没有析构函数,垃圾回收器,只知道,释放那些,经由,new,关键字分配的内存,问题,1,:是否存在,不经,new,分配的内存,?,如果不存在:上面一段话应该改为,垃圾回收器,能够回收一切不再需要的内存,如果存在:但,在,Java,中,一切都是对象,而对象,必须经由,new,关键字来分配内存,答案:确实存在

9、着不经,new,分配的内存(利用,本地方法,调用非,Java,代码,如,C,的,malloc,函数),问题,2,:垃圾回收器是否知道如何释放这块,特殊,的内存,?,答案很显然:不知道,那么这块特殊的内存如何释放呢?,Java,允许在,类中定义一个,finalize,()方法,,可以通过调用,该方法来实现,问题,3,:垃圾回收器是否等同于析构函数?,不等同(范围不等同),在,C+,中,,每一个对象,一定会通过析构函数而,销毁,而垃圾回收器,只知道,回收经由,new,分配的内存,,而其它的对象(不经,new,分配的)不能被垃圾,回收器回收,五、清理:终结处理和垃圾回收,3,、,垃圾回收器是如何工作

10、的?,在堆上分配对象的代价十分高昂,但由于垃圾回收器的存在,,Java,从堆,分配空间的速度,可以和其它语言从,堆栈分配空间的速度相媲美(了解),六、成员初始化,1,、,Java,编译器将尽力保证:,所有变量,在,使用前都要进行恰当的初始化,Java,的变量有两种:,引用变量,和,基本,类型变量,,后者又分为下面两种情况,六、成员初始化,非数据成员(方法中局部变量),Java,以,编译时错误,的形式来保证其,初始化,典例分析:,void f,(),int i,;,i+,;,/Error,,,i not initialized ,强制程序员提供一个初始值,编译器可以为,i,赋一个默认值,但是未初

11、始化的,局部变量更有可能是程序员的疏忽,所以采用,默认值反而会掩盖这种失误,六、成员初始化,数据成员为基本类型,Java,将为,类的每个基本数据成员提供,自动初始化,(保证都会有一个初始值),典例分析:,P92,代码(自己调试),六、成员初始化,引用类型,无论是否数据成员,如果不将其初始化,,该,对象引用会被,Java,自动赋值为,null,六、成员初始化,2,、,指定初始化,Java,允许:,在定义类的数据成员的同时,可以为其赋初值,优点:简单直观,缺点:每个对象都具有相同的初值,典例:,P93,代码,void,public,class,InitialValues2,int,i,;,/,自动

12、初始化,int,j,=999,;,/,先自动初始化,再指定初始化,注意:,C+,不允许这样做,必须全部通过构造,函数来初始化,七、构造器初始化,1,、,初始化的第一基本原则,可以用构造器来进行初始化,但执行顺序是:,先自动初始化,再指定,初始化,最后调用构造器进行初始化,public class Counter,int i=99,;,Counter,(),i=7,;,/.,执行顺序,:,i,首先被自动初始化为,0,,然后指定,初始化为,99,,最后利用构造器初始化为,7,大家肯定会问一个问题:既然这些数据成员的,初始化已经得到保证,那还要构造器做什么?,首先:自动初始化只是保证这些,Java,

13、类的稳定性,它的值并不是实际情况所需要的值,其次:,构造器存在着并没有为某个数据成员进行,初始化的危险,,那么如果没有自动初始化,我们,该怎么办?,七、构造器初始化,2,、,变量的初始化顺序,变量定义的先后顺序决定其初始化顺序,不管这些变量的定义位于什么地方,,它们一定会在,任何方法,(包括构造器),被调用之前得到初始化,七、构造器初始化,3,、,静态数据的初始化,还有一个棘手的问题没有解决:,我们从前面知道:类的数据成员将会先后进行,自动初始化和指定初始化,问题是:类的数据成员又分为,静态数据成员,和,非静态数据成员,,那么在所谓的自动初始化和,指定初始化过程中,是先做静态成员的初始化,还是

14、先做非静态成员的初始化?,七、构造器初始化,初始化的第二基本原则,初始化的顺序是,先静态对象,,而,后是非,静态对象,典例分析:,P95,分析:,1,、,public,所修饰的类是,主类,,里面包含的,main,方法,称为,主方法,,是,程序的入口点,所谓程序的入口点是指:程序将从这个地方开始,执行,而这将会导致主类的加载,分析:,2,、前面提到:不管变量的定义位于什么地方,它们,一定会在任何方法(包括构造器)被调用之前得,到初始化,所以:,table,和,cupboard,两个静态变量将首先被,初始化,而在利用构造器初始化的过程中,将导,致,Table,类和,Cupboard,类的先后加载,

15、分析:,3,、重要结论,:(后面章节还要仔细分析),类在必要的时候才会被加载,这样一来,我们很容易知道:该类的静态初始化,也只有在必要的时候才会进行,分析:,4,、推论:,初始化第二基本原则的重要补充,静态对象的初始化,发生在,类的加载时期,非静态对象的初始化,发生在,创建对象时期,八、数组初始化,1,、,有关数组的基本知识,数组的概念,数组只是相同类型的,且用一个标识符,封装到一起的一个,对象序列,或,基本类型,数据序列,八、数组初始化,数组的声明(,P99,),如:,int a,;或者,int a,;,仅仅声明了对,数组的一个引用,,而且,也没有给数组对象本身分配任何空间,八、数组初始化,

16、数组的定义,包括给数组创建相应的存储空间,,以及对数组的初始化,八、数组初始化,数组的固定成员,length,同,C/C+,一样,,Java,数组计数也是从,0,开始,到,length-1,结束,一旦越界,则系统自动抛出异常,八、数组初始化,数组的大小(与,C/C+,很大不同),数组的大小可以在运行时刻才决定,,P100,的,ArrayNew.java,可证明这点,但是不推荐这种使用方式,八、数组初始化,数组元素的类型可以是对象引用,,这种数组称为,引用数组,注意对引用数组进行初始化,否则在,程序中所使用的是空引用(,null,),八、数组初始化,2,、,可变参数列表,应用于参数个数或类型未知

17、的场合,典例分析,P102,public class NewVarArgs,/,可变参数列表的语法,static void printArray,(,Object.args,),/Foreach,语法,for,(,Object obj:agrs,),System.out.println,(,obj+“”,);,System.out.println,();,public static void main,(,String args,),printArray,(,new Integer,(,47,),,new Float,(,3.14,),,new Double,(,11.11,);,printArray,(,47,,,3.14F,,,11.11,);,printArray,(“,one”,,“,two”,,“,three”,);,printArray,(,new A,(),,new B,(),,new C,();,.,习题,P77,:习题,1,P86,:习题,9,P101,:习题,16,

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服