统计方法运行时间【Java实现】
接口Command:定义命令的执行操作
package common; public interface Command { // 运行方法
void run(); }
CommandRuntime 类:统计命令运行时间,使用命令模式
package common; public class CommandRuntime { private Command command; public CommandRuntime(Command command)
{
this.command = command;
} public long runtime() { long start = System.currentTimeMillis();
command.run();
long end = System.currentTimeMillis(); return end-start;
} }
CombinationCommand: 解决组合问题的命令, 采用类适配器模式:
package algorithm.problems; import algorithm.permutation.Combination; import common.Command; public class CombinationCommand extends Combination implements Command { public CombinationCommand(int n) {
super(n);
} public void run() {
solution();
} }
CombinationRuntime: 测量组合问题的运行时间
package algorithm.problems; import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException; import common.CommandRuntime; public class CombinationRuntime { public static void main(String[] args)
{
try {
BufferedWriter fileWriter = new BufferedWriter(new FileWriter("runtime.txt"));
fileWriter.write("runtime: ");
fileWriter.newLine();
for (int i=1; i < 30; i++) {
CommandRuntime comRuntime = new CommandRuntime(new CombinationCommand(i));
long runtime = comRuntime.runtime();
fileWriter.write( "n = " + i + " : " + runtime + " ms");
fileWriter.newLine();
}
System.out.println("over.");
fileWriter.close(); } catch (IOException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
} } }
另外一种使用反射机制实现的运行时间测量框架:
package common; import java.lang.reflect.Constructor;
import java.lang.reflect.Method; public class RuntimeMeasurement { public RuntimeMeasurement(int maxsize) {
this.maxsize = maxsize;
time = new double[maxsize];
} // 问题最大规模: 以 10 的 size 次幂计
private int maxsize ; // 运行时间以 ms 计
private double[] time ; /**
* measureTime : 对指定类型的对象调用指定参数列表的指定方法,并测量其运行时间
* @param type 指定对象类型,必须有一个 参数类型为 int 的公共构造器方法
* @param methodName 指定测试方法名称,要求是空参数列表
*/
public void measureTime(Class<?> type, String methodName)
{
try {
Constructor<?> con = type.getConstructor(int.class);
Method testMethod = null;
for (int i = 0; i < time.length; i++) {
Object obj = con.newInstance(power10(i+1));
testMethod = type.getMethod(methodName, new Class<?>[]{});
long start = System.nanoTime();
testMethod.invoke(obj, new Object[] {});
long end = System.nanoTime();
time[i] = ((end - start) / (double)1000000) ;
} } catch (Exception e) {
e.printStackTrace();
System.out.println(e.getMessage());
} } /**
* showTime : 显示已经测量获得的运行时间,在 measureTime 方法调用后调用该方法。
*/
public void showTime()
{
for (int i=0; i < time.length; i++) {
System.out.printf("n = %12d : " , power10(i+1));
System.out.printf("%12.3f\n", time[i]);
}
} private int power10(int n)
{
int result = 1;
while (n > 0) {
result *= 10;
n--;
}
return result;
} }
统计方法运行时间【Java实现】的更多相关文章
- java监测方法运行时间/效率方法
前言: 这周在写一个小项目,虽然小但是是纯调外部接口的,调完了接口还不停的循环接口返回的数据(已转换JSONArray),然后再判断值,再做不同处理,关键是数据量还比较大,这刚做完还没开始上线,测试也 ...
- 对于应用需要记录某个方法耗时的场景,必须使用clock_gettime传入CLOCK_MONOTONIC参数,该参数获得的是自系统开机起单调递增的纳秒级别精度时钟,相比gettimeofday精度提高不少,并且不受NTP等外部服务影响,能准确更准确来统计耗时(java中对应的是System.nanoTime),也就是说所有使用gettimeofday来统计耗时(java中是System.curre
对于应用需要记录某个方法耗时的场景,必须使用clock_gettime传入CLOCK_MONOTONIC参数,该参数获得的是自系统开机起单调递增的纳秒级别精度时钟,相比gettimeofday精度提高 ...
- spring3.0框架检测方法运行时间测试(转)
主要利用了Spring AOP 技术,对想要统计的方法进行横切处理,方法执行前开始计时,方法执行后停止计时,得到计时方法就是该方法本次消耗时间. 步骤: 首先编写自己的Interceptor类来实现M ...
- 成绩统计程序(Java)
我的程序: package day20181018;/** * 成绩统计系统 * @author Administrator */import java.util.Scanner;//提供计算机直接扫 ...
- ASP.net中网站访问量统计方法代码(在线人数,本月访问,本日访问,访问流量,累计访问)
一.建立一个数据表IPStat用于存放用户信息 我在IPStat表中存放的用户信息只包括登录用户的IP(IP_Address),IP来源(IP_Src)和登录时间 (IP_DateTime),些表的信 ...
- 记一次使用修改字节码的方法解决java.lang.NoSuchMethodError
接兔兔国际sdk ane 充值界面选择兔币充值就会闪退, 观察logcat 04-19 10:10:54.224: E/AndroidRuntime(20315): FATAL EXCEPTION: ...
- JAVA写JSON的三种方法,java对象转json数据
JAVA写JSON的三种方法,java对象转json数据 转自:http://www.xdx97.com/#/single?bid=5afe2ff9-8cd1-67cf-e7bc-437b74c07a ...
- maven 在clean package时,出现:找不到符号 [ERROR] 符号: 方法 sqlDdlFilter(java.lang.String) 解决办法
另一个项目中增加了,sqlDdlFilter 在调用的项目中clean package时,出现 找不到符号[ERROR] 符号: 方法 sqlDdlFilter(java.lang.String) 原 ...
- 基于git命令的代码统计方法
基于git命令的代码统计方法 没什么好说的,基于git log命令,使用前提是安装了git ...... .统计所有人代码量 统计所有人代码增删量,拷贝如下命令,直接在git bash等终端,git项 ...
随机推荐
- CENTOS安装ElasticSearch
原文链接:https://my.oschina.net/topeagle/blog/591451?fromerr=mzOr2qzZ CENTOS安装ElasticSearch ElasticSearc ...
- 在jmeter测试中模拟不同的带宽环境
怎么去测试在手机app中和在web的不同的连接速度对服务器的影响呢? 大部分情况下,手机终端用户通过移动网络访问网站.所以在不同的网络连接数据下,我们的网站或程序可以同时处理多少链接?今天,这篇文件就 ...
- CSS 盒子模型 二
Sublime 快捷键: 文件保存后,输入 html:xt + tab ,补全html html:xt <!DOCTYPE html PUBLIC "-//W3C//DTD XHTM ...
- 有向图的强联通tarjan算法(判断是否为强联通模板)(hdu1269)
hdu1269 迷宫城堡 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Tot ...
- Redis+Keepalived实现高可用
使用redis哨兵可以在主服务器出现故障的时候自动切换主从,但是从服务器的IP不同于原主服务器的IP还需要在客户端手动修改IP才能生效 下面使用keepalived实现VIP自动漂移 keepaliv ...
- POJ--3321 Apple Tree(树状数组+dfs(序列))
Apple Tree Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 22613 Accepted: 6875 Descripti ...
- N-N
---情景--- 关系:角色N-N区域 基础表:角色表.区域表 关系表:主键-角色id-区域id集 ---需求--- 实现“单个区域勾选角色”且不借助与非SQL脚本(php etc)遍历 ---疑惑- ...
- 可视化url
http://blog.csdn.net/u011532367/article/list/1
- 【HTML5】初识HTML5
HTML5 简介 HTML5是HTML最新的修订版本,2014年10月由万维网联盟(W3C)完成标准制定. HTML5的设计目的是为了在移动设备上支持多媒体. HTML5 简单易学. HTML5 是下 ...
- 了解Linux的进程与线程
了解Linux的进程与线程 http://timyang.net/linux/linux-process/ 上周碰到部署在真实服务器上某个应用CPU占用过高的问题,虽然经过tuning, 问题貌似已经 ...