多线程最常用的场景就是:
-
单个线程取出数据库的数据;
-
根据这个数据再进行耗时的处理,这个处理过程就需要用多线程。
常见的问题:
1.只能单读多写吗?即单线程读数据,多线程处理?
答:不能。 最好不用多线程读数据,因为读取到的数据是重复的,没有意义,还要去重,而且你没办法保证处理完的数据还会被读出来。需要考虑的就多了,完全没必要多线程读数据。
2.读数据的时候能一次性读吗?
答:显然不能啊。如果数据有一亿,你不爆炸了,常见的就是分页了,mybatis可以用RowBounds。
3.要考虑多线程的可配置化,动态改变核心线程数大小
4.只要是做多线程,就要做效率测试,1分钟执行多少条
5.最重要的,多线程都是批量处理,要做好事务控制
最常见的就是不能数据还没更新,就把源数据给删了。