一文带你轻松拿下Java中的抽象类

🤷‍♀️🤷‍♀️🤷‍♀️各位看官你们好呀!!! 今天我带大家来深入了解一下Java中的抽象类,相信看完这篇文章,你将会有很大的收获!

 个人主页

🌂c/java领域新星创作者

🎉欢迎👍点赞✍评论❤️收藏

😛😛😛希望我的文章能对你有所帮助,有不足的地方还请各位看官多多指教,大家一起学习交流!


目录

一、抽象类的概念 

二、抽象类语法 

三、抽象类特性 

1. 抽象类不能直接实例化对象

2. 抽象方法不能是 private

 3. 抽象方法不能被final和static修饰

4.抽象类必须被继承

四、抽象类的作用 


一、抽象类的概念 

在面向对象的概念中,所有的对象都是通过类来描绘的,但是反过来,并不是所有的类都是用来描绘对象的, 如果 一个类中没有包含足够的信息来描绘一个具体的对象,这样的类就是抽象类 。 比如:

 

在打印图形例子中 , 我们发现 , 父类 Shape 中的 draw 方法好像并没有什么实际工作 , 主要的绘制图形都是由 Shape的各种子类的 draw 方法来完成的。 像这种没有实际工作的方法 , 我们可以把它设计成一个 抽象方法(abstract method) , 包含抽象方法的类我们称为 抽象类(abstract class)

二、抽象类语法 

Java 中,一个类如果被 abstract 修饰称为抽象类,抽象类中被 abstract 修饰的方法称为抽象方法,抽象方法不用给出具体的实现体。

比如下面的代码:

// 抽象类:被abstract修饰的类
public abstract class Shape {
         // 抽象方法:被abstract修饰的方法,没有方法体
         abstract public void draw();
         abstract void calcArea();
         // 抽象类也是类,也可以增加普通方法和属性
         public double getArea(){
                 return area;
         }
         protected double area; // 面积
}
  •  注意:抽象类也是类,内部可以包含普通方法和属性,甚至构造方法。

三、抽象类特性 

1. 抽象类不能直接实例化对象

Shape shape = new Shape();
// 编译出错
Error:(30, 23) java: Shape是抽象的; 无法实例化

2. 抽象方法不能是 private

abstract class Shape {
      abstract private void draw();
}
// 编译出错
Error:(4, 27) java: 非法的修饰符组合: abstract和private

 3. 抽象方法不能被finalstatic修饰

抽象方法不能被final和static修饰,因为抽象方法要被子类重写,而被static和final修饰的方法是不允许被重写的!!!

public abstract class Shape {
     abstract final void methodA();
     abstract public static void methodB();
}
// 编译报错:
// Error:(20, 25) java: 非法的修饰符组合:abstract和final
// Error:(21, 33) java: 非法的修饰符组合: abstract和static

4.抽象类必须被继承

抽象类必须被继承,并且继承后子类要重写父类中的抽象方法,否则子类也是抽象类,必须要使用 abstract 修饰。
// 矩形类
public class Rect extends Shape {
    private double length;
    private double width;
    Rect(double length, double width){
          this.length = length;
          this.width = width;
    }
    public void draw(){
          System.out.println("矩形: length= "+length+" width= " + width);
    }
    public void calcArea(){
          area = length * width;
    }
}
// 圆类:
public class Circle extends Shape{
    private double r;
    final private static double PI = 3.14;
    public Circle(double r){
          this.r = r;
    }
    public void draw(){
          System.out.println("圆:r = "+r);
    }
    public void calcArea(){
          area = PI * r * r;
    }
}
// 三角形类:
public abstract class Triangle extends Shape {
    private double a;
    private double b;
    private double c;
    @Override
    public void draw() {
          System.out.println("三角形:a = "+a + " b = "+b+" c = "+c);
    }
// 三角形:直角三角形、等腰三角形等,还可以继续细化
    //@Override
   //double calcArea(); // 编译失败:要么实现该抽象方法,要么将三角形设计为抽象类
}
  •  注意:
  • 抽象类中不一定包含抽象方法,但是有抽象方法的类一定是抽象类
  • 抽象类中可以有构造方法,供子类创建对象时,初始化父类的成员变量

