ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

java – 为什么打印“B”比打印“#”要慢得多?

2019-09-25 22:02:43  阅读:237  来源: 互联网

标签:java performance loops for-loop system-out


我生成了两个1000 x 1000的矩阵:

第一个矩阵:O和#.
第二个矩阵:O和B.

使用以下代码,第一个矩阵需要8.52秒才能完成:

Random r = new Random();
for (int i = 0; i < 1000; i++) {
    for (int j = 0; j < 1000; j++) {
        if(r.nextInt(4) == 0) {
            System.out.print("O");
        } else {
            System.out.print("#");
        }
    }

   System.out.println("");
 }

使用此代码,第二个矩阵需要259.152秒才能完成:

Random r = new Random();
for (int i = 0; i < 1000; i++) {
    for (int j = 0; j < 1000; j++) {
        if(r.nextInt(4) == 0) {
            System.out.print("O");
        } else {
            System.out.print("B"); //only line changed
        }
    }

    System.out.println("");
}

运行时间大不相同的原因是什么?

正如评论中所建议的那样,只打印System.out.print(“#”);需要7.8871秒,而System.out.print(“B”);仍然打印….

正如其他人指出它通常适用于他们一样,例如我尝试了Ideone.com,并且两段代码以相同的速度执行.

测试条件:

>我从Netbeans 7.2运行此测试,输出到其控制台
>我使用System.nanoTime()进行测量

解决方法:

纯粹的推测是你使用的终端尝试做word-wrapping而不是字符包装,并将B视为单词字符,但将#视为非单词字符.因此,当它到达一条线的末端并寻找一条断线的地方时,它几乎立刻就会看到#并在那里快乐地打破;而对于B,它必须继续搜索更长的时间,并且可能有更多的文本要包装(在某些终端上可能很昂贵,例如,输出退格,然后输出空格以覆盖被包裹的字母).

但那是纯粹的猜测.

标签:java,performance,loops,for-loop,system-out
来源: https://codeday.me/bug/20190925/1817088.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有