日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

线程学习笔记(一)

發(fā)布時間:2025/6/17 编程问答 17 豆豆
生活随笔 收集整理的這篇文章主要介紹了 线程学习笔记(一) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

一、引入多線程

請看上圖中的代碼執(zhí)行流程,就可以大概的理解多線程。說到多線程就一定會聯(lián)系到單線程,所謂單線程就是程序只有一條執(zhí)行路徑。相反,多線程就是程序有多條執(zhí)行路徑。

二、進程的概述

1.要想了解多線程,必須先了解線程。了解線程就必須先了解進程。因為線程依賴于進程。

2.什么是進程:就是正在運行中的程序。進程是系統(tǒng)進行資源分配和調(diào)度的獨立單位,每一個進程都有自己獨立的內(nèi)存空間和系統(tǒng)資源。

3.多進程的意義:在同一時間段內(nèi)可以執(zhí)行多個任務(wù),極大的提高了CPU的使用率。單核的CPU在某一時刻只能執(zhí)行一個任務(wù)。

三、線程的概述

1.什么是線程:在同一個進程中又可以執(zhí)行多個任務(wù),而這每一個任務(wù)可以看成一個線程。線程是程序執(zhí)行路徑和執(zhí)行單元,是程序使用CPU的基本單元。

2.多線程的意義:不是提高程序的執(zhí)行速度的,而是提高應(yīng)用程序的使用率的。程序的執(zhí)行其實都在搶CPU資源和CPU的執(zhí)行權(quán)。多個進程都在爭奪CPU這一資源,而其中一進程有多個執(zhí)行路徑,搶到這一資源的幾率就更高。但線程的執(zhí)行是由隨機性的。

四、并行和并發(fā)

并行:邏輯上同時發(fā)生,是指在同一時間內(nèi)同時運行多個程序。

并發(fā):物理上同時發(fā)生,是指在同一時間點上同時運行多個程序。

五、Java程序運行原理

執(zhí)行Java命令就會啟動Java虛擬機,啟動JVM就等于啟動了一個應(yīng)用程序,也就是啟動了一個進程,該進程會自動啟動一個主線程。然后,主線程會去調(diào)用某個類的main方法,所以main方法時運行在主線程中的。

通過上圖,可以看到啟動一個Java程序,就會啟動一個線程,在該線程中調(diào)用main方法。

JVM的啟動是多線程的:在運行一個Java程序的時候,在啟動主線程的時候,也會啟動垃圾回收線程,否則會出現(xiàn)內(nèi)存溢出。

六、創(chuàng)建線程的方式

1. 繼承java.lang.Thread類,重寫run()方法,創(chuàng)建線程對象并啟動線程。

package com.jd;/*** Created by shifeifei on 2015/8/12.*/ public class MyThread extends Thread {public static void main(String[] args) {MyThread t = new MyThread();/*** run():僅僅是封裝了線程執(zhí)行的代碼,直接調(diào)用就是普通方法* start():首先啟動了線程,然后由JVM去調(diào)用run()方法*/t.start();/***要啟動多個線程,必須先創(chuàng)建多個線程對象,再調(diào)start()方法*/MyThread t2 = new MyThread();t2.start();}@Overridepublic void run() { for(int i=0;i<200;i++) {System.out.println("當(dāng)前線程是:"+ this.getName() + " " + i);}} }

?

獲取線程名稱的方法是:public final String getName(),該方法返回的線程名稱形式是:Thread-?(?代表0、1、2等自然數(shù)),為什么會是這種形式呢?我們開源碼解析:

由于MyThread類繼承與Thread類,進入到Thread類,我們可以看到如下代碼:

private static int threadInitNumber;public Thread() {init(null, null, "Thread-" + nextThreadNum(), 0);}private static synchronized int nextThreadNum() {return threadInitNumber++;}private char name[];private void init(ThreadGroup g, Runnable target, String name,long stackSize) {this.name = name.toCharArray();}public final String getName() {return String.valueOf(name);}

