难道这样就够了吗?不,远远不够!
提前多熟悉阿里往年的面试题肯定是对面试有很大的帮助的,但是作为技术性职业,手里有实打实的技术才是你面对面试官最有用的利器,这是从内在散发出来的自信。
备战阿里时我花的最多的时间就是在学习技术上,占了我所有学习计划中的百分之70,这是一些我学习期间觉得还是很不错的一些学习笔记
我为什么要写这篇文章呢,其实我觉得学习是不能停下脚步的,在网络上和大家一起分享,一起讨论,不单单可以遇到更多一样的人,还可以扩大自己的眼界,学习到更多的技术,我还会在csdn、博客、掘金等网站上分享技术,这也是一种学习的方法。
今天就分享到这里了,谢谢大家的关注,以后会分享更多的干货给大家!
-
可以给所有线程对象统一业务,业务保持一致
-
面向接口编程,代码更高级
多线程实现的方案三:线程池ExecutorService
Executors是用来辅助创建线程池的工具类对象
常用方法是newFixedThreadPool(int)
这个方法可以创建指定线程数目的线程池对象
创建出来的线程池对象是ExecutorService:用来存储线程的池子,负责:新建/启动/关闭线程
execute()让线程池中的线程来执行业务,每次调用都会将一个线程加入到就绪队列
public static void main(String[] args) {
//5.创建接口实现类TicketR3类的对象作为目标业务对象
TicketR3 target = new TicketR3();
/*Executors是用来辅助创建线程池的工具类对象
-
常用方法是newFixedThreadPool(int)这个方法可以创建指定数目的线程池对象
-
创建出来的线程池对象是ExecutorService:用来存储线程的池子,负责:新建/启动/关闭线程*/
//6.使用Executors工具创建一个最多有5个线程的线程池对象ExecutorService池对象
ExecutorService pool = Executors.newFixedThreadPool(5);
for (int i = 0; i < 5; i++) {
/execute()让线程池中的线程来执行业务,每次调用都会将一个线程加入到就绪队列/
pool.execute(target);/本方法的参数就是你要执行的业务,也就是目标业务类对象/
}
}
注意:线程池负责将线程加入到就绪队列中,但并不代表所有的线程都会运行,线程能否执行还是取决于OS的调用,如果没有被分配时间片,是转换不了运行状态的
注意:线程池是不关闭的,主要就是想实现线程的随取随用,这样就避免了频繁的创建与销毁线程,浪费大量资源,对于我们现在一个javaDemo的练习,大家可以手动关闭当前程序即可。
1. 出现数据安全问题的原因:
-
多线程程序
-
多个线程拥有共享数据
-
多条语句操作共享数据
2. 解决方案:加锁synchronized
- 同步代码块【常用】,格式:
synchronized(唯一的锁对象){
可能出现数据安全问题的所有代码
}
- 同步方法【不常用】,格式:
在方法的定义上加synchronized
3.使用同步时的注意事项:
- 锁对象必须唯一!!!
比如:如果是实现接口的方式,只创建了一个目标业务类对象(接口实现类对象),那么也只有一个锁对象
比如2:如果是继承Thread类的方式,你可能要创建多个子类的对象,那这个时候需要给锁对象加static,保证锁对象唯一被所有对象共享
所以:继承的方式,常用的锁对象是类名.class字节码对象
-
锁对象的类型不做限制,只要能保证唯一即可
-
加锁的范围需要认真考虑
不能太大,也不能太小,太大浪费效率,太小锁不住
4.同步与异步
异步:是多个线程抢占资源的效果,不排队,效率高,但是数据不安全
同步:每次只有一个线程独占资源,排队,效率低但是安全,synchronized也被称作同步关键字
5.多线程售票案例中问题的解决方案:
最后
小编利用空余时间整理了一份《MySQL性能调优手册》,初衷也很简单,就是希望能够帮助到大家,减轻大家的负担和节省时间。
关于这个,给大家看一份学习大纲(PDF)文件,每一个分支里面会有详细的介绍。
这里都是以图片形式展示介绍,如要下载原文件以及更多的性能调优笔记(MySQL+Tomcat+JVM)!