ThredLocal的使用

ThredLocal,即线程变量,是一个以ThreadLocal对象为键、任意对象为值得存储结构。

package cn.com.test;

import java.util.concurrent.TimeUnit;

public class Profiler {

	//第一次get()方法调用时会进行初始化(如果set方法没有调用),每个线程会调用一次
	private static final ThreadLocal<Long> TIME_THREADLOCAL = new ThreadLocal<Long>(){
		protected  Long initialValue(){
			return System.currentTimeMillis();
		}
		};
		
		public static final void begin() {
			TIME_THREADLOCAL.set(System.currentTimeMillis());
	}
		
		public static final long end(){
			return System.currentTimeMillis() - TIME_THREADLOCAL.get();
		}
		
		public static void main(String[] args) throws Exception {
			Profiler.begin();
			TimeUnit.SECONDS.sleep(10);
			System.out.println("cost:" + Profiler.end() + " mills");
		}
}

以上Profiler可以被复用在方法调用耗时统计的功能上,在方法的入口前执行begin()方法,在方法调用后执行end()方法,好处是两个方法的调用不用再一个方法或者类中,比如在AOP(面向切面变成)中,可以在方法调用前的切入点执行begin()方法,而在方法调用后的切入点执行end()方法,这样依旧可以获得方法的执行耗时。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏君赏技术博客

颤抖吧!都在我的魔法下颤抖吧!--------我是 iOS 黑魔法师!

对于子类 B重写父类 A方法 method2在 iOS6.0之后才可以用是错误的,因为父类方法是可以在 iOS5.0就可以用的。

581
来自专栏小樱的经验随笔

C++STL vector详解(杂谈)

介绍 这篇文章的目的是为了介绍std::vector,如何恰当地使用它们的成员函数等操作。本文中还讨论了条件函数和函数指针在迭代算法中使用,如在remove_i...

3539
来自专栏aCloudDeveloper

大神洗礼第二讲——内存对齐相关

Author:bakari       Date:2012.10.22 主要内容:内存对齐相关 1、 温故而知新:防御性编程的应用 防御性编程的详细讲解可见我的...

2058
来自专栏Java学习网

10个常见的 Java 错误及避免方法之第二集(后续持续发布)

当程序缺少关闭大括号(“}”)时,Java代码中就会发生此错误消息。 有时我们可以通过在代码的末尾放置大括号来快速修复错误。

723
来自专栏恰同学骚年

ch01.深入理解C#委托及原理_《没有控件的ASPDONET》

设想,如果我们写了一个厨师做菜方法用来做菜,里面有 拿菜、切菜、配菜、炒菜 四个环节,但编写此方法代码的人想让 配菜 这个环节让调用方法的人实现,换句话说,就是...

663
来自专栏学海无涯

5.逻辑分支

501
来自专栏进击的程序猿

C++奇淫巧技之SFINAE

SFINAE 技术,即匹配失败不是错误,英文Substitution Failure Is Not An Error,其作用是当我们在进行模板特化的时候,会去选...

643
来自专栏Python小屋

Python花式编程案例集锦(5)

问题描述: 输入三个序列,例如:[0.9,0.5,0.7],[0.4,0.6,0.3],[0.5,0.2,0.4],输出三个序列中各取一个相乘后最大的值,以及组...

2665
来自专栏栗霖积跬步之旅

2.2synchronized同步语句块

使用synchronized虽然能够避免不同步的现象出现,但是也会出现弊端,比如代码执行时间过长,那么其他线程就必须等待该线程执行完毕释放锁之后才能拿到锁。 面...

22510
来自专栏数据结构与算法

HDU 3530Subsequence(单调队列)

给出$n$个数,找出最长的区间,使得区间中最大数$-$最小数 $>= m$ 且$<= k$

441

扫码关注云+社区