关于Java面向对象的分析题

简介: 分析程序看有没有问题,如果有,说出原因即可。-----------------------------------------------------------------------------1. abstract class Name { private String name; public abstract boolean isStupidName(String name) {} //有方法体,但方法体为空。

分析程序看有没有问题,如果有,说出原因即可。
-----------------------------------------------------------------------------
1.

abstract class Name {
   private String name;
   public abstract boolean isStupidName(String name) {}    //有方法体,但方法体为空。会报错。
}

错误。
  抽象方法必须以分号结尾,且不带花括号。
  在Java中,一个没有具体的方法体的方法应该定义为抽象方法。
  而在一个类中如果有抽象方法,该类必须定义为抽象类。
-----------------------------------------------------------------------------
2.

public class Something {
   void doSomething () {
       private String s = "";
       int l = s.length();
   }
}

错误。
  局部变量前不能放置任何访问修饰符 (private,public和protected)。
  final可以用来修饰局部变量。被final修饰的局部变量变为常量了。
-----------------------------------------------------------------------------
3.

abstract class Something {
   private abstract String doSomething ();
}

错误。
  抽象的方法不能以private修饰。
  抽象的方法就是让子类implement(实现)具体细节的,怎么可以用private把抽象的方法封锁起来呢?
  (同理,抽象的方法前不能加final)。
-----------------------------------------------------------------------------
4.

public class Something {
   public int addOne(final int x) {
       return ++x;
   }
}

错误。
  int x被final修饰,意味着x不能在addOne 方法中被修改。
-----------------------------------------------------------------------------
5.

public class Something {
   public static void main(String[] args) {
       Other o = new Other();
       new Something().addOne(o);
   }
   public void addOne(final Other o) {
       //o = new Other();    //对象o重新指向了新的地址值,但是对象o是被final修饰了,所以这句会报错!
       o.i++;    //正确
   }
}

class Other {
   public int i;
}

正确。

  在addOne 方法中,参数o被修饰成final。
  如果在addOne 方法里我们修改了o的引用(比如: o = new Other();),那么如同上例这题也是错的。
  但这里修改的是o的成员变量i(member vairable),而o的引用(reference)并没有改变。
-----------------------------------------------------------------------------
6.

1 class Something {
2     int i;
3     public void doSomething() {
4         System.out.println("i = " + i);
5     }
6 } 

正确。
  输出的是"i = 0"。int i属于成员变量/实例变量(instant variable)。成员变量有缺省值(default value)。int i的缺省值是0。
-----------------------------------------------------------------------------
7.

class Something {
    final int i;
    public void doSomething() {
        System.out.println("i = " + i);
    }
}

错误。
  被final修饰的成员变量没有默认值(default value),必须在构造器(constructor )结束之前被赋予一个明确的值。
  即在定义被final修饰的成员变量时就给值,例如final int i = 0;
-----------------------------------------------------------------------------
8.

public class Something {
    public static void main(String[] args) {
        Something s = new Something();
        System.out.println("s.doSomething() returns " + doSomething());
    }
    public String doSomething() {
        return "Do something ...";
    }
}

错误。
  看上去在main里调用doSomething()没有什么问题,毕竟两个方法都在同一个class里。
  但仔细看,main方法是static的。静态的方法不能直接调用非静态的方法。
  可改成"System.out.println("s.doSomething() returns " + s.doSomething());"。
  同理,静态方法(static method)不能访问非静态成员变量(non-static instant variable)。
-----------------------------------------------------------------------------
9.

此处,Something类的文件名叫OtherThing.java
class Something {
    private static void main(String[] something_to_do) {        
        System.out.println("Do something ...");
    }
}

正确。
  从来没有人说过Java的Class名字必须和其文件名相同。但public class A {} 的名字必须和文件名相同。
-----------------------------------------------------------------------------
10.

interface  A {    //因为接口的所有成员变量的默认修饰符都是:public static final
   int x = 0;
}
class B { int x = 1; }
class C extends B implements A { public void pX() { System.out.println(x); } public static void main(String[] args) { new C().pX(); } }

错误。
  在编译时会发生错误(错误描述不同的JVM有不同的信息),
  意思就是未明确的x调用,两个x都匹配(就像在同时import java.util和java.sql两个包时直接声明Date一样)。
  对于父类的变量,可以用super.x来明确调用,而接口的成员变量(属性)默认隐含修饰符为public static final int x = ;可以通过A.x来明确调用。
-----------------------------------------------------------------------------
11.

interface Playable {    //因为接口的所有成员方法的默认修饰符都是:public abstract
    void play();    //完整形式为:public abstract void play();
}
interface Bounceable { void play(); }
interface Rollable extends Playable, Bounceable { //因为接口的所有成员变量的默认修饰符都是:public static final Ball ball = new Ball("PingPang"); //这是成员变量。完整形式为:public static final Ball ball = new Ball("PingPang"); } //即ball是一个最终变量(常量),其类型是引用数据类型,也即ball不能再new了。

class Ball implements Rollable { private String name; public String getName() { return name; } public Ball(String name) { this.name = name; } public void play() { ball = new Ball("Football"); System.out.println(ball.getName()); } }

错误。
  接口可以多继承,即接口可以继承多个接口。
  任何在接口里声明的接口变量,也可称成员变量,默认的修饰符为public static final。
  也就是说: Ball ball = new Ball("PingPang");是成员变量,实际上是 public static final Ball ball = new Ball("PingPang");。
  在Ball类的play()方法中,"ball = new Ball("Football");"改变了ball的引用,而这里的ball来自Rollable 接口,
  Rollable 接口里的ball是public static final的,final修饰的对象是不能被改变引用(reference)的。
  因此编译器将在 ball = new Ball("Football"); 这里显示有错。
-----------------------------------------------------------------------------

我的GitHub地址: https://github.com/heizemingjun
我的博客园地址: http://www.cnblogs.com/chenmingjun
我的蚂蚁笔记博客地址: http://blog.leanote.com/chenmingjun
Copyright ©2018 黑泽明军
【转载文章务必保留出处和署名,谢谢!】
相关文章
|
3月前
|
存储 Java
【编程基础知识】 分析学生成绩:用Java二维数组存储与输出
本文介绍如何使用Java二维数组存储和处理多个学生的各科成绩,包括成绩的输入、存储及格式化输出,适合初学者实践Java基础知识。
99 1
|
13天前
|
缓存 算法 搜索推荐
Java中的算法优化与复杂度分析
在Java开发中,理解和优化算法的时间复杂度和空间复杂度是提升程序性能的关键。通过合理选择数据结构、避免重复计算、应用分治法等策略,可以显著提高算法效率。在实际开发中,应该根据具体需求和场景,选择合适的优化方法,从而编写出高效、可靠的代码。
25 6
|
2月前
|
监控 算法 Java
jvm-48-java 变更导致压测应用性能下降,如何分析定位原因?
【11月更文挑战第17天】当JVM相关变更导致压测应用性能下降时,可通过检查变更内容(如JVM参数、Java版本、代码变更)、收集性能监控数据(使用JVM监控工具、应用性能监控工具、系统资源监控)、分析垃圾回收情况(GC日志分析、内存泄漏检查)、分析线程和锁(线程状态分析、锁竞争分析)及分析代码执行路径(使用代码性能分析工具、代码审查)等步骤来定位和解决问题。
|
1月前
|
Java
java中面向过程和面向对象区别?
java中面向过程和面向对象区别?
25 1
|
2月前
|
JavaScript 前端开发 Java
还不明白面向对象? 本文带你彻底搞懂面向对象的三大特征(2024年11月Java版)
欢迎来到我的博客,我是瑞雨溪,一名热爱JavaScript和Vue的大一学生。如果你从我的文章中受益,欢迎关注我,我将持续更新更多优质内容。你的支持是我前进的动力!🎉🎉🎉
26 0
还不明白面向对象? 本文带你彻底搞懂面向对象的三大特征(2024年11月Java版)
|
2月前
|
存储 Java 关系型数据库
在Java开发中,数据库连接是应用与数据交互的关键环节。本文通过案例分析,深入探讨Java连接池的原理与最佳实践
在Java开发中,数据库连接是应用与数据交互的关键环节。本文通过案例分析,深入探讨Java连接池的原理与最佳实践,包括连接创建、分配、复用和释放等操作,并通过电商应用实例展示了如何选择合适的连接池库(如HikariCP)和配置参数,实现高效、稳定的数据库连接管理。
72 2
|
2月前
|
Java 关系型数据库 数据库
面向对象设计原则在Java中的实现与案例分析
【10月更文挑战第25天】本文通过Java语言的具体实现和案例分析,详细介绍了面向对象设计的五大核心原则:单一职责原则、开闭原则、里氏替换原则、接口隔离原则和依赖倒置原则。这些原则帮助开发者构建更加灵活、可维护和可扩展的系统,不仅适用于Java,也适用于其他面向对象编程语言。
46 2
|
3月前
|
Java
让星星⭐月亮告诉你,Java synchronized(*.class) synchronized 方法 synchronized(this)分析
本文通过Java代码示例,介绍了`synchronized`关键字在类和实例方法上的使用。总结了三种情况:1) 类级别的锁,多个实例对象在同一时刻只能有一个获取锁;2) 实例方法级别的锁,多个实例对象可以同时执行;3) 同一实例对象的多个线程,同一时刻只能有一个线程执行同步方法。
24 1
|
3月前
|
小程序 Oracle Java
JVM知识体系学习一:JVM了解基础、java编译后class文件的类结构详解,class分析工具 javap 和 jclasslib 的使用
这篇文章是关于JVM基础知识的介绍,包括JVM的跨平台和跨语言特性、Class文件格式的详细解析,以及如何使用javap和jclasslib工具来分析Class文件。
62 0
JVM知识体系学习一:JVM了解基础、java编译后class文件的类结构详解,class分析工具 javap 和 jclasslib 的使用
|
3月前
|
Java
如何从Java字节码角度分析问题|8月更文挑战
如何从Java字节码角度分析问题|8月更文挑战