zoukankan      html  css  js  c++  java
  • 谜题95:只是些甜点

    本章的大多数谜题都是颇具挑战性的。但是这个不是。下面这个程序会打印出什么呢?如果你相信的话,前2个程序被报告为系统的缺陷[Bug 4157460 4763901]:

    
    public class ApplePie {
    
        public static void main(String[] args) {
    
            int count = 0;
    
            for(int i = 0; i < 100; i++); {
    
                count++;
    
            }
    
            System.out.println(count);
    
        }
    
    }
    
    
    
    import java.util.*;
    
    public class BananaBread {
    
        public static void main(String[] args) {
    
            Integer[] array = { 3, 1, 4, 1, 5, 9 };
    
            Arrays.sort(array, new Comparator<Integer>() {
    
                public int compare(Integer i1, Integer i2) {
    
                    return i1 < i2 ? -1 : (i2 > i1 ? 1 : 0);
    
                }
    
            });
    
           System.out.println(Arrays.toString(array));
    
      }
    
    }
    
    
    
    public class ChocolateCake {
    
        public static void main(String[] args) {
    
             System.out.println(true?false:true == true?false:true);
    
        }
    
    }
    

    如果你受够这些东西了,那么你不需要知道这些愚蠢谜题的详细解释,所以让我们把它们变得又短又甜:

    1,这个程序会打印出1。这是由多余的标号造成的。(分号的恶习?)

    2,这个程序在我们所知道的所有平台实现上都会打印出[3, 1, 4, 1, 5, 9]。从技术上说,程序的输出是未被定义的。它的比较器(comparator)承受着“是头我赢,是尾你输”的综合症。

    3,这个程序会打印出false。它书写的布局和它的操作符的优先级并不匹配。加一些括号可以解决问题。

    这个谜题的教训,也是整本书的教训,就是:不要像我的兄弟那样编码。

  • 相关阅读:
    【做题笔记】P1531 I Hate It
    【做题笔记】[NOIOJ,非NOIp原题]装箱问题
    SPOJ1811 最长公共子串
    洛谷P3975
    AtCoder Regular Contest 099 E
    AtCoder Regular Contest 097 D
    AtCoder Regular Contest 098 E
    AtCoder Regular Contest 098 D
    AtCoder Regular Contest 099 C
    AtCoder Regular Contest 097 C
  • 原文地址:https://www.cnblogs.com/yuyu666/p/9842724.html
Copyright © 2011-2022 走看看