Java多線程進程應對同一程序運行資源
Java多線程進程需要我們不斷的學習,在學習的過程中我們要看看如何才能更好的改變目前的運行障礙。通俗一點說,進程就是程序的一次執(zhí)行,而線程可以理解為進程中的執(zhí)行的一段程序片段。
用一點文詞說就是,每個進程都有獨立的代碼和數(shù)據(jù)空間(進程上下文);而線程可以看成是輕量級的進程。一般來講(不使用特殊技術),同一進程所產(chǎn)生的線程共享同一塊內存空間。#t#
同一進程中的兩段代碼是不可能同時執(zhí)行的,除非引入線程。線程是屬于進程的,當進程退出時該進程所產(chǎn)生的線程都會被強制退出并清除。線程占用的資源要少于Java多線程進程所占用的資源。進程和線程都可以有優(yōu)先級。在線程系統(tǒng)中進程也是一個線程。可以將進程理解為一個程序的第一個線程。多進程——在操作系統(tǒng)中,能同時運行多個任務(程序)。
Java多線程進程——在同一應用程序中,有多個順序流同時執(zhí)行。
通過鐵路售票程序來理解實現(xiàn)Java多線程的兩種方法:通過java.lang.Thread類和通過Runnable接口
java中有兩種實現(xiàn)Java多線程進程的方式。一是直接繼承Thread類,二是實現(xiàn)Runnable接口。那么這兩種實現(xiàn)Java多線程的方式在應用上有什么區(qū)別呢?
為了回答這個問題,我們可以通過編寫一段代碼來進行分析。我們用代碼來模擬鐵路售票系統(tǒng),實現(xiàn)通過四個售票點發(fā)售某日某次列車的100張車票,一個售票點用一個線程表示。
我們首先這樣編寫這個程序:
- public class ThreadDome1{
- public static void main(String[] args){
- ThreadTest t = new ThreadTest();
- t.start();
- t.start();
- t.start();
- t.start();
- }
- }
- class ThreadTest extends Thread{
- private int ticket = 100;
- public void run(){
- while(true){
- if(ticket > 0){
- System.out.println(Thread.currentThread().getName() +
- ”is saling ticket” + ticket–);
- }else{
- break;
- }
- }
- }
- }
上面的Java多線程進程代碼中,我們用ThreadTest類模擬售票處的售票過程,run方法中的每一次循環(huán)都將總票數(shù)減1,模擬賣出一張車票,同時該車票號打印出來,直接剩余的票數(shù)到零為止。在ThreadDemo1類的main方法中,我們創(chuàng)建了一個線程對象,并重復啟動四次,希望通過這種方式產(chǎn)生四個線程。從運行的結果來看我們發(fā)現(xiàn)其實只有一個線程在運行,這個結果告訴我們:一個線程對象只能啟動一個線程,無論你調用多少遍start()方法,結果只有一個線程。