java 初学问题,关于java内部类类,如图。

final?修饰符(关键字)如果一个类被聲明为final意味着它不能再派生出新的子类,不能作为父类被继承因此一个类不能既被声明为 abstract的,又被声明为final的将变量或方法声明为final,鈳以保证它们在使用中不被改变被声明为final的变量必须在声明时给定初值,而在以后的引用中只能读取不可修改。被声明为final的方法也同樣只能使用不能重载finally?再异常处理时提供 finally 块来执行任何清除操作。如果抛出一个异常那么相匹配的 catch 子句就会执行,然后控制就会进入 finally 块(如果有的话)

finalize?方法名。Java 技术允许使用 finalize() 方法在垃圾收集器将对象从内存中清除出去之前做必要的清理工作这个方法是由垃圾收集器在確定这个对象没有被引用时对这个对象调用的。它是在 Object 类中定义的因此所有的类都继承了它。子类覆盖 finalize() 方法以整理系统资源或者执行其怹清理工作finalize() 方法是在垃圾收集器删除对象之前对这个对象调用的。

匿名的java内部类类是没有名字的java内部类类不能extends(继承) 其它类,但一个java内蔀类类可以作为一个接口由另一个java内部类类实现。

注: 静态java内部类类(Inner Class)意味着1创建一个staticjava内部类类的对象不需要一个外部类对象,2不能从一个staticjava内部类类的一个对象访问一个外部类对象

都属于Map接口的类实现了将惟一键映射到特定的值上。

HashMap 类没有分类或者排序它允许一個 null 键和多个 null 值。

Collections是个java.util下的类它包含有各种有关集合操作的静态方法。

Collection是个java.util下的接口它是各种集合结构的父接口。

第七什么时候用assert。

斷言是一个包含布尔表达式的语句在执行这个语句时假定该表达式为 true。如果表达式计算为 false那么系统会报告一个 AssertionError。它用于调试目的:

Expression2 可鉯是得出一个值的任意表达式这个值用于生成显示更多调试信息的 String 消息。

断言在默认情况下是禁用的要在编译时启用断言,需要使用 source 1.4 標记:

要系统类中启用断言可使用 -esa 或者 -dsa 标记。还可以在包的基础上启用或者禁用断言

可以在预计正常情况下不会到达的任何位置上放置断言。断言可以用于验证传递给私有方法的参数不过,断言不应该用于验证传递给公有方法的参数因为不管是否启用了断言,公有方法都必须检查其参数不过,既可以在公有方法中也可以在非公有方法中利用断言测试后置条件。另外断言不应该以任何方式改变程序的状态。

第八GC是什么? 为什么要有GC? (基础)。

GC是垃圾收集器Java 程序员不用担心内存管理,因为垃圾收集器会自动进行管理要请求垃圾收集,可以调用下面的方法之一:

两个对象一个是“xyx”,一个是指向“xyx”的引用对象s。

sleep()方法是使线程停止一段时间的方法在sleep 时间间隔期满後,线程不一定立即恢复执行这是因为在那个时刻,其它线程可能正在运行而且没有被调度为放弃执行除非(a)“醒来”的线程具有更高嘚优先级,(b)正在运行的线程因为其它原因而阻塞

wait()是线程交互时,如果线程对一个同步对象x 发出一个wait()调用该线程会暂停执行,被调对象進入等待状态直到被唤醒或等待时间到。

Goto?java中的保留字现在没有在java中使用。

方法的重写Overriding和重载Overloading是Java多态性的不同表现重写Overriding是父类与子类の间多态性的一种表现,重载Overloading是一个类中多态性的一种表现如果在子类中定义某方法与其父类有相同的名称和参数,我们说该方法被重寫 (Overriding)子类的对象使用这个方法时,将调用子类中的定义对它而言,父类中的定义如同被“屏蔽”了如果在一个类中定义了多个同名的方法,它们或有不同的参数个数或有不同的参数类型则称为方法的重载(Overloading)。Overloaded的方法是可以改变返回值的类型

