这是并发系列第10篇文章. 什么是线程安全? 当多个线程去访问同一个类(对象或方法)的时候,该类都能表现出正常的行为(与自己预想的结果一致),那我们就可以所这个类是线程安全的. 看一段代码: package com.itsoku.chat04; /** * 微信公众号:路人甲Java,专注于java技术分享(带你玩转 爬虫.分布式事务.异步消息服务.任务调度.分库分表.大数据等),喜欢请关注! */ public class Demo1 { static int num = 0; public…
1. 本章学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结异常与多线程相关内容. 1.守护线程:setDaemon(true or false),如果所有前台线程死亡,守护线程自动结束,一般是一些用来提示信息的线程. 2.线程休眠:静态方法sleep(long million)可以让正在执行的线程暂停一段时间,进入休眠等待的状态. 3.线程让步:yield()方法暂停正在运行的线程,不会阻塞线程. 4.线程插队:join()方法阻塞调用的线程,直到被join()方法加入的线程完成后,调…
20172319 2018.05.09-05.21 <Java程序设计教程>第10周学习总结 目录 教材学习内容总结 教材学习中的问题和解决过程 代码调试中的问题和解决过程 代码托管 上周考试错题总结 结对及互评 其他(感悟.思考等,可选) 学习进度条 参考资料 教材学习内容总结 第十三章 集合: 13.1 集合与数据结构:       集合: 一种对象,类似保存其他对象的存储库. 13.1.1 集合的同构与异构:     同构: 保存的对象类型相同     异构: 保存的对象类型不同 13.…
死锁 经典的死锁:哲学家进餐问题.5个哲学家 5个筷子 如果没有哲学家都占了一个筷子 互相等待筷子 陷入死锁 数据库设计系统中一般有死锁检测,通过在表示等待关系的有向图中搜索循环来实现. JVM没有死锁检测. 锁顺序死锁 典型的列子:LeftRightDeadLock,多个线程尝试去获取左右的锁.这个和哲学家吃饭的两个筷子类似. 下面的转账锁顺序死锁: public class DynamicOrderDeadlock {    public static void transferMoney(…
前言 这两年,tomcat慢慢在新项目里不怎么接触了,因为都被spring boot之类的框架封装进了内部,成了内置server,不用像过去那样打个war包,再放到tomcat里部署了. 但是,内部的机制我们还是有必要了解的,尤其是线程模型和classloader,这篇我们会聚焦线程模型. 其实我本打算将一个问题,即大家知道,我们平时最终写的controller.service那些业务代码,最终是由什么线程来执行的呢? 大家都是debug过的人,肯定知道,线程名称大概如下: http-nio-8…
要想解决“脏数据”的问题,最简单的方法就是使用synchronized关键字来使run方法同步,代码如下: public synchronized void run() { ... } 从上面的代码可以看出,只要在void和public之间加上synchronized关键字,就可以使run方法同步,也就是说,对于同一个Java类的对象实例,run方法同时只能被一个线程调用,并当前的run执行完后,才能被其他的线程调用.即使当前线程执行到了run方法中的yield方法,也只是暂停了一下.由于其他线…
1.语法:必须比较熟悉,在写代码的时候IDE的编辑器对某一行报错应该能够根据报错信息知道是什么样的语法错误并且知道任何修正. 2.命令:必须熟悉JDK带的一些常用命令及其常用选项,命令至少需要熟悉:appletviewer. HtmlConverter.jar. java.javac.javadoc.javap.javaw.native2ascii.serialver,如果这些命令你没有全部使用过,那么你对java实际上还很不了解. 3.工具:必须至少熟练使用一种IDE的开发工具,例如Eclip…
Web Workers API - Web API 接口参考 | MDNhttps://developer.mozilla.org/zh-CN/docs/Web/API/Web_Workers_API 通过使用Web Workers,Web应用程序可以在独立于主线程的后台线程中,运行一个脚本操作.这样做的好处是可以在独立线程中执行费时的处理任务,从而允许主线程(通常是UI线程)不会因此被阻塞/放慢. Web Workers 概念与用法 使用构造函数(例如,Worker())创建一个 worker…
当用Synchronized修饰某个方法的时候,表示该方法都对当前对象加锁. 给方法加Synchronized和用Synchronized修饰对象的效果是一致的. 一个线程可以拿到多个锁标记,一个对象最多只能将monitor给一个线程. Synchronized是以牺牲程序运行的效率为代价的,因此应该尽量控制互斥代码块的范围. 方法的Synchronized特性本身不会被继承,只能覆盖. 线程因为未拿到锁标记而发生的阻塞不同于前面五个基本状态中的阻塞,称为锁池. 每个对象都有自己的一个锁池的空间…
1.Object类中的wait()/notify()/notifyAll() wait(): 让当前线程处于Waiting状态并释放掉持有的对象锁,直到其他线程调用此对象的线程notify()/notifyAll()方法,当前线程被唤醒进入Runnable状态 .**wait(long timeout):**让当前线程处于Timed Waiting状态并释放掉持有的对象锁,直到其他线程调用此对象的线程notify()/notifyAll()方法或者时间到期,当前线程被唤醒进入Runnable状态…