Spring中的计时器StopWatch

 

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。

需要记录每个任务执行时间,或者记录一段代码执行时间,简单方法是打印当前时间与执行完时间的差值,若执行大量测试很麻烦并且不直观。若想对执行时间做进一步控制,则需要在程序中很多地方修改。spring-framework提供了一个StopWatch类可以做类似任务执行时间控制。

 

 

[java] view plain copy
 print?
  1. StopWatch sw = new StopWatch();  
  2. sw.start();  
  3. // 业务操作  
  4. sw.stop();  
  5. logger.info("耗时间:" + sw.getTotalTimeMillis());  

 

2 配合拦截器

在filter中用spring StopWatch来统计每个请求的执行时间。在filter的doFilter中加入如下代码:

 

 

 

[java] view plain copy
 print?
  1. StopWatch stopWatch = new StopWatch(url+System.currentTimeMillis());    
  2. stopWatch.start();    
  3. doFilter(arg0,arg1);    
  4. opWatch.stop();    
  5. loginfo(stopWatch.getTotalTimeMillis()+"---"+request.getRequestURI()+"执行时间");  

从源代码构造看出,StopWatch根据id构造对象,确保构造id唯一即可区分不同的请求。

 

 

[java] view plain copy
 print?
  1. public StopWatch() {   
  2.     keepTaskList = true;    
  3.     taskList = new LinkedList();    
  4.     id = "";    
  5. }    
  6.     
  7. public StopWatch(String id) {    
  8.     keepTaskList = true;    
  9.     taskList = new LinkedList();    
  10.     this.id = id;    
  11. }  

 

原贴地址:

http://blog.csdn.net/linfssay/article/details/7680323
http://blog.csdn.net/u012186154/article/details/54923210

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/451415.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

常用数据结构--线性结构

数据结构是计算机存储、组织数据的方式。常见的数据结构分类方式如下图: 常用的线性结构有:线性表,栈,队列,循环队列,数组。线性表中包括顺序表、链表等,其中,栈和队列只是属于逻辑上…

依赖注入简介(一)

依赖注入(Injecting dependencies)经常听起来会让人感觉到很难以理解,会让大家感觉这是很复杂的编程技术,但是事实上并不是这样,依赖注入非常方便使用,它会让你的程序非常便于理解,同时也更容易进行测试。 依赖注入的…

Jmeter笔记(Ⅱ)使用Jmeter实现轻量级的接口自动化测试

接口测试虽然作为版本的一环,但是也是有一套完整的体系,有接口的功能测试、性能测试、安全测试;同时,由于接口的特性,接口的自动化低成本高收益的,使用一些开源工具或一些轻量级的方法,在测试用…

设置Android Studio工程布局文件的默认布局

每次创建新的工程后&#xff0c;布局文件的的布局总是ConstraintLayout&#xff0c;如何更改&#xff1f; 进入Android Studio安装目录&#xff0c;用文本编辑器打开文件plugins\android\lib\templates\activities\common\root\res\layout\simple.xml.ftl 将文件内容修改为 <…

依赖注入简介(二)

在上一篇中&#xff0c;我们已经介绍过了最基本的依赖注入&#xff0c;接下来我们来看如何对需要使用的类进行装配。通常应用程序的组件之间的关联是通过wiring&#xff0c;在Spring中同样有很多方式来装配。但是一个最通常我们使用的方法是利用XML。接下来我们来展示一个简单的…

eclipse启动tomcat 访问http://localhost:8080 报404错误

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 eclipse正常启动tomcat&#xff0c;但是 访问http://localhost:8080 却报404错误 修改下配置 就好操作如下图 打开eclipse的server视图&a…

3秒搞定!~~ 一亿数据获取前100个最大值

3秒搞定&#xff01;~~ 一亿数据获取前100个最大值 整合网络上的算法。 根据我的思路。计算一亿个数字中最大的前100个值。 昨晚效率还是很低。 今天搞的算法。 只需要3秒钟。 获取前100个 前1000个 速度都非常快。 算法原理&#xff1a; 把一亿个数字的前100个 首先放入数…

手把手JDK环境变量配置

分为下载&#xff0c;配置&#xff0c;验证三个步骤解释如何进行JDK环境变量配置。 步骤一&#xff1a; 首先查看配置成功后的效果&#xff1a; tip:点击win——>运行&#xff08;或者使用winr,或者shift鼠标右键打开powershell&#xff09;——>输入cmd回车——>控制…

