美文网首页JavaJava并发编程实战-可爱猪猪解读
【连载】第1章-1.4线程无处不在

【连载】第1章-1.4线程无处不在

作者: 可爱猪猪 | 来源:发表于2019-08-20 21:01 被阅读1次

格言:在程序猿界混出点名堂!

《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一样,也可以被多个客户端调用,存在访问共享变量的安全性问题,对共享变量也要协同共享对象的状态。

知识点

  1. 了解这些多线程的框架来体会多线程可能带来的非安全性问题。

喜欢连载可关注简书或者微信公众号
简书专题:Java并发编程实战-可爱猪猪解读
https://www.jianshu.com/c/ac717321a386
微信公众号:逗哥聊IT

相关文章

  • 【连载】第1章-1.4线程无处不在

    格言:在程序猿界混出点名堂! 《JAVA并发编程实战》解读【连载】第1章-1.4线程无处不在 回顾:在1.3中介绍...

  • JAVA

    1.4 Java的 内存模型 是否线程安全线程安全与cpu资源的抢夺 多线程在读写共享变量时引发的问题 线程的原子...

  • 内存模型

    1.4 Java的 内存模型 是否线程安全线程安全与cpu资源的抢夺多线程在读写共享变量时引发的问题 线程的原子性...

  • jmeter之发送json数据的post请求

    1.1 创建一个线程组 1.2 设置线程组参数 1.3 添加http请求 1.4 修改http请求的内容 1.5 ...

  • 1.4 多线程 - 控制线程

    join() 线程 Thread 提供了让一个线程等待另一个线程完成的方法 —— join() 方法。当在某个程序...

  • iOS | 底层原理分析(二)

    一. 多线程 1.1 ios 多线程方案 1.2GCD的常用函数 1.3 GCD的队列 1.4 容易混淆的术语 1...

  • Concurrent Basic

    Concurrent Basic基础无处不在的线程线程的创建和运行线程的状态和上下文切换线程的监视原子性、内存可见...

  • grpc线程模型

    BIO 线程模型 在 JDK 1.4 推出 Java NIO 之前,基于 Java 的所有 Socket 通信都采...

  • 锋利的jquery 学习笔记

    Menu 第1章 认识jQuery 1.3 jQuery代码的编写 1.4 jQuery对象和DOM对象 1.4....

  • 【连载】第1章-1.2线程的优势

    格言:在程序猿界混出点名堂! 《JAVA并发编程实战》解读【连载】第1章-1.2线程的优势 回顾:在1.1中我们介...

网友评论

    本文标题:【连载】第1章-1.4线程无处不在

    本文链接:https://www.haomeiwen.com/subject/fnymsctx.html