四、抽象类的作用 

抽象类本身不能被实例化 , 要想使用 , 只能创建该抽象类的子类 然后让子类重写抽象类中的抽象方法。
那我们就会想到, 普通的类也可以被继承呀, 普通的方法也可以被重写呀, 为啥非得用抽象类和抽象方法呢?

确实如此.,但是使用抽象类相当于多了一重编译器的校验。

使用抽象类的场景就如上面的代码 , 实际工作不应该由父类完成 , 而应由子类完成。 那么此时如果不小心误用成父类了, 使用普通类编译器是不会报错的 .。 但是父类是抽象类就会在实例化的时候提示错误 , 让我们尽早发现问题。
很多语法存在的意义都是为了 "预防出错", 例如Java中的final也是类似.。创建的变量用户不去修改, 不就相当于常量嘛? 但是加上 final 能够在不小心误修改的时候, 让编译器及时提醒我们。
充分利用编译器的校验, 在实际开发中是非常有意义的。

🎉好啦,今天的分享就到这里!!

创作不易,还希望各位大佬支持一下!

👍点赞,你的认可是我创作的动力

收藏,你的青睐是我努力的方向!

✏️评论:你的意见是我进步的财富!

 

 

  • 19
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 9
    评论
Spark是一个快速通用的集群计算框架,它可以处理大规模数据,并且具有高效的内存计算能力。Spark可以用于各种计算任务,包括批处理、流处理、机器学习等。本你了解Spark计算框架的基本概念和使用方法。 一、Spark基础概念 1. RDD RDD(Resilient Distributed Datasets)是Spark的基本数据结构,它是一个分布式的、可容错的、不可变的数据集合。RDD可以从Hadoop、本地件系统等数据源读取数据,并且可以通过多个转换操作(如map、filter、reduce等)进行处理。RDD也可以被持久化到内存,以便下次使用。 2. Spark应用程序 Spark应用程序是由一个驱动程序和多个执行程序组成的分布式计算应用程序。驱动程序是应用程序的主要入口点,它通常位于用户的本地计算机上,驱动程序负责将应用程序分发到执行程序上并收集结果。执行程序是运行在集群节点上的计算单元,它们负责执行驱动程序分配给它们的任务。 3. Spark集群管理器 Spark集群管理器负责管理Spark应用程序在集群的运行。Spark支持多种集群管理器,包括Standalone、YARN、Mesos等。 二、Spark计算框架使用方法 1. 安装Spark 首先需要安装Spark,可以从Spark官网下载并解压缩Spark安装包。 2. 编写Spark应用程序 编写Spark应用程序通常需要使用Java、Scala或Python编程语言。以下是一个简单的Java代码示例,用于统计单词的出现次数: ```java import org.apache.spark.SparkConf; import org.apache.spark.api.java.JavaRDD; import org.apache.spark.api.java.JavaSparkContext; import java.util.Arrays; import java.util.Map; public class WordCount { public static void main(String[] args) { SparkConf conf = new SparkConf().setAppName("WordCount").setMaster("local"); JavaSparkContext sc = new JavaSparkContext(conf); JavaRDD<String> lines = sc.textFile("input.txt"); JavaRDD<String> words = lines.flatMap(line -> Arrays.asList(line.split(" ")).iterator()); Map<String, Long> wordCounts = words.countByValue(); for (Map.Entry<String, Long> entry : wordCounts.entrySet()) { System.out.println(entry.getKey() + " : " + entry.getValue()); } sc.stop(); } } ``` 3. 运行Spark应用程序 将编写好的Spark应用程序打包成jar包,并通过以下命令运行: ```bash spark-submit --class WordCount /path/to/wordcount.jar input.txt ``` 其,--class参数指定应用程序的主类,后面跟上打包好的jar包路径,input.txt是输入件的路径。 4. 查看运行结果 Spark应用程序运行完毕后,可以查看应用程序的输出结果,例如上述示例的单词出现次数。 以上就是Spark计算框架的基本概念和使用方法。通过学习Spark,我们可以更好地处理大规模数据,并且提高计算效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

..清风

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值