想进阿里、京东?这些多线程并发的技术要点你需要知道,Java 程序员怎么优雅迈过 30K+ 这道坎
一、概念
什么是线程
一个线程要执行任务,必须得有线程
一个进程(程序)的所有任务都在线程中执行的
一个线程执行任务是串行的,也就是说一个线程,同一时间内,只
能执行一个任务
多线程原理
同一时间,CPU 只能处理 1 条线程,只有一条线程在工作(执行)
多线程并发(同时)执行,其实质是 CPU 快速的在多线程之间调度(切换)
如果线程过多,会怎样?
CPU 在 N 多条线程中调度,会消耗大量的 cpu 资源
每条线程被调度执行的频率越低(线程的执行效率低)
多线程的优点
能适当提高程序的执行效率
能适当提高资源的利用率(CPU 内存利用率等)
多线程的缺点
创建线程是有开销的,iOS 下主要成本包括:内核数据结构(大约 1KB)、栈空间(子线程 512KB、主线程 1MB,也可以使用-setStackSize:设置,但必须是 4K 的倍数,而且最小是 16K),创建线程大约需要 90 毫秒的创建时间
如果开启大量的线程,会降低程序的性能
程序越多 CPU 的线程上的开销就越大
程序设计更加复杂:线程之间的通讯,多线程的数据共享
主线程的主要作用
显示和刷新 UI 界面
处理 UI 事件(比如点击事件,滚动事件,拖拽事件等)
主线程的使用注意
别将比较耗时的操作放在主线程中,会导致 UI 界面的卡顿
将耗时操作放在子线程(后台线程,非主线程)
二、多线程的 4 种方案
三、常见多线程面试题:
1.现在有 T1、T2、T3 三个线程,你怎样保证 T2 在 T1 执行完后执行,T3 在 T2 执行完后执行?
这个线程问题通常会在第一轮或电话面试阶段被问到,目的是检测你对”join”方法是否熟悉。这个多线程问题比较简单,可以用 join 方法实现。
2.在 Java 中 Lock 接口比 synchronized 块的优势是什么?你需要实现一个高效的缓存,它允许多个用户读,但只允许一个用户写,以此来保持它的完整性,你会怎样去实现它?
lock 接口在多线程和并发编程中最大的优势是它们为读和写分别提供了锁,它能满足你写像 ConcurrentHashMap 这样的高性能数据结构和有条件的阻塞。Java 线程面试的问题越来越会根据面试者的回答来提问。我强烈建议在你去参加多线程的面试之前认真读一下 Locks,因为当前其大量用于构建电子交易终统的客户端缓存和交易连接空间。
3.在 java 中 wait 和 sleep 方法的不同?
通常会在电话面试中经常被问到的 Java 线程面试问题。最大的不同是在等待时 wait 会释放锁,而 sleep 一直持有锁。Wait 通常被用于线程间交互,sleep 通常被用于暂停执行。
评论