A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 刘晓 中级黑马   /  2013-6-8 15:12  /  1946 人查看  /  10 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 刘晓 于 2013-6-8 23:12 编辑
  1. class demo
  2. {
  3.         public void getTime()
  4.         {
  5.                 long start=System.currentTimeMillis();
  6.                 for(int x=0;x<100;x++)
  7.                 {
  8.                         System.out.print(x);
  9.                 }
  10.                 long end=System.currentTimeMillis();
  11.                 System.out.println();
  12.                 System.out.print(end-start);
  13.         }
  14. }
复制代码

评分

参与人数 1技术分 +1 收起 理由
黑马伍哲沂 + 1 鼓励个。

查看全部评分

10 个回复

倒序浏览
cup的原因 ,与代码无关 。。
回复 使用道具 举报
OK,谢谢
回复 使用道具 举报
刘凯 发表于 2013-6-8 15:16
cup的原因 ,与代码无关 。。

Ok,谢谢
回复 使用道具 举报
感觉是currentTimeMillis() 的问题,它以毫秒计数返回时间,但是不能保证返回的计数的粒度或精度。在一些系统上,时间是真正的毫 秒计数,大约每一毫秒改变一次。在另一些系统上,时间可能每隔 10 或 20 毫秒才变一 次,因此每一次的精度都可能变化。
我用你的程序实验了一下,在我机子上结果为0

评分

参与人数 1技术分 +1 收起 理由
袁梦希 + 1 很给力!

查看全部评分

回复 使用道具 举报
因为操作系统中同时有很多任务被cpu处理, 每次运行时的环境都不可能是完全相同的。
回复 使用道具 举报
代码相同,但每次运行时,cpu都要同时处理多个进程,你可以调用任务管理器看看,所以每次运行不一定是从头运行到尾,cpu是在多个线程间切换的,一个进程可能要多次获取spu时间片才能运行完。所以每次运行时间不同。

评分

参与人数 1技术分 +1 收起 理由
袁梦希 + 1 很给力!

查看全部评分

回复 使用道具 举报
测试代码运行前的currentTimeMillis当前时间和代码运行后之间的时间差,
系统运行是多线程的,如前面那同学说的是和每次执行Cpu有关,硬件有关哦。
当然了如果你把循环次数改大点,每次误差就会小些,测出的时间也就越接近
这样才符合统计学的基本规律哈{:soso_e113:}

评分

参与人数 1技术分 +1 收起 理由
袁梦希 + 1 很给力!

查看全部评分

回复 使用道具 举报
与底层处理速度有关,和代码的关系不大,代码只是实现了获取时间差的功能
回复 使用道具 举报
李培根 来自手机 金牌黑马 2013-6-9 10:01:59
10#
cpu的问题,cpu的执行效率高,for循环几乎在0毫秒内就执行完了,cpu差一点也可能需要几毫秒的时间。
回复 使用道具 举报
时间是会流动的,就像有位哲人说的,人不可能同一时间踏入同一条河流。。如果是一样的,就是计时器出问题了。。。
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马