说一下java程序中的进程以及并发的概念?

Python011

说一下java程序中的进程以及并发的概念?,第1张

在 Java 程序中,进程是指正在运行的程序的实例。一个 Java 程序可以创建多个进程,每个进程都有自己的内存空间和执行上下文。

并发是指多个进程或线程在同一时间内同时执行。在 Java 中,你可以使用线程来实现并发。线程是进程中的一个执行单元,它共享进程的内存空间和执行上下文。使用线程可以让你的程序同时执行多个任务,从而提高程序的效率。

Java 提供了许多工具和技术来帮助你管理并发,例如线程同步、线程间通信和线程池。使用这些工具可以让你的程序在多个线程之间共享资源,同时避免线程冲突和死锁。

多线程共享资源,比如一个对象的内存,怎样保证多个线程不会同时访问(读取或写入)这个对象,这就是并发最大的难题,因此产生了 互斥机制(锁)。

using the same monitor lock.

获取锁后,该线程本地存储失效,临界区(就是获得锁后释放锁之前 的代码区)从主存获取数据,并在释放锁后刷入主存。

互斥:

保证临界区代码线程间互斥。

synchronized实现同步的基础:

java中每个对象都可以作为锁

一个任务可以多次获得锁,比如在一个线程中调用一个对象的 synchronized标记的方法,在这个方法中调用第二个synchronized标记的方法,然后在第二个synchronized方法中调用第三个synchronized方法。一个线程每次进入一个synchronized方法中JVM都会跟踪加锁的次数,每次+1,当该这个方法执行完毕,JVM计数-1;当JVM计数为0时,锁完全被释放,其他线程可以访问该变量。

在使用并发时将对象的field设为private 很重要!尤其是使用static变量(evil static variable) 使用 Lock lock =new ReentrantLock()的问题是代码不够优雅,增加代码量;我们一般都是使用synchronized实现互斥机制。但是1.当代码中抛出异常时,显示锁的finally里可以进行资源清理工作。2.ReentrantLock还给我们更细粒度的控制力

个人理解

同步是为了数据的准确性

并发只是线程同时执行的多少,如果是单核处理器看起来是并发,其实也就是单核处理不断且来切去,但因为速度快感觉是同时执行

举个例子:

破解密码

通过软件多线程进行密码破解

假设四个线程之间不进行同步,一个密码就有可能被4个线程都使用一次,这就体现到数据同步的重要性了