home *** CD-ROM | disk | FTP | other *** search
/ Reverse Code Engineering RCE CD +sandman 2000 / ReverseCodeEngineeringRceCdsandman2000.iso / RCE / Ebooks / Thinking in Java / c07 / Music4.java < prev    next >
Encoding:
Java Source  |  2000-05-25  |  4.1 KB  |  123 lines

  1. //: Music4.java
  2. //////////////////////////////////////////////////
  3. // Copyright (c) Bruce Eckel, 1998
  4. // Source code file from the book "Thinking in Java"
  5. // All rights reserved EXCEPT as allowed by the
  6. // following statements: You can freely use this file
  7. // for your own work (personal or commercial),
  8. // including modifications and distribution in
  9. // executable form only. Permission is granted to use
  10. // this file in classroom situations, including its
  11. // use in presentation materials, as long as the book
  12. // "Thinking in Java" is cited as the source. 
  13. // Except in classroom situations, you cannot copy
  14. // and distribute this code; instead, the sole
  15. // distribution point is http://www.BruceEckel.com 
  16. // (and official mirror sites) where it is
  17. // freely available. You cannot remove this
  18. // copyright and notice. You cannot distribute
  19. // modified versions of the source code in this
  20. // package. You cannot use this file in printed
  21. // media without the express permission of the
  22. // author. Bruce Eckel makes no representation about
  23. // the suitability of this software for any purpose.
  24. // It is provided "as is" without express or implied
  25. // warranty of any kind, including any implied
  26. // warranty of merchantability, fitness for a
  27. // particular purpose or non-infringement. The entire
  28. // risk as to the quality and performance of the
  29. // software is with you. Bruce Eckel and the
  30. // publisher shall not be liable for any damages
  31. // suffered by you or any third party as a result of
  32. // using or distributing software. In no event will
  33. // Bruce Eckel or the publisher be liable for any
  34. // lost revenue, profit, or data, or for direct,
  35. // indirect, special, consequential, incidental, or
  36. // punitive damages, however caused and regardless of
  37. // the theory of liability, arising out of the use of
  38. // or inability to use software, even if Bruce Eckel
  39. // and the publisher have been advised of the
  40. // possibility of such damages. Should the software
  41. // prove defective, you assume the cost of all
  42. // necessary servicing, repair, or correction. If you
  43. // think you've found an error, please email all
  44. // modified files with clearly commented changes to:
  45. // Bruce@EckelObjects.com. (Please use the same
  46. // address for non-code errors found in the book.)
  47. /////////////////////////////////////////////////
  48.  
  49. // Abstract classes and methods
  50. import java.util.*;
  51.  
  52. abstract class Instrument4 {
  53.   int i; // storage allocated for each
  54.   public abstract void play();
  55.   public String what() {
  56.     return "Instrument4";
  57.   }
  58.   public abstract void adjust();
  59. }
  60.  
  61. class Wind4 extends Instrument4 {
  62.   public void play() {
  63.     System.out.println("Wind4.play()");
  64.   }
  65.   public String what() { return "Wind4"; }
  66.   public void adjust() {}
  67. }
  68.  
  69. class Percussion4 extends Instrument4 {
  70.   public void play() {
  71.     System.out.println("Percussion4.play()");
  72.   }
  73.   public String what() { return "Percussion4"; }
  74.   public void adjust() {}
  75. }
  76.  
  77. class Stringed4 extends Instrument4 {
  78.   public void play() {
  79.     System.out.println("Stringed4.play()");
  80.   }
  81.   public String what() { return "Stringed4"; }
  82.   public void adjust() {}
  83. }
  84.  
  85. class Brass4 extends Wind4 {
  86.   public void play() {
  87.     System.out.println("Brass4.play()");
  88.   }
  89.   public void adjust() { 
  90.     System.out.println("Brass4.adjust()");
  91.   }
  92. }
  93.  
  94. class Woodwind4 extends Wind4 {
  95.   public void play() {
  96.     System.out.println("Woodwind4.play()");
  97.   }
  98.   public String what() { return "Woodwind4"; }
  99. }
  100.  
  101. public class Music4 {
  102.   // Doesn't care about type, so new types
  103.   // added to the system still work right:
  104.   static void tune(Instrument4 i) {
  105.     // ...
  106.     i.play();
  107.   }
  108.   static void tuneAll(Instrument4[] e) {
  109.     for(int i = 0; i < e.length; i++)
  110.       tune(e[i]);
  111.   }
  112.   public static void main(String[] args) {
  113.     Instrument4[] orchestra = new Instrument4[5];
  114.     int i = 0;
  115.     // Upcasting during addition to the array:
  116.     orchestra[i++] = new Wind4();
  117.     orchestra[i++] = new Percussion4();
  118.     orchestra[i++] = new Stringed4();
  119.     orchestra[i++] = new Brass4();
  120.     orchestra[i++] = new Woodwind4();
  121.     tuneAll(orchestra);
  122.   }
  123. } ///:~