1、引言
當(dāng)前隨著計(jì)算機(jī)硬件的快速發(fā)展,個(gè)人電腦上的 CPU 也是多核的,現(xiàn)在普遍的 CUP 核數(shù)都是 4 核或者 8 核的。因此,在編寫(xiě)程序時(shí),需要為了提高效率,充分發(fā)揮硬件的能力,則需要編寫(xiě)并行的程序。Java 語(yǔ)言作為互聯(lián)網(wǎng)應(yīng)用的主要語(yǔ)言,廣泛應(yīng)用于企業(yè)應(yīng)用程序的開(kāi)發(fā)中,它也是支持多線程(Multithreading)的,但多線程雖好,卻對(duì)程序的編寫(xiě)有較高的要求。
單線程可以正確運(yùn)行的程序不代表在多線程場(chǎng)景下能夠正確運(yùn)行,這里的正確性往往不容易被發(fā)現(xiàn),它會(huì)在并發(fā)數(shù)達(dá)到一定量的時(shí)候才可能出現(xiàn)。這也是在測(cè)試環(huán)節(jié)不容易重現(xiàn)的原因。因此,多線程(并發(fā))場(chǎng)景下,如何編寫(xiě)線程安全(Thread-Safety)的程序,對(duì)于程序的正確和穩(wěn)定運(yùn)行有重要的意義。
下面將結(jié)合示例,談?wù)勅绾卧?Java 語(yǔ)言中,實(shí)現(xiàn)線程安全的程序。
為了給出感性的認(rèn)識(shí),下面給出一個(gè)線程不安全的示例,具體如下:
package com.example.learn;
public class Counter {
private static int counter = 0;
public static int getCount(){
return counter;
}
public static void add(){
counter = counter + 1;
}
}
2、synchronized方法
基于上述的示例,讓其變成線程安全的程序,最直接的就是在對(duì)應(yīng)的方法上添加 synchronized 關(guān)鍵字,讓其成為同步的方法。它可以修飾一個(gè)類(lèi),一個(gè)方法和一個(gè)代碼塊。對(duì)上述計(jì)數(shù)程序進(jìn)行修改,代碼如下:
package com.example.learn;
public class Counter {
private static int counter = 0;
public static int getCount(){
return counter;
}
public static synchronized void add(){
counter = counter + 1;
}
}
3、加鎖機(jī)制
另外一種常見(jiàn)的同步方法就是加鎖,比如 Java 中有一種重入鎖 ReentrantLock,它是一種遞歸無(wú)阻塞的同步機(jī)制,相對(duì)于 synchronized 來(lái)說(shuō),它可以提供更加強(qiáng)大和靈活的鎖機(jī)制,同時(shí)可以減少死鎖發(fā)生的概率。示例代碼如下:
package com.example.learn;
import java.util.concurrent.locks.ReentrantLock;
public class Counter {
private static int counter = 0;
private static final ReentrantLock lock = new ReentrantLock(true);
public static int getCount(){
return counter;
}
public static void add(){
lock.lock();
try {
counter = counter + 1;
} finally {
lock.unlock();
}
}
}
到此這篇關(guān)于python多線程的線程如何安全實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)python多線程的線程安全實(shí)現(xiàn)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!