首页 > 试题广场 > 往outerClass类的代码段中插入内部类声明, 哪一个是
[不定项选择题]
往OuterClass类的代码段中插入内部类声明, 哪一个是错误的:
public class OuterClass{
    private float f=1.0f;
    //插入代码到这里
}
  • class InnerClass{
    public static float func(){return f;}
    }
  • abstract class InnerClass{
    public abstract float func(){}
    }
  • static class InnerClass{
    protected static float func(){return f;}
    }
  • public class InnerClass{
     static float func(){return f;}
    }

108个回答

添加回答
主要考核了这几个知识点:
1.静态内部类才可以声明静态方法
2.静态方法不可以使用非静态变量
3.抽象方法不可以有函数体
发表于 2016-05-22 10:21:50 回复(26)
这是我学习Java内部类的笔记
1.为什么使用内部类?
使用内部类最吸引人的原因是:每个内部类都能独立地继承一个(接口的)实现,所以无论外围类是否已经继承了某个(接口的)实现,
对于内部类都没有影响
1.1.使用内部类最大的优点就在于它能够非常好的解决多重继承的问题,使用内部类还能够为我们带来如下特性:
(1)、内部类可以用多个实例,每个实例都有自己的状态信息,并且与其他外围对象的信息相互独。
(2)、在单个外围类中,可以让多个内部类以不同的方式实现同一个接口,或者继承同一个类。
(3)、创建内部类对象的时刻并不依赖于外围类对象的创建。
(4)、内部类并没有令人迷惑的“is-a”关系,他就是一个独立的实体。
(5)、内部类提供了更好的封装,除了该外围类,其他类都不能访问。
2.内部类分类:
(一).成员内部类:
public class Outer{
		private int age = 99;
		String name = "Coco";
		public class Inner{
			String name = "Jayden";
			public void show(){
				System.out.println(Outer.this.name);
				System.out.println(name);
				System.out.println(age);
			}
		}
		public Inner getInnerClass(){
			return new Inner();
		}
		public static void main(String[] args){
			Outer o = new Outer();
			Inner in = o.new Inner();
			in.show();
		}
	}
1.Inner 类定义在 Outer 类的内部,相当于 Outer 类的一个成员变量的位置,Inner 类可以使用任意访问控制符,
如 public 、 protected 、 private 等
2.Inner 类中定义的 show() 方法可以直接访问 Outer 类中的数据,而不受访问控制符的影响,
如直接访问 Outer 类中的私有属性age
3.定义了成员内部类后,必须使用外部类对象来创建内部类对象,而不能直接去 new 一个内部类对象,
即:内部类 对象名 = 外部类对象.new 内部类( );
4.编译上面的程序后,会发现产生了两个 .class 文件: Outer.class,Outer$Inner.class{}
5.成员内部类中不能存在任何 static 的变量和方法,可以定义常量:
(1).因为非静态内部类是要依赖于外部类的实例,而静态变量和方法是不依赖于对象的,仅与类相关,
简而言之:在加载静态域时,根本没有外部类,所在在非静态内部类中不能定义静态域或方法,编译不通过;
非静态内部类的作用域是实例级别
(2).常量是在编译器就确定的,放到所谓的常量池了
★★友情提示:
1.外部类是不能直接使用内部类的成员和方法的,可先创建内部类的对象,然后通过内部类的对象来访问其成员变量和方法;
2.如果外部类和内部类具有相同的成员变量或方法,内部类默认访问自己的成员变量或方法,如果要访问外部类的成员变量,
可以使用 this 关键字,如:Outer.this.name
(二).静态内部类: 是 static 修饰的内部类,
1.静态内部类不能直接访问外部类的非静态成员,但可以通过 new 外部类().成员 的方式访问
2.如果外部类的静态成员与内部类的成员名称相同,可通过“类名.静态成员”访问外部类的静态成员;
如果外部类的静态成员与内部类的成员名称不相同,则可通过“成员名”直接调用外部类的静态成员
3.创建静态内部类的对象时,不需要外部类的对象,可以直接创建 内部类 对象名 = new 内部类();
public class Outer{
			private int age = 99;
			static String name = "Coco";
			public static class Inner{
				String name = "Jayden";
				public void show(){
					System.out.println(Outer.name);
					System.out.println(name);					
				}
			}
			public static void main(String[] args){
				Inner i = new Inner();
				i.show();
			}
		}
