1. (略)
  2. (略)
  3. (略)
  4. (略)
  5. 创建两个带有默认构造器(空参数列表)的类A和类B。从A中继承产生一个名为C的新,并在C内创建一个B类的成员。不要给C编写构造器。创建一个C类的对象并观察其结果。
    package net.mindview.reusing;
    
    public class A {
    public A(){
    System.out.println("A");
    }
    } package net.mindview.reusing; public class B {
    public B(){
    System.out.println("B");
    }
    } package net.mindview.reusing; public class C extends A {
    B b = new B();
    public static void main(String[] args) {
    C c = new C(); }
    }
  6. (略)
  7. (略)
  8. (略)
  9. 创建一个Root类,令其含有名为Component1、Component 2、Component3的类的各一个实例(这些也由你写)。从Root中派生一个类Stem,也含有上述各“组成部分”。所有的类都应带有可打印出类的相关信息的默认构造器
    package net.mindview.reusing;
    
    public class Root {
    private Component1 c1 = new Component1();
    private Component2 c2 = new Component2();
    private Component3 c3 = new Component3(); public Root() {
    System.out.println("Root");
    System.out.println("Root->c1");
    System.out.println("Root->c2");
    System.out.println("Root->c3");
    } } package net.mindview.reusing; public class Component1 { public Component1() {
    System.out.println("Component1");
    } } package net.mindview.reusing; public class Component2 { public Component2() {
    System.out.println("Component2");
    } } package net.mindview.reusing; public class Component3 { public Component3() {
    System.out.println("Component3");
    } } package net.mindview.reusing; public class Stem extends Root { private Component1 c1 = new Component1();
    private Component2 c2 = new Component2();
    private Component3 c3 = new Component3();
    public Stem() {
    System.out.println("RootChild");
    System.out.println("Stem->c1");
    System.out.println("Stem->c2");
    System.out.println("Stem->c3");
    } public static void main(String[] args) {
    Root t = new Stem(); } }
  10. (略)可参考总结中的第5点,使用代理模式。
  11. (略)
  12. (略)
  13. (略)
  14. 在Car.java中给Engine添加一个service(),并在main()中调用该方法。
    package net.mindview.reusing;
    
    class Engine {
    public void start(){}
    public void rev(){}
    public void stop(){}
    public void Service() {
    System.out.println("Engine.Service");
    }
    } class Wheel {
    public void inflate(int psi){}
    } class Window{
    public void rollup(){}
    public void rolldown(){}
    } class Door{
    public Window window = new Window();
    public void open(){}
    public void close(){}
    } public class Car {
    public Engine engine = new Engine();
    public Wheel[] wheels = new Wheel[];
    public Door left = new Door(),right = new Door();
    public Car(){
    for(int i=;i<; i++){
    wheels[i] = new Wheel();
    }
    }
    public static void main(String[] args) {
    Car car = new Car();
    car.left.window.rollup();
    car.wheels[].inflate();
    car.engine.Service();
    }
    }
  15. (略)
  16. 创建一个名为Amphibian的类,由此继承产生一个成为Frog的类,在基类中设置适当的方法,在main()中,创建一个Frog向上转型至Amphibian, 然后说明所有方法都可工作
    package net.mindview.reusing;
    
    //两栖动物
    class Amphibian{
    //交配
    public void mating(Amphibian amphibian){
    System.out.println("两栖动物交配");
    }
    }
    //青蛙
    public class Frog extends Amphibian{ public static void main(String[] args) {
    Frog frog = new Frog();
    frog.mating(frog); }
    }
  17. 修改练习16,使Frog覆盖基类中方法的定义。请留心main中都发生了什么
    package net.mindview.reusing;
    
    //两栖动物
    class Amphibian{
    //交配
    public void mating(Amphibian amphibian){
    System.out.println("两栖动物交配");
    }
    }
    //青蛙
    public class Frog extends Amphibian{
    public void mating(Frog frog){
    System.out.println("青蛙交配");
    }
    public static void main(String[] args) {
    Frog frog = new Frog();
    frog.mating(frog); }
    }
  18. (略)
  19. (略)

