-
二者区别查看全部
-
成员变量和局部变量查看全部
-
使用对象查看全部
-
定义类查看全部
-
Java 中的方法内部类 方法内部类就是内部类定义在外部类的方法中,方法内部类只在该方法的内部可见,即只在该方法内可以使用。 一定要注意哦:由于方法内部类不能在外部类的方法以外的地方使用,因此方法内部类不能使用访问控制符和 static 修饰符。查看全部
-
Java 中的静态内部类 静态内部类是 static 修饰的内部类,这种内部类的特点是: 1、 静态内部类不能直接访问外部类的非静态成员,但可以通过 new 外部类().成员 的方式访问 2、 如果外部类的静态成员与内部类的成员名称相同,可通过“类名.静态成员”访问外部类的静态成员;如果外部类的静态成员与内部类的成员名称不相同,则可通过“成员名”直接调用外部类的静态成员 3、 创建静态内部类的对象时,不需要外部类的对象,可以直接创建 内部类 对象名= new 内部类();查看全部
-
Java 中的成员内部类 内部类中最常见的就是成员内部类,也称为普通内部类。 成员内部类的使用方法: 1、 Inner 类定义在 Outer 类的内部,相当于 Outer 类的一个成员变量的位置,Inner 类可以使用任意访问控制符,如 public 、 protected 、 private 等 2、 Inner 类中定义的 test() 方法可以直接访问 Outer 类中的数据,而不受访问控制符的影响,如直接访问 Outer 类中的私有属性a 3、 定义了成员内部类后,必须使用外部类对象来创建内部类对象,而不能直接去 new 一个内部类对象,即:内部类 对象名 = 外部类对象.new 内部类( ); 4、 编译上面的程序后,会发现产生了两个 .class 文件 其中,第二个是外部类的 .class 文件,第一个是内部类的 .class 文件,即成员内部类的 .class 文件总是这样:外部类名$内部类名.class 另外,友情提示哦: 1、 外部类是不能直接使用内部类的成员和方法滴 可先创建内部类的对象,然后通过内部类的对象来访问其成员变量和方法。 2、 如果外部类和内部类具有相同的成员变量或方法,内部类默认访问自己的成员变量或方法,如果要访问外部类的成员变量,可以使用 this 关键字。查看全部
-
什么是 Java 中的内部类 问:什么是内部类呢? 答:内部类( Inner Class )就是定义在另外一个类里面的类。与之对应,包含内部类的类被称为外部类。 问:那为什么要将一个类定义在另一个类里面呢?清清爽爽的独立的一个类多好啊!! 答:内部类的主要作用如下: 1. 内部类提供了更好的封装,可以把内部类隐藏在外部类之内,不允许同一个包中的其他类访问该类 2. 内部类的方法可以直接访问外部类的所有数据,包括私有的数据 3. 内部类所实现的功能使用外部类同样可以实现,只是有时使用内部类更方便 问:内部类有几种呢? 答:内部类可分为以下几种: 成员内部类 静态内部类 方法内部类 匿名内部类查看全部
-
Java 中的 static 使用之静态方法 与静态变量一样,我们也可以使用 static 修饰方法,称为静态方法或类方法。其实之前我们一直写的 main 方法就是静态方法。静态方法的使用如: 运行结果: 需要注意: 1、 静态方法中可以直接调用同类中的静态成员,但不能直接调用非静态成员。如: 如果希望在静态方法中调用非静态变量,可以通过创建类的对象,然后通过对象来访问非静态变量。如: 2、 在普通成员方法中,则可以直接访问同类的非静态变量和静态变量,如下所示: 3、 静态方法中不能直接调用非静态方法,需要通过对象来访问非静态方法。查看全部
-
this关键字的解释查看全部
-
1、 静态内部类不能直接访问外部类的非静态成员,但可以通过 new 外部类().成员 的方式访问 2、 如果外部类的静态成员与内部类的成员名称相同,可通过“类名.静态成员”访问外部类的静态成员;如果外部类的静态成员与内部类的成员名称不相同,则可通过“成员名”直接调用外部类的静态成员 3、 创建静态内部类的对象时,不需要外部类的对象,可以直接创建 内部类 对象名= new 内部类();查看全部
-
访问修饰符查看全部
-
类中:public float getScreen(){ return screen; } public void setScreen(float newScreen){ screen=newScreen;} 主方法中:Phone2.setScreen(6.0f); System.out.println("screen:"+Phone2.getScreen());查看全部
-
可区分同名的类文件查看全部
-
所以说,程序在真正执行的时候发现两个类型不匹配。那么,你是不能进行类型转换的。那么我们怎么来避免这个问题呢?就可以用到我们的instanceof这个关键字,他就可以判断一个引用是否是某个类型或者某个类型的子类型?那他就会返回一个bool值,那么我们通常会用这个bool值跟if语句配合来使用,如果你这个对象里面含有这个cat类型的元素,我就可以转换,否则呢,就不能转换,我们是可以判断一下,同理,如果我返回的bool值为假,说明是不能转换的,我就提示一句话,无法进行类型转换。if(animal instanceof Cat){ Cat cat=(Cat)animal; }else{ System.out.println("不能进行类型转换!转换成Cat类型"); }所以说,我们通常会使用instanceof关键字来避免这个问题。那我们想想上面的方式可否用这种方式来验证呢?也是可以的,if(animal instanceof Dog){ Dog dog2=(Dog)animal;//向下类型转换 强制类型转换 }else{ System.out.println("不能进行类型转换! 转换成Dog类型"); }查看全部
举报
0/150
提交
取消