home *** CD-ROM | disk | FTP | other *** search
/ Reverse Code Engineering RCE CD +sandman 2000 / ReverseCodeEngineeringRceCdsandman2000.iso / RCE / Ebooks / Thinking in Java / c11 / petcount2 / PetCount2.java
Encoding:
Java Source  |  2000-05-25  |  4.5 KB  |  126 lines

  1. //: PetCount2.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. // Using Java 1.1 class literals
  50. package c11.petcount2;
  51. import java.util.*;
  52.  
  53. class Pet {}
  54. class Dog extends Pet {}
  55. class Pug extends Dog {}
  56. class Cat extends Pet {}
  57. class Rodent extends Pet {}
  58. class Gerbil extends Rodent {}
  59. class Hamster extends Rodent {}
  60.  
  61. class Counter { int i; }
  62.  
  63. public class PetCount2 {
  64.   public static void main(String[] args) {
  65.     Vector pets = new Vector();
  66.     Class[] petTypes = {
  67.       // Class literals work in Java 1.1+ only:
  68.       Pet.class,
  69.       Dog.class,
  70.       Pug.class,
  71.       Cat.class,
  72.       Rodent.class,
  73.       Gerbil.class,
  74.       Hamster.class,
  75.     };
  76.     try {
  77.       for(int i = 0; i < 15; i++) {
  78.         // Offset by one to eliminate Pet.class:
  79.         int rnd = 1 + (int)(
  80.           Math.random() * (petTypes.length - 1));
  81.         pets.addElement(
  82.           petTypes[rnd].newInstance());
  83.       }
  84.     } catch(InstantiationException e) {}
  85.       catch(IllegalAccessException e) {}
  86.     Hashtable h = new Hashtable();
  87.     for(int i = 0; i < petTypes.length; i++)
  88.       h.put(petTypes[i].toString(),
  89.         new Counter());
  90.     for(int i = 0; i < pets.size(); i++) {
  91.       Object o = pets.elementAt(i);
  92.       if(o instanceof Pet)
  93.         ((Counter)h.get(
  94.           "class c11.petcount2.Pet")).i++;
  95.       if(o instanceof Dog)
  96.         ((Counter)h.get(
  97.           "class c11.petcount2.Dog")).i++;
  98.       if(o instanceof Pug)
  99.         ((Counter)h.get(
  100.           "class c11.petcount2.Pug")).i++;
  101.       if(o instanceof Cat)
  102.         ((Counter)h.get(
  103.           "class c11.petcount2.Cat")).i++;
  104.       if(o instanceof Rodent)
  105.         ((Counter)h.get(
  106.           "class c11.petcount2.Rodent")).i++;
  107.       if(o instanceof Gerbil)
  108.         ((Counter)h.get(
  109.           "class c11.petcount2.Gerbil")).i++;
  110.       if(o instanceof Hamster)
  111.         ((Counter)h.get(
  112.           "class c11.petcount2.Hamster")).i++;
  113.     }
  114.     for(int i = 0; i < pets.size(); i++)
  115.       System.out.println(
  116.         pets.elementAt(i).getClass().toString());
  117.     Enumeration keys = h.keys();
  118.     while(keys.hasMoreElements()) {
  119.       String nm = (String)keys.nextElement();
  120.       Counter cnt = (Counter)h.get(nm);
  121.       System.out.println(
  122.         nm.substring(nm.lastIndexOf('.') + 1) + 
  123.         " quantity: " + cnt.i);
  124.     }
  125.   }
  126. } ///:~