爱奇艺的面试官问 (1) 线程池是如何关闭的 (2) 如何确定线程池的数量 一.线程池销毁,停止线程池 ThreadPoolExecutor提供了两个方法,用于线程池的关闭,分别是shutdown()和shutdownNow(),注意,他们都不调用stop(),仅仅调用interrrupt)(函数:其中:       (a) shutdown():将线程状态设为SHUTDOWN,并不会立即停止,调用了Interrupt(); 不会立即终止线程池,而是要等所有任务缓存队列中的任务都执行完后才终止,…
线程属于一次性消耗品,在执行完run()方法之后线程便会正常结束了,线程结束后便会销毁,不能再次start,只能重新建立新的线程对象,但有时run()方法是永远不会结束的.例如在程序中使用线程进行Socket监听请求,或是其他的需要循环处理的任务.在这种情况下,一般是将这些任务放在一个循环中,如while循环.当需要结束线程时,如何退出线程呢? 有三种方法可以结束线程: 1.设置退出标志,使线程正常退出,也就是当run()方法完成后线程终止,比如使用一个volatile 的变量: 2.使用int…
原作者:海子 出处:http://www.cnblogs.com/dolphin0520/ 本文归作者海子和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利. 在前面的文章中,我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题: 如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了,这样频繁创建线程就会大大降低系统的效率,因为频繁创建线程和销毁线程需要时间. 那么有没有一种办法使得线程可…
原文链接 原文出处: 海 子 在前面的文章中,我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题: 如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了,这样频繁创建线程就会大大降低系统的效率,因为频繁创建线程和销毁线程需要时间. 那么有没有一种办法使得线程可以复用,就是执行完一个任务,并不被销毁,而是可以继续执行其他的任务? 在Java中可以通过线程池来达到这样的效果.今天我们就来详细讲解一下Java的线程池,首先我们从最核心的ThreadPoolE…
今天给大家分享我曾经在爱奇艺的面试,过程还是比较有意思的,可以给大家一些参考 聊骚阶段 嗲妹妹:你好,我是爱奇艺的HR,我们正在招聘运维开发岗位,请问您最近有在看工作机会吗? 我:(这声音也太酥了吧我去--)嗯,你好,信号不太好,能在说下吗?(让我再酥一次吧) 嗲妹妹:(重复) 我:(我去,真的好酥啊)啊听到了,嗯,最近有在看 (不看机会,就没机会聊下去了啊) 嗲妹妹:嗯嗯,那简单的介绍一下,--,公司在xxx,你看什么时候方便过来一次吗? 我:可以可以,那就约在周xx吧,我应该可以,那天是你本…
今天给大家分享我曾经在爱奇艺的面试,过程还是比较有意思的,可以给大家一些参考 聊骚阶段 嗲妹妹:你好,我是爱奇艺的HR,我们正在招聘运维开发岗位,请问您最近有在看工作机会吗? 我:(这声音也太酥了吧我去……)嗯,你好,信号不太好,能在说下吗?(让我再酥一次吧) 嗲妹妹:(重复) 我:(我去,真的好酥啊)啊听到了,嗯,最近有在看 (不看机会,就没机会聊下去了啊) 嗲妹妹:嗯嗯,那简单的介绍一下,……,公司在xxx,你看什么时候方便过来一次吗? 我:可以可以,那就约在周xx吧,我应该可以,那天是你本…
原文链接:http://www.cnblogs.com/dolphin0520/p/3932921.html 附加:http://www.cnblogs.com/wxd0108/p/5479442.html( Java中的多线程你只要看这一篇就够了 ) 核心类:ThreadPoolExecutor 四个构造方法: 构造中的各个参数含义: corePoolSize:核心池大小. maximumPoolSize:线程池中最大线程数. 后续再理解!…
目录 为什么需要线程池 定义 ThreadPoolExecutor 工作队列workQueue 不同的线程池 Executor 线程池的工作原理 线程池生命周期 线程池增长策略 线程池大小的设置 线程池使用的注意事项 参考 为什么需要线程池 new Thread()不是创建一个对象那么简单,需要调用操作系统内核的API,然后操作系统要为线程分配一系列的资源,这个成本就很高.所以线程是一个重量级的对象,应该避免频繁创建和销毁.而应对方案就是线程池. 定义 线程池,除了池的功能外,还提供了更全面的线…
一.主要使用类 . ExecutorService java线程池类 申明方式:ExecutorService exc = Executors.newFixedThreadPool(requestParameterArray.length()); 参数:requestParameterArray.length()是请求线程的总数量,其中每一个成员存放单个线程所需参数. 代码: .Future Future是一个接口,他提供给了我们方法来检测当前的任务是否已经结束,还可以等待任务结束并且拿到一个结…
目录 一轮 电话面试 二轮 代码笔试 三轮 技术面试 总结 附:电话面试问题点解惑 补充:面试未通过 一轮 电话面试 2019.04.28 16:21 [w]:面试官,[m]:我,下面的内容来自电话录音. [m]:喂,喂 [w]:喂你好,请问是xxx同学吗? [m]:对,是的: [w]:你好,我这边是上海爱奇艺,之前和你约好下午有电话面试,你现在那边OK吗? [m]:可以啊 [w]:你那边信号好吗?听我说话听的清楚吗? [m]:听得清楚呀,你那边听得清楚我说的吗? [w]:嗯,我这边听得清楚 […