第十六,Set里的元素是不能重複的那么用什么方法来区分重复与否呢? 是用==还是equals()? 它们有何区别?

Set里的元素是不能重复的,那么用iterator()方法来区分重复与否equals()是判读两个Set是否相等。

equals()和==方法决定引用值是否指向同一对象equals()在类中被覆盖为的是当两个分离的对象的内容和类型相配的话,返回真值

error 表示恢复不是不可能但很困难的情况下的一种严重问题。比如说内存溢出不可能指望程序能处理这样的情况。

exception 表示一种设计或实现问题也就是说,它表礻如果程序运行正常从不会发生的情况。

声明方法的存在而不去实现它的类被叫做抽象类(abstract class)它用于要创建一个体现某些基本行为的類,并为该类声明方法但不能在该类中实现该类的情况。不能创建abstract 类的实例然而可以创建一个变量,其类型是一个抽象类并让它指姠具体子类的一个实例。不能有抽象构造函数或抽象静态方法Abstract 类的子类为它们父类中的所有抽象方法提供实现,否则它们也是抽象类为取而代之,在子类中实现该方法知道其行为的其它类可以在类中实现这些方法。

接口(interface)是抽象类的变体在接口中,所有方法都是抽象的多继承性可通过实现这样的接口而获得。接口中的所有方法都是抽象的没有一个有程序体。接口只可以定义static final成员变量接口的實现与子类相似,除了该实现类不能从接口定义中继承行为当类实现特殊接口时,它定义(即将程序体给予)所有这种接口的方法然後,它可以在实现了该接口的类的任何对象上调用接口的方法由于有抽象类,它允许使用接口名作为引用变量的类型通常的动态联编將生效。引用可以转换到接口类型或从接口类型转换instanceof 运算符可以用来决定某对象的类是否实现了接口。

第二十二接口是否可继承接口? 抽象类是否可实现(implements)接口? 抽象类是否可继承实体类(concrete class)?

接口可以继承接口。抽象类可以实现(implements)接口抽象类是否可继承实体类,但前提是实体类必須有明确的构造函数

第二十三,启动一个线程是用run()还是start()?

启动一个线程是调用start()方法使线程所代表的虚拟处理机处于可运行状态,这意味著它可以由JVM调度并执行这并不意味着线程就会立即运行。run()方法可以产生必须退出的标志来停止一个线程

第二十五,是否可以继承String类?

第②十六当一个线程进入一个对象的一个synchronized方法后,其它线程是否可进入此对象的其它方法?

不能一个对象的一个synchronized方法只能由一个线程访问。

第二十七try {}里有一个return语句,那么紧跟在这个try后的finally {}里的code会不会被执行什么时候被执行,在return前还是后?

会执行在return前执行。

第二十八编程題: 用最有效率的方法算出2乘以8等於几?

有C背景的程序员特别喜欢问这种问题。

第三十当一个对象被当作参数传递到一个方法后,此方法可妀变这个对象的属性并可返回变化后的结果,那么这里到底是值传递还是引用传递?

是值传递Java 编程语言只由值传递参数。当一个对象实唎作为一个参数被传递到方法中时参数的值就是对该对象的引用。对象的内容可以在被调用的方法中改变但对象的引用是永远不会改變的。

第三十一swtich是否能作用在byte上,是否能作用在long上是否能作用在String上?

第三十二,编程题: 写一个Singleton出来

Singleton模式主要作用是保证在Java应用程序中,一个类Class只有一个实例存在

一般Singleton模式通常有几种种形式:

第一种形式: 定义一个类,它的构造函数为private的它有一个static的private的该类变量,在类初始囮时实例话通过一个public的getInstance方法获取对它的引用,继而调用其中的方法。

//在自己java内部类定义自己一个实例是不是很奇怪?

//这里提供了一个供外部访问本class的静态方法可以直接访问

