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

  1. //: BitManipulation.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 the bitwise operators
  50. import java.util.*;
  51.  
  52. public class BitManipulation {
  53.   public static void main(String[] args) {
  54.     Random rand = new Random();
  55.     int i = rand.nextInt();
  56.     int j = rand.nextInt();
  57.     pBinInt("-1", -1);
  58.     pBinInt("+1", +1);
  59.     int maxpos = 2147483647;
  60.     pBinInt("maxpos", maxpos);
  61.     int maxneg = -2147483648;
  62.     pBinInt("maxneg", maxneg);
  63.     pBinInt("i", i);
  64.     pBinInt("~i", ~i);
  65.     pBinInt("-i", -i);
  66.     pBinInt("j", j);
  67.     pBinInt("i & j", i & j);
  68.     pBinInt("i | j", i | j);
  69.     pBinInt("i ^ j", i ^ j);
  70.     pBinInt("i << 5", i << 5);
  71.     pBinInt("i >> 5", i >> 5);
  72.     pBinInt("(~i) >> 5", (~i) >> 5);
  73.     pBinInt("i >>> 5", i >>> 5);
  74.     pBinInt("(~i) >>> 5", (~i) >>> 5);
  75.  
  76.     long l = rand.nextLong();
  77.     long m = rand.nextLong();
  78.     pBinLong("-1L", -1L);
  79.     pBinLong("+1L", +1L);
  80.     long ll = 9223372036854775807L;
  81.     pBinLong("maxpos", ll);
  82.     long lln = -9223372036854775808L;
  83.     pBinLong("maxneg", lln);
  84.     pBinLong("l", l);
  85.     pBinLong("~l", ~l);
  86.     pBinLong("-l", -l);
  87.     pBinLong("m", m);
  88.     pBinLong("l & m", l & m);
  89.     pBinLong("l | m", l | m);
  90.     pBinLong("l ^ m", l ^ m);
  91.     pBinLong("l << 5", l << 5);
  92.     pBinLong("l >> 5", l >> 5);
  93.     pBinLong("(~l) >> 5", (~l) >> 5);
  94.     pBinLong("l >>> 5", l >>> 5);
  95.     pBinLong("(~l) >>> 5", (~l) >>> 5);
  96.   }
  97.   static void pBinInt(String s, int i) {
  98.     System.out.println(
  99.       s + ", int: " + i + ", binary: ");
  100.     System.out.print("   ");
  101.     for(int j = 31; j >=0; j--)
  102.       if(((1 << j) &  i) != 0)
  103.         System.out.print("1");
  104.       else
  105.         System.out.print("0");
  106.     System.out.println();
  107.   }
  108.   static void pBinLong(String s, long l) {
  109.     System.out.println(
  110.       s + ", long: " + l + ", binary: ");
  111.     System.out.print("   ");
  112.     for(int i = 63; i >=0; i--)
  113.       if(((1L << i) & l) != 0)
  114.         System.out.print("1");
  115.       else
  116.         System.out.print("0");
  117.     System.out.println();
  118.   }
  119. } ///:~