粗略讲一下ThreadLocal的使用

晚上九点四十了,离下班还有二十分钟。桌上咖啡已尽,窗外夜色阑珊。其实我也不是经常加班的,今天突然神志不清的坐到十点,与君共勉。不过发现,现在白天整天开会确定requirement,也只有晚上的时间能稍微干点事情了。

闲话不说了,剩下的时间也懒得继续墨迹,想到什么就写点什么把。

其实我的基础是非常松散的,用所谓高手们的话来说,就是经不起推敲,活脱脱小菜鸟一个。用了这么多年java,其实对于多线程的原理心中还是没什么底的。不过好在会用就成,我也从来不打算出个书把自己脑袋印封面上。咱走的是非常规技术路线。

不过很多人不知道ThreadLocal,这是不能被原谅的。

关于ThreadLocal的基本概念和使用网上已经铺天盖地了,这里也不赘述,没啥意思。真想深入的,去看看Spring的底层实现,就可见一斑了。简单的说,ThreadLocal为解决多线程程序的并发问题提供了一种新的思路。使用这个工具类可以很简洁地编写出优美的多线程程序。事实上,ThreadLocal并不是一个“本地线程”,而可以理解为Thread的一个局部变量。在多线程程序运行的时候,每个线程都为同一个访问对象生成一个副本,这样就有效的阻止了线程间的相互影响,提高了并发性。再简单点说,其实这就是典型的拿空间换时间的方式。而多线程通常的另一种解决方式,则反过来,是典型的时间换空间了。怎么取舍,任君采撷。在使用时我们只需通过简单的get set方法就能轻松实现多线程的并发访问了。

另外,ThreadLocal还支持泛型,这是一个相当令人激赏的特性。我们可以用它写出各种精彩的程序,有时,它和java的反射也结合的很不错。

本来想来个例子的,不过,没车了。以后补上吧。下班快乐。

你可能感兴趣的:(spring,多线程,thread)