详谈java线程与线程,进程与进程间通信

  

  

  

关于进程和线程,首先从定义上理解就有所不同

  

  

是具有一定独立功能的程序,它是系统进行资源分配和调度的一个独立单位,重点在系统调度和单独的单位,也就是说进程是可以独立运行的一段程序。

  

  

线程进程的一个实体,是CPU调度和分派的基本单位,他是比进程更小的能独立运行的基本单位,线程自己基本上不拥有系统资源。

  

在运行时,只是暂用一些计数器,寄存器和栈。

  

  

1,一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程(通常说的主线程)。

  

2,资源分配给进程,同一进程的所有线程共享该进程的所有资源。

  

3线程在执行过程中,需要协作同步。不同进程的线程间要利用消息通信的办法实现同步。

  

4处理机分给线程,即真正在处理机上运行的是线程。

  

5日线程是指进程内的一个执行单元,也是进程内的可调度实体。

  

  

1,调度:线程作为调度和分配的基本单位,进程作为拥有资源的基本单位。

  

2,并发性:不仅进程之间可以并发执行,同一个进程的多个线程之间也可以并发执行。

  

3,拥有资源:进程是拥有资源的一个独立单位,线程不拥有系统资源,但可以访问隶属于进程的资源. .

  

  

1,共享变量

  

2,等待/通知机制

  

3,锁定/状态机制

  

4,管道

  

  

线程间发送信号的一个简单方式是在共享对象的变量里设置信号值。线程一个在一个同步块里设置布尔型成员变量hasDataToProcess为真的,线程B也在同步块里读取hasDataToProcess这个成员变量。这个简单的例子使用了一个持有信号的对象,并提供了设置和检查方法:

  


  

     公开课MySignal {      保护布尔hasDataToProcess=false;      公共同步布尔hasDataToProcess () {   返回this.hasDataToProcess;   }      公共同步空白setHasDataToProcess(布尔hasData) {   这一点。hasDataToProcess=hasData;   }      }      之前   A和B

线程必须获得指向一个MySignal共享实例的引用,以便进行通信。如果它们持有的引用指向不同的MySingal实例,那么彼此将不能检测到对方的信号,需要处理的数据可以存放在一个共享缓存区里,它和MySignal实例是分开存放的。

  

  

为了实现线程通信,我们可以使用对象类提供的()等,通知(),notifyAll()三个方法。调用等()方法会释放对该同步监视器的锁定。这三个方法必须由同步监视器对象来调用,这可分成两种情况:

  

& # 8226;对于使用同步修饰的同步方法,因为该类的默认实例是(这样)就是同步监视器,所以可以直接调用这三使用个方法。

  

& # 8226;对于同步修饰的同步代码块,同步监视器是同步括号里的对象,所以必须使用该对象调用这三个方法。

  

假设系统中有两条线程,这两条线程分别代表取钱者和存钱者。现在系统有一种特殊的要求,系统要求存款者和取钱者不断的实现存款和取钱动作,而且要求每当存款者将钱存入指定账户后,取钱者立即将钱取走,不允许存款者两次存的钱,也不允许取钱者两次取钱。

  

我们通过设置一个旗标来标识账户中是否已有存款,有就为真,没有就标为假,具体代码如下:

  

首先我们定义一个账户类,这个类中有取钱和存钱的两个方法,由于这两个方法可能需要并发的执行取钱,存钱操作,所有将这两个方法都修改为同步方法。(使用同步关键字)。

        公共类账户{   私人字符串accountNo;   私人双平衡;//标识账户中是否有存款的旗标   私人布尔标志=false;      公共账户(){   超级();   }      公共账户(字符串accountNo、双平衡){   超级();   这一点。accountNo=accountNo;   这一点。余额=资产;   }      公共同步空白画(双drawAmount) {      尝试{   如果(国旗){   this.wait ();   其他}{//取钱   System.out.println (Thread.currentThread () . getname() +”取钱:“+ drawAmount);   平衡=balance-drawAmount;   system . out。println(“余额:“+平衡);//将标识账户是否已有存款的标志设为false   国旗=false;//唤醒其它线程   this.notifyAll ();   }   }捕捉(异常e) {   e.printStackTrace ();   }   }         公共同步真空沉积(双depositAmount) {   尝试{   如果(国旗){   this.wait ();   }   其他{   System.out.println (Thread.currentThread () . getname() +“存”钱+ depositAmount);   余额=资产+ depositAmount;   System.out.println(“账户余额为:“+平衡);   国旗=true;//唤醒其它线程   this.notifyAll ();   }   }捕捉(异常e) {//TODO:处理异常   e.printStackTrace ();   }   }      }

详谈java线程与线程,进程与进程间通信