Java笔记1.2--基本的流程控制 方法的覆盖和重载 抽象类抽象方法

流程控制:

1.判断。在写if的时候注意多个条件判断时,如果是 &&  第一个条件不符合时第二个就不会计算了。

2.注意边界问题。

3.if过多改写为switch。(必须要有Break,不然会继续执行下一个case)

4.switch在jdk1.7之前只支持byte,short,char,int和其对应的封装类。1.8以后加入了枚举,boolean,字符串。

 

覆盖和继承:

在继承父类的时候子类重写的函数不能将public重写为private(缩小后会造成父类本该可见的方法不可见,即违背了父类定义通用的属性和方法),反之可以(但是就不叫继承了,是一个新的方法)。

在继承父类的方法有抛出异常行为时,不能抛出比父类更宽泛的异常。理由:父类定义的方法原型是外部调用的规范,如果子类扩大了异常类型,那么外部调用时候就无法处理抛出的异常。

 

public class OverloadDemo {
    public void print(){}
    public void print(int size){}
//    public void print(int size,String type){}
    //public void print(int number,String owner){} //error
    public int print(int number,String owner){return 1;} //error
}

在重载中上述五个方法,3和4和5算重复方法。比如 1 2 5 算重载。可以看出来返回类型不会影响是否为重载。

1.实现业务和业务细节的分离(重载实现细节)

2.与相近功能方法进行重载,增加可读性。

3.业务相同,参数不同。解耦合。

 

抽象类和抽象方法:

1.有抽象方法的必须是抽象类,反之不然。

2.抽象方法不能定义方法体。

3.子类继承抽象方法必须去实现。

什么时候用接口,什么时候用抽象类?

概念上是从属关系,可以用抽象类。(动物类,狗类)

功能上的封装,用接口。(比如提供链接数据库功能的接口)

举个例子:设计一个基类为“车”,生产商要生产一种“空调车”,所以“空调车”要继承“车”这个父类,继承其“车”的基本类型,其要增加的“空调”功能可以封装在一个功能类里,这里只是实现该接口(因为不同的车或者其他地方安装“空调”的方式不同,都要实现这个接口)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
很好的问题!让我来解答。 首先,让我们来了解一下 `Comparable` 接口。这个接口是 Java 中的一个接口,它只有一个方法 `compareTo()`。这个方法的作用是定义类的自然排序顺序。 如果我们要对一个对象集合进行排序,只需要让这个类实现 `Comparable` 接口,并且重写 `compareTo()` 方法。这个方法返回一个整型值,表示该对象与另一个对象的大小关系。如果该对象小于另一个对象,则返回负整数;如果两个对象相等,则返回零;如果该对象大于另一个对象,则返回正整数。 下面是一个简单的例子,展示如何使用 `Comparable` 接口进行排序。 ```java public class Student implements Comparable<Student> { private String name; private int age; public Student(String name, int age) { this.name = name; this.age = age; } public String getName() { return name; } public int getAge() { return age; } // 重写 compareTo 方法 @Override public int compareTo(Student o) { // 按照年龄从小到大排序 return this.age - o.getAge(); } } ``` 在这个例子中,我们定义了一个 `Student` 类,并且让它实现了 `Comparable` 接口。我们重写了 `compareTo()` 方法,按照年龄从小到大排序。 现在,我们可以使用 `Collections.sort()` 方法对 `Student` 对象进行排序了: ```java List<Student> students = new ArrayList<>(); students.add(new Student("Tom", 20)); students.add(new Student("Jerry", 18)); students.add(new Student("Alice", 22)); Collections.sort(students); for (Student student : students) { System.out.println(student.getName() + " " + student.getAge()); } ``` 输出结果为: ``` Jerry 18 Tom 20 Alice 22 ``` 可以看到,我们成功地按照年龄从小到大对 `Student` 对象进行了排序。 希望这个例子能够帮助你理解如何使用 `Comparable` 接口进行排序。如果你还有其他问题,请随时提出!

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值