(三).方法内部类:其作用域仅限于方法内,方法外部无法访问该内部类
(1).局部内部类就像是方法里面的一个局部变量一样,是不能有 public、protected、private 以及 static 修饰符的
(2).只能访问方法中定义的 final 类型的局部变量,因为:
当方法被调用运行完毕之后,局部变量就已消亡了。但内部类对象可能还存在,
直到没有被引用时才会消亡。此时就会出现一种情况,就是内部类要访问一个不存在的局部变量;
==>使用final修饰符不仅会保持对象的引用不会改变,而且编译器还会持续维护这个对象在回调方法中的生命周期.
局部内部类并不是直接调用方法传进来的参数,而是内部类将传进来的参数通过自己的构造器备份到了自己的内部,
自己内部的方法调用的实际是自己的属性而不是外部类方法的参数;
防止被篡改数据,而导致内部类得到的值不一致
   /*
		使用的形参为何要为 final???
		 在内部类中的属性和外部方法的参数两者从外表上看是同一个东西,但实际上却不是,所以他们两者是可以任意变化的,
		 也就是说在内部类中我对属性的改变并不会影响到外部的形参,而然这从程序员的角度来看这是不可行的,
		 毕竟站在程序的角度来看这两个根本就是同一个,如果内部类该变了,而外部方法的形参却没有改变这是难以理解
		 和不可接受的,所以为了保持参数的一致性,就规定使用 final 来避免形参的不改变
		 */
		public class Outer{
			public void Show(){
				final int a = 25;
				int b = 13;
				class Inner{
					int c = 2;
					public void print(){
						System.out.println("访问外部类:" + a);
						System.out.println("访问内部类:" + c);
					}
				}
				Inner i = new Inner();
				i.print();
			}
			public static void main(String[] args){
				Outer o = new Outer();
				o.show();
			}
		}    

(3).注意:在JDK8版本之中,方法内部类中调用方法中的局部变量,可以不需要修饰为 final,匿名内部类也是一样的,主要是JDK8之后增加了 Effectively final 功能
反编译jdk8编译之后的class文件,发现内部类引用外部的局部变量都是 final 修饰的
(四).匿名内部类:
(1).匿名内部类是直接使用 new 来生成一个对象的引用;
(2).对于匿名内部类的使用它是存在一个缺陷的,就是它仅能被使用一次,创建匿名内部类时它会立即创建一个该类的实例,
该类的定义会立即消失,所以匿名内部类是不能够被重复使用;
(3).使用匿名内部类时,我们必须是继承一个类或者实现一个接口,但是两者不可兼得,同时也只能继承一个类或者实现一个接口;
(4).匿名内部类中是不能定义构造函数的,匿名内部类中不能存在任何的静态成员变量和静态方法;
(5).匿名内部类中不能存在任何的静态成员变量和静态方法,匿名内部类不能是抽象的,它必须要实现继承的类或者实现的接口的所有抽象方法
(6).匿名内部类初始化:使用构造代码块!利用构造代码块能够达到为匿名内部类创建一个构造器的效果
  public class OuterClass {
            public InnerClass getInnerClass(final int   num,String str2){
                return new InnerClass(){
                    int number = num + 3;
                    public int getNumber(){
                        return number;
                    }
                };        /* 注意:分号不能省 */
            }
            public static void main(String[] args) {
                OuterClass out = new OuterClass();
                InnerClass inner = out.getInnerClass(2, "chenssy");
                System.out.println(inner.getNumber());
            }
        }
        interface InnerClass {
            int getNumber();
        }          

编辑于 2017-11-24 10:33:55 回复(96)
静态方法不能访问非静态变量,A和C错;
抽象类中的抽象方法不能有方法提,B错;
一个类中有多个类声明时,只能有一个public类,D错
发表于 2015-08-30 13:07:19 回复(14)
感觉这题目有问题,目测没有正确答案。
ACD中函数func都是静态函数,而变量f是非静态的。静态函数直接访问非静态变量会有问题。
B中func用abstract修饰,却在后面又加了空的函数体,有问题。
发表于 2015-08-27 16:18:46 回复(3)
AD静态类不能定义静态方法,C静态方法不能引用非静态变量,B抽象方法没有方法体。
发表于 2016-03-13 00:45:41 回复(1)
静态的内部类才可以定义static方法,排除ACD
 abstract方法不能有函数体,排除B
