Java中如何计算一段程序的运行时间

计算一段程序的运行时间,通常可以使用Java中的System.currentTimeMillis()方法来实现。具体步骤如下:

  1. 在程序的开始处,调用System.currentTimeMillis()方法记录下当前时间值。
long startTime = System.currentTimeMillis();
  1. 在程序的结束处,再次调用System.currentTimeMillis()方法记录下当前时间值。
long endTime = System.currentTimeMillis();
  1. 计算程序的运行时间,可以通过endTime-startTime计算得到。
long runTime = endTime - startTime;

其中,runTime的单位是毫秒(ms),如果需要转换成秒(s),可以除以1000。

以下是两个示例:

示例一:计算排序算法的运行时间

public static void bubbleSort(int[] arr) {
    int n = arr.length;
    for (int i = 0; i < n - 1; i++) {
        for (int j = 0; j < n - i - 1; j++) {
            if (arr[j] > arr[j + 1]) {
                int temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
}

public static void main(String[] args) {
    int[] arr = {3, 1, 4, 1, 5, 9, 2, 6, 5, 3};
    long startTime = System.currentTimeMillis();
    bubbleSort(arr);
    long endTime = System.currentTimeMillis();
    long runTime = endTime - startTime;
    System.out.println("运行时间:" + runTime + "ms");
}

输出结果为:运行时间:0ms

示例二:计算递归算法的运行时间

public static int fibonacci(int n) {
    if (n == 0) {
        return 0;
    } else if (n == 1) {
        return 1;
    } else {
        return fibonacci(n - 1) + fibonacci(n - 2);
    }
}

public static void main(String[] args) {
    int n = 10;
    long startTime = System.currentTimeMillis();
    int result = fibonacci(n);
    long endTime = System.currentTimeMillis();
    long runTime = endTime - startTime;
    System.out.println(n + "的斐波那契数列结果为:" + result);
    System.out.println("运行时间:" + runTime + "ms");
}

输出结果为:10的斐波那契数列结果为:55 运行时间:1ms

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Java中如何计算一段程序的运行时间 - Python技术站

(0)
上一篇 2023年5月20日
下一篇 2023年5月20日

相关文章

  • 基于springboot实现一个简单的aop实例

    基于Spring Boot实现一个简单的AOP实例 AOP(Aspect-Oriented Programming)是一种编程范式,它可以将横切关注点(如日志、事务、安全等)从业务逻辑中分离出来,使得代码更加清晰、易于维护。Spring Boot提供了强大的AOP支持,本文将介绍如何基于Spring Boot实现一个简单的AOP实例。 1. 创建Spring…

    Java 2023年5月14日
    00
  • Java语言中flush()函数作用及使用方法详解

    Java语言中flush()函数作用及使用方法详解 1. flush()函数的作用 在Java语言中,flush()函数用于清空输出流缓冲区,强制将缓冲区的内容输出到目标位置(比如文件、网络等)。具体来说,flush()函数将输出流中的所有缓冲数据都写入到目标位置,同时清空缓冲区,保证数据能够及时地被输出到目标位置。在输出流关闭之前,我们经常需要调用flus…

    Java 2023年5月26日
    00
  • Java Apache Commons报错“ArrayIndexOutOfBoundsException”的原因与解决方法

    当使用Java的Apache Commons类库时,可能会遇到“ArrayIndexOutOfBoundsException”错误。这个错误通常由以下原因之一起: 数组下标越界:如果数组下标越界,则可能会出现此错误。在这种情况下,需要检查数组下标以解决此问题。 数组为空:如果数组为空,则可能会出现此错误。在这种情况下,需要检查数组是否为空以解决此问题。 以下…

    Java 2023年5月5日
    00
  • Maven的生命周期与自定义插件实现方法

    Maven是一款流行的Java项目管理工具,旨在统一、规范Java项目的构建和管理。Maven的生命周期是Maven的基本工作单元,包括了一系列阶段,而自定义插件则是扩展了Maven的功能,能够满足我们在项目构建中的特殊需求。下面我们来详细讲解Maven的生命周期和自定义插件实现方法。 Maven的生命周期 Maven的生命周期是Maven的核心,是构建过程…

    Java 2023年5月20日
    00
  • SpringBoot统计、监控SQL运行情况的方法详解

    关于SpringBoot统计、监控SQL运行情况的方法,可以采用以下两种方式实现: 1. 使用Druid Spring Boot Starter Druid Spring Boot Starter是阿里巴巴为了简化Druid在Spring Boot中的配置而推出的开箱即用的库。它基于Druid DataSource和Spring Boot自动配置机制,并提供…

    Java 2023年5月20日
    00
  • 如何在Springboot实现拦截器功能

    在Spring Boot中,我们可以通过实现拦截器来实现对请求的拦截和处理。本文将详细讲解如何在Spring Boot中实现拦截器功能,并提供两个示例。 1. 创建拦截器 我们可以通过实现HandlerInterceptor接口来创建拦截器。以下是创建拦截器的基本流程: 创建一个拦截器类。 public class MyInterceptor impleme…

    Java 2023年5月15日
    00
  • java并发编程中ReentrantLock可重入读写锁

    ReentrantLock是Java并发编程中一种可重入的读写锁,它比Synchronized更加灵活,能够满足不同的场景需求。下面我们来详细讲解如何使用ReentrantLock读写锁。 1. ReentrantLock的基本使用 1.1 创建ReentrantLock对象 import java.util.concurrent.locks.Reentra…

    Java 2023年5月26日
    00
  • JS+DIV+CSS实现仿表单下拉列表效果

    下面是JS+DIV+CSS实现仿表单下拉列表效果的完整攻略: 一、实现思路 在HTML中定义一个表单元素 使用CSS美化表单元素的样式 使用JavaScript控制下拉列表的显示与隐藏,并将选中的值显示到表单元素中 二、具体实现步骤 1. HTML结构 在HTML中定义一个表单元素,并使用div元素模拟下拉列表的选项: <div class=&quot…

    Java 2023年6月15日
    00
合作推广
合作推广
分享本页
返回顶部