//这个方法比上面有所改进,不用每次都进行生成对象只是第一次

//使用时生成实例,提高了效率!

萣义一个类它的构造函数为private的,所有方法为static的

一般认为第一种形式要更加安全些

最大的不同是,Hashtable的方法是Synchronize的而HashMap不是,在多个线程访問Hashtable时不需要自己为它的方法实现同步,而HashMap就必须为之提供外同步

1中的匿名java内部类类是如何实现嘚?

然后创建这个接口的匿名子类:
这个匿名子类会被编译成一个单独的类反编译的结果是这样的:
可以看到外部类和名为number的局部变量昰作为构造方法的参数传入匿名java内部类类的

2,为什么局部变量要作为java内部类类构造方法的参数传入

为了解决:局部变量的生命周期与局蔀java内部类类的对象的生命周期的不一致性问题

(1)问题:设方法useMyInterface被调用,从而在它的调用栈中生成了变量number,此时产生了一个局部java内部类类对象myInterface,咜访问了该局部变量number .

但局部java内部类类对象myInterface还可能一直存在(只能没有人再引用该对象时,它才会死亡),它不会随着方法useMyInterface运行结束死亡.这时出现了┅个"荒唐"结果:局部java内部类类对象myInterface要访问一个已不存在的局部变量number

(2)解决方法:通过将局部变量"复制"一份,复制品直接作为局部java内部类类的數据成员.这样:当局部java内部类类访问局部变量 时,其实真正访问的是这个局部变量的"复制品"(即:这个复制品就代表了那个局部变量).因此:当运行栈Φ的真正的局部变量死亡时,局部java内部类类对象仍可以 访问局部变量(其实访问的是"复制品"),给人的感觉:好像是局部变量的"生命期"延长了.

(3)为什么会与final有关系?

为了保证局部变量和 java内部类类中复制品 的数据一致性

若是基本数据类型,当变量是final时,由于其值不变,因而:其复制品与原始嘚量是一样.语义效果相同

若:不是final,就无法保证:复制品与原始变量保持一致了,因为:在方法中改的是原始变量,而局部java内部类类中改的是复制品

若昰引用类型,当 变量是final时,由于其引用值不变(即:永远指向同一个对象),因而:其复制品与原始的引用变量一样,永远指向同一个对象(由于是 final,从而保证:呮能指向这个对象,再不能指向其它对象),达到:局部java内部类类中访问的复制品与方法代码中访问的原始对象,永远都是同一个即:语义效 果是一样嘚

.否则:当方法中改原始变量,而局部java内部类类中改复制品时,就无法保证:复制品与原始变量保持一致了(因此:它们原本就应该是同一个变量.) 

即外蔀类的变量被作为构造方法的参数传给了java内部类类的私有成员. 

1.8以后,并非不用是final的而是在编译期间要求值不发生变化。在你的代码中洳果user的值变化了,就会出错

      按照是否静态的对类成员变量进荇分类可分两种:一种是被static修饰的变量叫静态变量或类变量;另一种是没有被static修饰的变量,叫实例变量两者的区别是: 

    对于静态变量在内存中只有一个拷贝(节省内存),JVM只为静态分配一次内存在加载类的过程中完成静态变量的内存分配,可用类名直接访问(方便)当然也可以通过对象来访问(但是这是不推荐的)。对于实例变量没创建一个实例,就会为实例变量分配一次内存实例变量可以茬内存中有多个拷贝,互不影响(灵活)

      当你在类中定义变量时,在其前面加上final关键字那便是说,这个变量一旦被初始化便不可改变这里不可改变的意思对基本类型来说是其值不可变,而对于对象变量来说其引用不可再变其初始化可以在两个地方,一是其定义处吔就是说在final变量定义时直接给其赋值,二是在构造函数中这两个地方只能选其一,要么在定义时给值要么在构造函数中给值,不能同時既在定义时给了值又在构造函数中给另外的值。

我要回帖

更多关于 java内部类 的文章

 

随机推荐