java多线程什么情况下用 如何实现java多个线程同时开始执行?

[更新]
·
·
分类:互联网
2461 阅读

java多线程什么情况下用

如何实现java多个线程同时开始执行?

如何实现java多个线程同时开始执行?

线程池,通过线程池的方式可以启动多个线程,当然这些线程不一定立马执行。但是在目前多核心cpu的场景下,是可以执行多个线程的。

java电商项目,什么场景需要使用多线程?

场景一:一个业务逻辑有很多次的循环,每次循环之间没有影响,比如验证1万条url路径是否存在,正常情况要循环1万次,逐个去验证每一条URL,这样效率会很低,假设验证一条需要1分钟,总共就需要1万分钟,有点恐怖。这时可以用多线程,将1万条URL分成50等份,开50个线程,没个线程只需验证200条,这样所有的线程执行完是远小于1万分钟的。
场景二:需要知道一个任务的执行进度,比如我们常看到的进度条,实现方式可以是在任务中加入一个整型属性变量(这样不同方法可以共享),任务执行一定程度就给变量值加1,另外开一个线程按时间间隔不断去访问这个变量,并反馈给用户。
总之使用多线程就是为了充分利用cpu的资源,提高程序执行效率,当你发现一个业务逻辑执行效率特别低,耗时特别长,就可以考虑使用多线程。不过CPU执行哪个线程的时间和顺序是不确定的,即使设置了线程的优先级,因此使用多线程的风险也是比较大的,会出现很多预料不到的问题,一定要多熟悉概念,多构造不同的场景去测试才能够掌握!

java的线程安全是什么?谁能一言以蔽之?

这个还真不能一句话概况,我博客写了一长篇关于线程安全的,我提炼了下面这段,看懂也基本够了:
单线程不会有安全问题,多线程编程才会有安全问题,根本在于是否存在critical resource竞争资源,如果多线程不会访问竞争资源就不存在安全问题,否则则要处理,
什么是竞争资源呢,具体如下:
如果是各自访问其上下文context的资源,比如kafka consumer partition worker线程访问各自的storage则是互相不打扰的;
如果执行的某个方法内只用到了局部变量,由于局部变量位于各自thread的栈里,所以互不干扰;
如果执行的某个方法用到了传入的变量,也就是所谓的形式参数变量,则要看这个传入的变量是否是object,如果只是普通的参数则没关系,如果是对象,要看对象是否是同一个引用,不同引用没有关系;
如果执行的某个方法内用到了同一个引用,不管是传入的还是外部全局的变量,比如log4的logger,由于log4已经做好了线程安全写log,所以不用担心;
如果执行的某个方法内用到了同一个引用:
i)但是只是读没有写,读和读是没有冲突的,也没有关系
ii)都有写,但是写不依赖于读,即线程不需要获取“最新”数据就可以直接写入覆盖,这种情况也没有关系;
iii)都有写,而且写依赖于读到最新数据,则需要处理;