一直以为java的sleep不准,原来是测量方法错了--
一直都是用System.currentTimeMillis()来计算时间差,实际上这是不准确的,
System.currentTimeMillis()的返回有10到15毫秒误差,用来测量Thread.sleep(0)得到的要么是0要么是10或15, 但用System.nanoTime()来测量的话,误差不超过1毫秒.
API 解释:
static long |
currentTimeMillis() 返回以毫秒为单位的当前时间。 |
static long |
nanoTime() 返回最准确的可用系统计时器的当前值,以毫微秒为单位。 |
相关推荐
System.nanoTime() System.currentTimeMillis() SystemClock.uptimeMillis() SystemClock.elapsedRealtime() SystemClock.currentThreadTimeMillis 0、时间的单位: 秒:second 毫秒:Millisecond 微妙:Microsecond...
互联网资讯,技术简介,IT、AI技术,人工智能互联网资讯,技术简介,IT、AI技术,人工智能互联网资讯,技术简介,IT、AI技术,人工智能互联网资讯,技术简介,IT、AI技术,人工智能互联网资讯,技术简介,IT、AI技术...
为了解决 `System.currentTimeMillis()` 的局限性,Java 提供了 `System.nanoTime()` 方法来获取比毫秒更精确的时间。该方法返回自某个固定点以来的纳秒数,通常用于测量时间差,而不是绝对时间。需要注意的是,虽然...
`System.currentTimeMillis()`适合简单场景,`System.nanoTime()`与`TimeUnit`组合提供更高精度,而第三方库如Guava的`Stopwatch`则提供了更友好的API。对于性能敏感的代码,推荐使用专业的性能测试工具和框架进行...
Java 计算程序代码执行时间的方法可以使用 System.currentTimeMillis() 方法和 System.nanoTime() 方法来记录程序的开始和结束时间,从而计算出程序的执行时间。这些方法对于排查性能问题、优化代码执行效率和 debug...
Java 8引入了`System.nanoTime()`方法,它可以提供纳秒级别的计时,相比`System.currentTimeMillis()`更加精确。 ```java public long startTime = System.nanoTime(); // 执行待测代码 public long endTime = ...
在Java中,我们可以使用内置的`System.currentTimeMillis()`或`System.nanoTime()`方法来创建一个简单的秒表功能。本项目名为“miaobiao.rar”,提供了一个用于学习的Java秒表程序,该程序不仅实现了基本的计时功能...
首先,我们可以使用Java内置的`System.currentTimeMillis()`或`nanoTime()`方法来获取当前时间点,以此作为计时起点。在方法执行完毕后,再获取一次当前时间,通过两者之差计算出方法的执行时间。例如: ```java ...
3. **系统时间(System.currentTimeMillis(), System.nanoTime())**:在某些测试中,需要固定或者精确控制时间。System Lambda 可以提供预设的时间值,避免因为系统时间的变化导致测试结果不一致。 4. **安全退出...
根据提供的代码片段,我们可以看到三种不同的计时器实现方法:使用`java.util.Date`、`System.currentTimeMillis()`以及`System.nanoTime()`。下面将分别介绍这三种方法的特点和应用场景。 #### 三、使用`java.util...
总结起来,Java提供了多种工具和方法来测试代码的执行时间,包括`System.currentTimeMillis()`、`System.nanoTime()`、`TimeUnit`以及`Thread.sleep()`等。开发者可以根据具体需求选择合适的方式,对代码进行性能...
总结来说,Java提供了多种计时工具,如`System.currentTimeMillis()`、`Date`类以及`System.nanoTime()`,可以根据实际需求选择合适的计时方法。在实现限时循环时,可以结合这些方法控制循环的执行时间,确保程序...
总结来说,当需要测量Java程序执行时间时,`System.currentTimeMillis()` 是一种简单且适用于大多数场景的方法,而`System.nanoTime()` 则适用于对性能敏感的微基准测试,它提供了更高的精度但不适用于长时间间隔的...
首先,我们来看第一种方法,即通过`System.currentTimeMillis()`方法来获取程序的运行时间。这个方法返回的是自1970年1月1日00:00:00 GMT以来的毫秒数。下面是一个简单的示例: ```java public class Main { ...
在Java或Android中,我们可以使用`System.currentTimeMillis()`或者`System.nanoTime()`来获取当前时间戳,但这两个方法并不能直接提供毫秒级的精确度。为达到毫秒级倒计时,我们需要结合`System.nanoTime()`和`...
Java中的`java.lang.System`类是Java核心库中不可或缺的一部分,它是系统级操作的主要入口点。这个类提供了很多静态字段和...理解并熟练使用`System`类的各种方法,可以帮助开发者更好地操控Java程序与系统资源的交互。
在Java中,`System.currentTimeMillis()`返回的是自1970年1月1日00:00:00 GMT以来的毫秒数,而`nanoTime()`方法虽然返回的是自某个不确定的起点以来的纳秒数,但这个值并不适合直接用来计算时间差,因为它并不与`...
如果需要高精度的时间戳,可以使用`System.nanoTime()`,但请注意它并不直接代表时间,而是微秒级别的系统计时器值,需要适当转换。 3. **示例代码**: - NTP客户端实现: ```java public class NtpClient { ...
此外,如果你希望计时器更为精确,可以考虑使用`System.nanoTime()`代替`System.currentTimeMillis()`,并考虑线程同步问题。以上就是基于Handler的简单计时器实现,希望能为你提供实现“android 秒表计时器”的基础...
对于更高精度的需求,可以考虑使用 `System.nanoTime()`,它提供了纳秒级的时间戳,但需要注意的是,这种时间戳并不表示绝对时间,仅适用于测量相对时间间隔。 #### 5. **性能测试策略** 除了直接测量代码段的执行...