Java多线程进程应对同一程序运行资源

Java多线程进程需要我们不断的学习,在学习的过程中我们要看看如何才能更好的改变目前的运行障碍。通俗一点说,进程就是程序的一次执行,而线程可以理解为进程中的执行的一段程序片段。

用一点文词说就是,每个进程都有独立的代码和数据空间(进程上下文);而线程可以看成是轻量级的进程。一般来讲(不使用特殊技术),同一进程所产生的线程共享同一块内存空间。#t#

同一进程中的两段代码是不可能同时执行的,除非引入线程。线程是属于进程的,当进程退出时该进程所产生的线程都会被强制退出并清除。线程占用的资源要少于Java多线程进程所占用的资源。进程和线程都可以有优先级。在线程系统中进程也是一个线程。可以将进程理解为一个程序的第一个线程。多进程——在操作系统中,能同时运行多个任务(程序)。

Java多线程进程——在同一应用程序中,有多个顺序流同时执行。

通过铁路售票程序来理解实现Java多线程的两种方法:通过java.lang.Thread类和通过Runnable接口

java中有两种实现Java多线程进程的方式。一是直接继承Thread类,二是实现Runnable接口。那么这两种实现Java多线程的方式在应用上有什么区别呢?

为了回答这个问题,我们可以通过编写一段代码来进行分析。我们用代码来模拟铁路售票系统,实现通过四个售票点发售某日某次列车的100张车票,一个售票点用一个线程表示。

我们首先这样编写这个程序:

 
 
 
  1. public class ThreadDome1{  
  2. public static void main(String[] args){  
  3. ThreadTest t = new ThreadTest();  
  4. t.start();  
  5. t.start();  
  6. t.start();  
  7. t.start();  
  8. }  
  9. }  
  10. class ThreadTest extends Thread{  
  11. private int ticket = 100;  
  12. public void run(){  
  13. while(true){  
  14. if(ticket > 0){  
  15. System.out.println(Thread.currentThread().getName() +  
  16. ”is saling ticket” + ticket–);  
  17. }else{  
  18. break;  
  19. }  
  20. }  
  21. }  
  22. }  

上面的Java多线程进程代码中,我们用ThreadTest类模拟售票处的售票过程,run方法中的每一次循环都将总票数减1,模拟卖出一张车票,同时该车票号打印出来,直接剩余的票数到零为止。在ThreadDemo1类的main方法中,我们创建了一个线程对象,并重复启动四次,希望通过这种方式产生四个线程。从运行的结果来看我们发现其实只有一个线程在运行,这个结果告诉我们:一个线程对象只能启动一个线程,无论你调用多少遍start()方法,结果只有一个线程。

当前标题:Java多线程进程应对同一程序运行资源
转载来于:http://www.shufengxianlan.com/qtweb/news30/417580.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联