网易NEI在面临前后端分离问题,所提供的完整解决方案

内容来源&#xff1a;2018 年 1 月5 日&#xff0c;网易NEI产品负责人包勇明在“2018移动技术创新大会”进行《网易高效多端应用协作开发实践》演讲分享。IT 大咖说&#xff08;微信id&#xff1a;itdakashuo&#xff09;作为独家视频合作方&#xff0c;经主办方和讲者审阅授权…

如何使用js动态显示或隐藏DIV

在web页面中&#xff0c;经常需要使用select控件来显示div的显示与隐藏&#xff0c;实现这个方法主要用到了setAttribute方法&#xff0c;以下为示例代码 [html] view plaincopy <html> <title>通过选择项显示不同的结果</title> <head> <scr…

myeclipse进入Myeclipse configuration center 如何关闭

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 找到这个图标&#xff0c;放上去显示return即可关闭&#xff0c;隐藏很深有木有

程序员保持身心健康的八种方式

程序员是一个辛苦的行业&#xff0c;长时间面对的只是需要解决的问题&#xff0c;更不要提开发期限和无理取闹的客户了&#xff0c;这样的工作简直无以承受。怎么办呢我们&#xff1f;我们热爱编程&#xff0c;乐于创建功能……我们喜欢那种将一堆代码弄成像Facebook或者Digg那…

[No0000166]CPU的组成结构及其原理

中央处理器(Central Processing Unit, CPU)CPU的基本架构和工作原理其实百科上讲得已经相当清楚了&#xff0c;不过我觉得有些事情呢还是给个例子出来比较方便学习。本文会先从内存地址&#xff0c;计算机的一般架构之类的基础知识出发&#xff0c;然后逐步为读者"拼装&qu…

Java 时间总结

转载请标明出处&#xff1a;http://blog.csdn.net/zhaoyanjun6/article/details/80613024 本文出自【赵彦军的博客】 时区 整个地球分为二十四时区&#xff0c;每个时区都有自己的本地时间。为了统一起见&#xff0c;使用一个统一的时间&#xff0c;称为通用协调时(UTC, Univer…

js中的var是什么意思

声明&#xff08;创建&#xff09; JavaScript 变量 在 JavaScript 中创建变量经常被称为“声明”变量。您可以通过 var 语句来声明 JavaScript 变量&#xff1a;var x; var carname; 在以上声明之后&#xff0c;变量并没有值&#xff0c;不过您可以在声明它们时向变量赋值&…

HTTP/2 协议入门

一、2015年&#xff0c; HTTP/2发布。 二、二进制协议 HTTP/2是一个二进制协议&#xff0c;头信息和数据体都是二进制&#xff0c;并且统称为“帧”&#xff08;frame&#xff09;,头信息帧和数据帧。 二进制协议的一个好处是&#xff0c;可以定义额外的帧。HTTP/2定义了近1…

态度决定高度

“一个将什么都不放在眼里的人&#xff0c;他的未来一定是一片黑暗&#xff0c;因为他什么都看不到”。知识的获得和能力的锻炼是个一点一滴慢慢积累的过程&#xff0c;这个过程需要我们端正态度&#xff0c;俯身求教。好高骛远一直都是很多人容易犯的错误&#xff0c;这样导致…

中间件技术是什么?

&#xff08;一&#xff09;举例说明&#xff1a; 我开了一家炸鸡店&#xff08;业务端&#xff09;&#xff0c;然而周边有太多屠鸡场&#xff08;底层&#xff09;&#xff0c;为了成本我肯定想一个个比价&#xff0c;再综合质量挑选一家屠鸡场合作&#xff08;适配不同底层逻…

4.10/4.11/4.12 lvm讲解 4.13 磁盘故障小案例

2019独角兽企业重金招聘Python工程师标准>>> 准备磁盘分区 fdisk /dev/sdb n 创建三个新分区&#xff0c;分别1G t 改变分区类型为8e 准备物理卷 pvcreate /dev/sdb1 pvcreate /dev/sdb2 pvcreate /dev/sdb3 pvdisplay/pvs 列出当前的物理卷 pvremove /dev/sdb3 删除…

《Effective Java》 第一讲:创建和销毁对象

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 一、用静态工厂方法代替构造器 用静态工厂的优点 &#xff1a; 1. 方法有名字&#xff0c;更好理解。 2.不必每次调用的时候都创建一…