Android开发中为什么不能标记重写(@override)抽象方法(abstract)

本文探讨了在Android开发中为何不能使用@override注解标记抽象方法,并解释了解决此问题的方法。文中提到,在JDK 1.5中无法正确使用@override修饰接口或抽象方法,但更新到JDK 1.6可以解决这一限制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Android开发中为什么不能标记重写(@override)抽象方法(abstract)

当你使用java开发Android应用时,很多时候要通过使用匿名类来完成诸如按钮点击这种事件处理方法。例如:

     Button btnBack = (Button)findViewById(R.id.btnBack);
     btnBack.setOnClickListener(new View.OnClickListener() {

      @override
       public void onClick(View v) {
                back();
         }
      });

 

有时你会发现,编译器会告诉你,出错了:

The method onClick(View) of type new View.OnClickListener(){} must override a superclass。

 

这是为什么呢?莫非因为onClick是抽象方法不能override,或者说不能用@override修饰。这不科学啊。其实是这样的,在jdk 1.5中是不可以用@override修饰接口和抽象方法的,它认为人家本身没有具体实现,因此不算override。。。。。。。只要将

项目属性---->javaCompiler中的complier compliance level 将1.5改为1.6即可。


来源:http://hi.baidu.com/cenxcen/item/642f4c46eb5909f2dc0f6cdd

 

### Java 中抽象类不能创建对象的原因 在 Java 编程语言中,抽象类被设计成一种不允许直接实例化的特殊类。当一个类声明为 `abstract` 类型时,意味着该类包含了未完成的部分——至少有一个或多个抽象方法,这些方法只有签名而无具体的实现逻辑。 如果允许直接通过 `new()` 来创建抽象类的对象,则无法提供完整的功能行为给调用者,因为某些成员函数可能根本就没有实际的内容可供执行。因此,在尝试这样做时编译器将会报错并阻止这种操作的发生[^3]。 然而这并不妨碍我们利用多态性的特性来间接地处理这种情况:可以通过其非抽象子类来进行实例化,并将它们赋值给父类型的引用变量。例如: ```java public abstract class Animal { public abstract void makeSound(); } public class Dog extends Animal { @Override public void makeSound() { System.out.println("Woof!"); } } // 正确的方式是使用具体子类进行实例化 Animal myDog = new Dog(); myDog.makeSound(); // 输出: Woof! ``` 上述代码展示了如何正确地使用抽象类及其子类的关系。这里的关键在于 `Animal` 是一个抽象基类,它本身不能用来创建任何实体;相反,`Dog` 继承自 `Animal` 并提供了所有必需的具体实现细节,所以能够正常工作。 另外值得注意的是,即使某个类没有任何显式的抽象方法也可以标记为 `abstract` 。这么做通常是为了防止其他开发者误以为可以直接实例化此类,同时也强制要求它的每一个直接子类都要给出特定的行为定义[^4]。 #### 关于抽象类的几点补充说明 - 抽象类的存在主要是为了建立一组通用属性和行为框架供后续更具体的子类继承和发展; - 子类必须覆盖(重写)所有的抽象方法才能成为可实例化的常规类; - 如果子类也包含新的抽象方法,则该子类同样需要保持为 `abstract` 状态直到进一步细化为止。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值