说到volatile,一些参加过面试的同学对此肯定不陌生. 它是面试官口中的常客,但是平时的编码却很少打照面(起码,我是这样的). 最近的面试,我也经常会问到volatile相关的问题,比如volatile和sychronized的区别:volatile的使用场景:volatile的实现原理等等. 问这些问题其实主要还是考察多线程.锁等方便的知识储备.虽然volatile在我们日常编码使用不多,但是他的实现思想以及背后牵扯的一些概念还是值得我们学习和思考的. 举例 首先我们来看一个例子 publ…
上篇<并发和多线程-说说面试常考平时少用的volatile>主要介绍的是volatile的可见性.原子性等特性,同时也通过一些实例简单与synchronized做了对比. 相比较volatile,其实我们应该更加熟悉synchronized,平时开发中接触和使用也更多一些. 那么为什么说synchronized是八面玲珑呢,因为它可以混迹在很多"场所"(方法.代码块),与各种角色(类.对象)打交道. 也正是因为它的八面玲珑,所以就显得比较神秘,也比较复杂,今天就来追踪下sy…
http://www.importnew.com/12773.html     https://blog.csdn.net/u011163372/article/details/73995897   https://juejin.im/post/5b57b81af265da0f4b7a9ae5ImportNew 首页所有文章资讯Web架构基础技术书籍教程Java小组工具资源 Java线程面试题 Top 50 2014/08/21 | 分类: 基础技术 | 27 条评论 | 标签: 多线程, 面试…
该文章是一个系列文章,是本人在Android开发的漫漫长途上的一点感想和记录,如果能给各位看官带来一丝启发或者帮助,那真是极好的. 前言 前一篇Android并发编程开篇呢,主要是简单介绍一下线程以及JMM,虽然文章不长,但却是理解后续文章的基础.本篇文章介绍多线程与锁. 深入认识Java中的Thread Thread的三种启动方式上篇文章已经说了,下面呢,我们继续看看Thread这个类. 线程的状态 Java中线程的状态分为6种. 初始(NEW):新创建了一个线程对象,但还没有调用start(…
今天,我们开始Java高并发与多线程的第四篇,锁. 之前的三篇,基本上都是在讲一些概念性和基础性的东西,东西有点零碎,但是像文科科目一样,记住就好了. 但是本篇是高并发里面真正的基石,需要大量的理解和实践,一环扣一环,环环相扣,不难,但是需要认真去读. 好了,现在开始. --------------第一部分,咱们要谈到java里面的两个用于保证线程之间有序性的关键字-------------- [synchronized] synchronized是Java中解决并发问题的一种最常用的方法,也是…
“高并发和多线程”总是被一起提起,给人感觉两者好像相等,实则 高并发 ≠ 多线程 多线程是完成任务的一种方法,高并发是系统运行的一种状态,通过多线程有助于系统承受高并发状态的实现.   高并发是一种系统运行过程中遇到的一种“短时间内遇到大量操作请求”的情况,主要发生在web系统集中大量访问或者socket端口集中性收到大量请求(例如:12306的抢票情况:天猫双十一活动).该情况的发生会导致系统在这段时间内执行大量操作,例如对资源的请求,数据库的操作等.如果高并发处理不好,不仅仅降低了用户的体验…
首先搞清楚php-fpm与cgi的关系 cgi cgi是一个web server与cgi程序(这里可以理解为是php解释器)之间进行数据传输的协议,保证了传递的是标准数据. php-cgi php-cgi是php解释器,就是上文提到的cgi程序. Fastcgi Fastcgi是用来提高cgi程序(php-cgi)性能的方案/协议. cgi程序的性能问题在哪呢?"PHP解析器会解析php.ini文件,初始化执行环境",就是这里了.标准的CGI对每个请求都会执行这些步骤,所以处理的时间会…
wait.notify.notifyAll 这三个方法都是属于Object的,Java中的类默认继承Object,所以在任何方法中都可以直接调用wait(),notifyAll(),notify(),static方法也一样,new一个对象再调用.这三个方法必须是在获取到monitor锁的前提下使用,也就是使用ReentrantLock这类锁是不行的,只能是synchronized关键字内部,否则会出现IllegalMonitorStateException异常. 1.wait: 作用就是进入阻塞…
启动线程: 从一个最基本的面试题开始,启动线程到底是start()还是run()? Runnable runnable = () -> System.out.println(Thread.currentThread().getName()); Thread thread = new Thread(runnable); thread.run(); thread.start(); 结果: main Thread-0 我们可以看到thread.run()是通过main线程执行的,而start()启动的…
Pythpn并发编程--多线程与协程 目录 Pythpn并发编程--多线程与协程 1. 进程与线程 1.1 概念上 1.2 多进程与多线程--同时执行多个任务 2. 并发和并行 3. Python多线程--futures 3.1 多线程用法 3.2. 为什么多线程每次只允许只能有一个线程执行? 3.3 多线程的缺点 4. python协程--asyncio 4.1 概念 4.2 Asyncio原理 4.3 如何使用? 4.4. 协程的优点 6. 选择多线程还是协程 1. 进程与线程 1.1 概念…