java编程思想第四版第七章习题的更多相关文章

  1. Java编程思想第四版*第七章*个人练习

    欢迎加群:239063848 成团的笔记:该组仅用于技术共享和交流,问题和答案公布 潘基聊天.禁止广告.禁止招聘-- 练习1:(2)创建一个简单的类.第二个类中,将一个引用定义为第一个类的对象.运用惰 ...

  2. java编程思想第四版第七章总结

    1. 实现类的复用通常有两种方式 组合:在新的类中产生现有类的对象 继承:按照现有类的类型来创造新类 2. 一个特殊的方法toString() 在非基本类型的对象中, 都有toString()方法 当 ...

  3. java编程思想第四版第十一章习题

    第一题 package net.mindview.holding.test1; import java.util.ArrayList; import java.util.List; /** * 沙鼠 ...

  4. java编程思想第四版第六章习题

    (略) (略) 创建两个包:debug和debugoff,他们都包含一个相同的类,该类有一个debug()方法,第一个版本显示发送给控制台的String参数,而第二版本什么也不做,使用静态import ...

  5. java编程思想第四版第五章习题

    创建一个类, 它包含一个未初始化的String引用.验证该引用被Java初始化成了null package net.mindview.initialization; public class Test ...

  6. java编程思想第四版第十三章字符串 习题

    fas 第二题 package net.mindview.strings; import java.util.ArrayList; import java.util.List; /** * 无限循环 ...

  7. java编程思想第四版第六章总结

    1. 代码重构 为什么f要代码重构 第一次代码不一定是完美的, 总会发现更优雅的写法. 代码重构需要考虑的问题 类库的修改不会破坏客户端程序员的代码. 源程序方便扩展和优化 2. 包 创建一个独一无二 ...

  8. java编程思想 第四版 第六章 个人练习

    欢迎加群:239063848 进群须知:本群仅用于技术分享与交流.问题公布与解答 禁止闲聊.非诚勿扰 练习1:(1)在某个包中创建一个类,在这个类所处的包的外部创建该类的一个实例. import mi ...

  9. java编程思想第四版第十三章字符串 总结

    1. String和StringBulider的使用 通过书中介绍, 我们得知如下结论: 当使用+连接符将字符串进行拼接的时候, 编译器会进行自动优化为使用StringBuilder连接字符串. 当在 ...

随机推荐

  1. PMBOK(第六版) PMP笔记——《十三》第十三章(项目干系人管理)

    PMBOK(第六版) PMP笔记——<十三>第十三章(项目干系人管理) 第十三章 项目干系人管理: 了解干系人的需要和期望.解决实际发生的问题.管理利益冲突.促进干系人合理参与 项目决策和 ...

  2. luoguP1006 传纸条

    题目描述 Description 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个 m" role="presentation& ...

  3. [GDKOI2016]染色大战

    Description

  4. 图像处理笔记(二十一):halcon在图像处理中的运用

    概要: 分水岭算法做图像分割 二维码识别 稍后将其他几篇笔记全都补充上概要方便查询. 分水岭算法做图像分割 使用距离变换结合分水岭算法实现图像分割,可以用来分割仅通过阈值分割还是有边缘连接在一起的情况 ...

  5. mysql 二十余种报错注入姿势

    1.floor()  floor 和group by 搭配使用 利用group by 的key唯一性 和mysql 编码执行顺序导致二次执行产生不同key ))) ) 数值型注入时 不用闭合‘  进行 ...

  6. dos命令创建批处理脚本

    win+r  打开cmd 输入 copy con  1.bat 回车 进入编辑状态输入 @echo off echo xxxx Ctrl+z 结束编辑   会在当前目录生成一个bat文件

  7. JavaScript ES6函数式编程(三):函子

    前面二篇学习了函数式编程的基本概念和常见用法.今天,我们来学习函数式编程的最后一个概念--函子(Functor). 相信有一部分同学对这个概念很陌生,毕竟现在已经有很多成熟的轮子,基本能满足我们日常的 ...

  8. 热烈祝贺达孚电子(NDF)网站上线

    尊敬的客户: 您们好! 为适应公司发展的需要,树立公司的良好形象,满足大家更多的了解电容器系列产品及公司的服务,经过1个多月的筹备,在2019年10月21日公司网站正式上线啦,这标志着NDF(达孚电子 ...

  9. git jenkins 基本部署 jenkins持续集成

    1.什么是持续集成?  持续集成来简化我们的工作 还能让产品可以快速迭代,同时还能保持代码高质量产出.2.Jenkins的安装配置:        [root@jenkins ~]# yum inst ...

  10. 二叉树的查找(前序、中序、后序、层序遍历)--biaobiao88

    建立一棵含有n个结点的二叉树,采用二叉链表存储: 输出前序.中序.后序..层序遍历该二叉树的遍历结果. 定义二叉树的数据类型——二叉树结点结构体BiNode.建立二叉链表可以采用扩展二叉树的一个遍历序 ...