格言:在程序猿界混出点名堂!
《JAVA并发编程实战》解读
【连载】第1章-1.4线程无处不在
回顾:在1.3中介绍了,线程带来的风险,包括安全性问题、活跃性问题还有性能问题,这一小节讲的是线程无处不在。
每个JAVA应用程序都会使用线程。
当JVM启动后,为JVM内部任务(比如垃圾回收器)创建后台线程,并创建一个主线程来运行main方法。可以使用jstack的监控工具打印堆栈日志查看,我只写了一个main方法启动,可以看到有很多的JVM线程。
"main" #1 prio=5 os_prio=31 tid=0x00007f9f3c801800 nid=0x2803 waiting on condition [0x000070000d152000]
java.lang.Thread.State: TIMED_WAITING (sleeping)
at java.lang.Thread.sleep(Native Method)
at cn.kazz.RunOneTask.main(RunOneTask.java:8)
"VM Thread" os_prio=31 tid=0x00007f9f3c83e800 nid=0x5103 runnable
"GC task thread#0 (ParallelGC)" os_prio=31 tid=0x00007f9f3c800800 nid=0x2007 runnable
"GC task thread#1 (ParallelGC)" os_prio=31 tid=0x00007f9f3c81d000 nid=0x2103 runnable
"GC task thread#2 (ParallelGC)" os_prio=31 tid=0x00007f9f3c81d800 nid=0x5403 runnable
"GC task thread#3 (ParallelGC)" os_prio=31 tid=0x00007f9f3c81e000 nid=0x2b03 runnable
"VM Periodic Task Thread" os_prio=31 tid=0x00007f9f3b00a000 nid=0x3a03 waiting on condition
多数Java应用程序都是多线程
多少Java应用程序都是多线程,使用时需要对应用程序的状态(比如内存变量)的访问进行
协同
。
而且一些框架引入了并发性时,通常并发性不仅局限于框架代码。比如下面提到的这些。
-
Timer
Java的工具,作用是在稍后的片刻运行,或者运行一次或者周期性运行。
带来的问题是周期性运行可能改变其他线程访问的共享数据
。也就是说Timer本身就是一个线程,可能存在不安全的操作,最简单的方式解决这种不安全就是把线程安全封装在共享对象内部。AtomicInteger
就是很好的安全封装的例子。 -
Servlet和JSP
Servlet框架属于Web应用程序。有可能同一个Servlet服务同时被多个客户端调用,也就是多线程调用,因此也需要注意线程安全的问题。 -
远程方法调用
就是RMI,跟Dubbo、Thrift等框架类似,这些框架跟Servlet一样,也可以被多个客户端调用,存在访问共享变量的安全性问题,对共享变量也要协同共享对象的状态。
知识点
- 了解这些多线程的框架来体会多线程可能带来的非安全性问题。
喜欢连载可关注
简书
或者微信公众号
:
简书专题:Java并发编程实战-可爱猪猪解读
https://www.jianshu.com/c/ac717321a386
微信公众号:逗哥聊IT
。
网友评论