?

即在創(chuàng)建線程對象的時候,就調(diào)用init()方法。

既然能夠獲取線程的名稱,我們也能夠設(shè)置線程的名稱,常用的方式有兩種:調(diào)用public final void setName(String name)和

  • 線程調(diào)度

?? (1) 分時調(diào)度模型:所有線程輪流使用CPU的執(zhí)行權(quán),平均分配每個線程占用CPU的時間片。

?? (2) 搶占式調(diào)度模型:優(yōu)先級高的線程優(yōu)先使用CPU執(zhí)行權(quán),如果線程的優(yōu)先級相同,就會隨機選擇一個執(zhí)行,優(yōu)先級高的線程獲取CPU使用權(quán)多一些。

?? (3) Java中使用搶占式調(diào)度模型。

??? 線程的優(yōu)先是從1 - 10,默認(rèn)的優(yōu)先級為 5.Thread類定義了2個常量:MIN_PRIORITY和MAX_PRIORITY來表示最高和最低優(yōu)先級。

??? 1.獲取線程的優(yōu)先級:public final int getPriority()

??? 2.設(shè)置線程的優(yōu)先級:public final void setPriority(int newPriority)

package com.jd;/*** Created by shifeifei on 2015/8/13.* */ public class ThreadPriority extends Thread {@Overridepublic void run() {for(int i=0;i<100;i++) {System.out.println(this.getName() + " " + i);}}public static void main(String[] args) {ThreadPriority t1 = new ThreadPriority();ThreadPriority t2 = new ThreadPriority();System.out.println(t1.getPriority() + " " + t2.getPriority());t1.start();t1.setPriority(10);t2.start();t2.setPriority(1);} }

3.線程信息

package com.jd;/*** Created by shifeifei on 2015/8/12.*/ public class MyTestOne {public static void main(String[] args) {//Thread.currentThread()返回當(dāng)前線程的引用String name = Thread.currentThread().getName();int priority = Thread.currentThread().getPriority();String groupName = Thread.currentThread().getThreadGroup().getName();boolean isDaemon = Thread.currentThread().isDaemon();System.out.println("線程名字: " + name);System.out.println("線程優(yōu)先級: " + priority);System.out.println("線程組名稱: " + groupName);System.out.println("是否為守護線程: " + isDaemon);} }

?

  • 守護線程和用戶線程

????? 1. 守護線程:Java程序運行時后臺提供的一種通用服務(wù)的線程。守護線程是用來服務(wù)用戶線程的,如果全部的用戶線程結(jié)束了,守護線程也就結(jié)束了。

package com.jd;/*** Created by shifeifei on 2015/8/12.*/ public class MyThread extends Thread {public static void main(String[] args) {Thread t1 = new Thread("daemon") {@Overridepublic void run() {Thread t2 = new Thread("sub") {@Overridepublic void run() {for (int i = 0; i < 20; i++) {System.out.println(this.getName() + " " + i);}}};t2.setDaemon(true);t2.start();}};t1.start();} }

????? 注意:(1) 所有的用戶線程結(jié)束時,JVM就可以退出了。

????????????? (2) 設(shè)置當(dāng)前線程為守護線程時必須在start()方法之前。

????????????? (3) 在Daemon線程中產(chǎn)生的新線程也是Daemon的。

????????????? (4) 守護線程應(yīng)該永遠不去訪問固有資源,如文件、數(shù)據(jù)庫,因為它會在任何時候甚至在一個操作的中間發(fā)生中斷。

  • GroupName,每個線程都會默認(rèn)在一個線程組里,我們也可以顯式的創(chuàng)建線程組,一個線程組中也可以包含子線程組,這樣線程和線程組,就構(gòu)成了一個樹狀結(jié)構(gòu)。

轉(zhuǎn)載于:https://www.cnblogs.com/shi-blog/p/4726453.html

總結(jié)

以上是生活随笔為你收集整理的线程学习笔记(一)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。