我对上一篇博客的拙见

我将教练和教练放在一块儿,共同继承教练类,教练类中有个抽象方法,就是教学,因此,必须在子类中重写这个方法,不同的教练也会有不同的教学方法,在子类中可以得到体现。将球员放在一块儿,共同继承球员类,球员类中的方法就是学习,也是一个抽象方法,也要求我们进行重写,可以分别写出不同球员学习的不同类。将说英语作为一个接口,将乒乓球队接入这个接口,可让乒乓球队类重写这个方法,逻辑清晰,方便快捷,以下是我的拙见,我写出来的一些粗糙代码,望点评。

public class FinalTest {
    public static void main(String[] args) {
        Basketballer b1=new Basketballer("james",35);
        System.out.println(b1.getAge()+","+b1.getName());
        Tableplayer t1=new Tableplayer();
        t1.speak();
        t1.study();
        b1.study();
        Basket b2=new Basket();
        Table t2=new Table();
        b2.teach();
        t2.speak();
        t2.teach();
    }
}

这是测试类

package Exaple;

public class Person {
    private String name;
    private int age;

    public Person() {
    }

    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }
}


这是父类Person。

public abstract class Coach extends Person {
    public Coach() {
    }

    public Coach(String name, int age) {
        super(name, age);
    }

    public abstract void teach();

}

这是教练的父类。

public  abstract class Sportsman extends Person {
    public Sportsman() {
    }

    public Sportsman(String name, int age) {
        super(name, age);
    }

    public abstract void study();
}

这是球员类的父类。

public interface SpeakEnglish {
    public abstract void speak();
}

这是接口“说英语”。

public class Table extends Coach implements SpeakEnglish {
    public Table() {
    }

    public Table(String name, int age) {
        super(name, age);
    }

    @Override
    public void teach() {
        System.out.println("乒乓球教练在教学");
    }
    @Override
    public void speak(){
        System.out.println("乒乓球教练在说英语");
    }
}

这是乒乓球教练员类。

public class Basket extends Coach {
    public Basket() {
    }

    public Basket(String name, int age) {
        super(name, age);
    }

    @Override
    public void teach() {
        System.out.println("篮球教练在教学");
    }
}

这是篮球教练员类。

public class Tableplayer extends Sportsman implements SpeakEnglish {
    public Tableplayer() {
    }

    public Tableplayer(String name, int age) {
        super(name, age);
    }

    @Override
    public void speak() {
        System.out.println("乒乓球运动员在说英语");
    }

    @Override
    public void study() {
    System.out.println("乒乓球运动员在学习打乒乓球");
    }
}

这是乒乓球员类。

public class Basketballer extends Sportsman {
    public Basketballer() {
    }

    public Basketballer(String name, int age) {
        super(name, age);
    }

    @Override
    public void study() {
        System.out.println("篮球运动员在学习如何打篮球");
    }
}

这是篮球运动员类。
这个题我觉得是很锻炼人的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Vue 3中,没有直接的`created()`语法糖。在Vue 2中,`created()`是一个生命周期钩子函数,用于在组件实例创建后执行特定的操作。然而,在Vue 3中,为了简化组件的写法,将数据和方法的声明与组件实例的创建过程分离,采用了新的`<script lang="ts" setup>`语法糖来替代传统的选项API。使用`setup()`函数来声明组件的数据和方法。 如果你想在Vue 3中实现类似于`created()`的功能,可以在`setup()`函数中使用`onMounted()`钩子函数。`onMounted()`会在组件实例挂载到DOM后被调用,相当于Vue 2中的`created()`。你可以在`onMounted()`中执行需要在组件创建后立即执行的操作。 下面是一个示例代码,展示了如何使用`onMounted()`来实现类似于`created()`的功能: ```javascript <script lang="ts" setup> import { onMounted } from 'vue' onMounted(() => { // 在组件实例挂载到DOM后执行的操作 console.log('Component created') }) </script> ``` 在上面的代码中,`onMounted()`钩子函数中的回调函数会在组件实例挂载到DOM后被调用,你可以在其中执行你需要的操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [keylime:用JavaScript处理原型的好方法](https://download.csdn.net/download/weixin_42117032/18918167)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [关于vue3Setup语法糖的拙见以及实际运用](https://blog.csdn.net/Web_Sam/article/details/127276270)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值