编辑于 2017-09-14 09:58:37 回复(12)
选ABCD。
A选项,InnerClass非静态内部类中出现了static修饰的func()方法,静态内部类才可以声明静态方法。
B选项,abstract修饰的抽象类中抽象方法func(){}包含了方法体。
C选项,static的内部类不能引用外部类的非static的私有成员变量 f 。
D选项,静态内部类才可以声明静态方法, 静态方法不能使用非静态变量。
发表于 2019-04-23 21:15:02 回复(0)
AD很明显,你的内部类又不是用static关键字修饰的内部类怎么可以用static方法。。而且你static的方法return一个f是闹哪样。。
B选项内部类怎么还有abstract的。。。而且还实现了方法。。。铁锒。
C选项本来在我这边身份做好。但是它return了一个f。。。你是静态方法耶大哥。。怎么可以学AD我真是看错人了。。。
所以。。我觉得都有错啊。。但是你问我哪一个错。。。。。所以我只好勉为其难选一个给你咯。。。莫名委屈。。
编辑于 2017-08-25 22:00:36 回复(4)
静态方法不能访问非静态变量,因为静态方法及变量是属于类的,随着类的加载而加载;非静态变量是属于对象的,也就是说静态方法要早于非静态变量的存在,因此,A,C,D错;
抽象类中的抽象方法不能有方法体,B错;
发表于 2017-04-22 19:34:20 回复(0)
A错:内部类中不能定义static变量和方法
B错:抽象类中抽象方法只能声明(声明之后用分号结束)不能有方法体
C错:静态方法不能访问非静态变量
D错:一个类中有多个类声明时只能有一个public类
发表于 2016-03-09 20:01:09 回复(4)
静态方法只能在静态内部类或顶层中; 静态方法不能访问非静态的域; 虚拟方法只能存在虚拟类中,且不能有方法体。
发表于 2016-03-03 23:11:43 回复(1)
静态内部类不能访问外部类的实例成员,只能访问外部类的类成员,即使是静态内部类的实例方法也不能访问外部类的实例成员。
发表于 2015-12-15 16:36:25 回复(0)
机翻了一下IDEA的解释,英语不好请见谅
A.内部类不能有静态定义,非静态变量“f”不能被静态上下文引用
B.抽象方法不能拥有方法体
C.非静态变量“f”不能被静态上下文引用
D.同A
编辑于 2019-04-26 15:59:53 回复(0)
选A、B、C、D。其中
A,静态内部类才可以声明静态方法;
B,抽象方法没有方法体;
C,静态内部类不能引用外部类的非静态变量 f;
D,静态内部类才可以声明静态方法
编辑于 2019-04-25 11:42:15 回复(0)
  1. Cannot make a static reference to the non-static field f  静态方法不能使用非静态变量
  2. Abstract methods do not specify a body  抽象方法不能有方法体
  3. Cannot make a static reference to the non-static field f   静态方法不能使用非静态变量
  4. The method func cannot be declared static; static methods can only be declared in a static or top level type 静态内部类才可以声明静态方法, 静态方法不能使用非静态变量
发表于 2018-08-13 15:29:56 回复(0)
选ABCD
ACD,静态内部类中不能访问外部的非静态资源。
B,抽象方法可没有方法体(也就是大括号{})

PS:
        1. 静态内部类才可以定义静态资源,且不可访问外部非静态资源
        2. 成员内部类可以访问外部的所有资源,但是本身却不能定义静态资源(因为本身自己就需要实例化
        3. 局部内部类,这个就看成是一个局部变量,只能访问方法的形参和方法中被定义成final的成员。
        4. 匿名内部类,这个可以推成很多东西,比如不是每个类都有构造器。
发表于 2018-07-02 16:04:57 回复(0)
图文解析~
发表于 2018-06-08 23:08:21 回复(0)
静态内部类才可以定义静态方法,抽象方法不能有方法体
使用内部类可以很好的解决java中的多继承问题
发表于 2017-08-03 09:49:37 回复(0)
c是因为访问了f,f是非静态变量,这里是静态方法,所有c错。b是因为抽象方法不能有方法体
发表于 2017-07-03 12:46:11 回复(0)
感觉@小杨vita的解释并没有错。只是回复中的人还发现别的错而已。
下面似乎解释了三点:
1. 静态的内部类才可以定义static方法
2.  abstract方法不能有函数体(这一点毋庸置疑)
3.  静态方法不能访问非静态变量 (这一点也毋庸置疑)
不过证实了@ rhwayfun第三点解释并不是D错误的原因

@BlueFish 的笔记很丰富,但我没有验证,可以看看
编辑于 2016-11-25 20:07:15 回复(0)