精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

一個測試記錄:利用【分段鎖】來處理并發(fā)情況下的資源競爭問題

開發(fā) 項(xiàng)目管理
這篇文章主要描述的就是使用分段鎖來解決這個問題,說起來很簡單:就是把鎖的粒度降低,以達(dá)到資源獨(dú)占、最大程度避免競爭的目的。

目錄

  • 問題描述
  • 測試代碼
  • 測試結(jié)果
  • 測試代碼簡介

別人的經(jīng)驗(yàn),我們的階梯!

在開發(fā)中經(jīng)常遇到多個并發(fā)執(zhí)行的線程,需要對同一個資源進(jìn)行訪問,也就是發(fā)生資源競爭。

在這種場景中,一般的做法就是加鎖,通過鎖機(jī)制對臨界區(qū)進(jìn)行保護(hù),以達(dá)到資源獨(dú)占的目的。

這篇文章主要描述的就是使用分段鎖來解決這個問題,說起來很簡單:就是把鎖的粒度降低,以達(dá)到資源獨(dú)占、最大程度避免競爭的目的。

問題描述

周末和朋友聊天說到最近的工作,他們有個項(xiàng)目,需要把之前的一個單片機(jī)程序,移植到x86平臺。

由于歷史的原因,代碼中到處都充斥著全局變量,你懂得:在以前的單片機(jī)中充斥著大量的全局變量,方便、好用啊!

在代碼中,盡量避免使用全局變量。壞處有:不方便模塊化,函數(shù)不可重入,耦合性大。。。

由于大部分的單片機(jī)都只有一個CPU,是真正的串行操作。

也許你會說:會發(fā)生中斷啊,這也是一種異步操作。

沒錯,但是可以在訪問全局變量的地方把中斷關(guān)掉,這樣就不會避免了資源競爭的情況了。

但是,移植到x86平臺之后,在多核的情況下,多個線程(任務(wù))是真正的并發(fā)執(zhí)行序列。

如果多個線程同時操作某一個全局變量,就一定存在競爭的情況。

針對這個問題,首先想到的方案就是:分配一般互斥鎖,無論哪個線程想訪問全局變量,首先獲取到鎖,然后才能操作全局變量,操作完成之后再釋放鎖。

但是,這個方案有一個很大的問題,就是:當(dāng)并發(fā)線程很多的情況下,程序的執(zhí)行效率太低。

他們最后的解決方案是分段加鎖,也就是對全局變量按照數(shù)據(jù)索引進(jìn)行分割,每一段數(shù)據(jù)分配一把鎖。

至于每一段的數(shù)據(jù)長度是多少,這需要根據(jù)實(shí)際的業(yè)務(wù)場景進(jìn)行調(diào)整,以達(dá)到最優(yōu)的性能。

回來之后,我覺得這個想法非常巧妙。

這個機(jī)制看起來很簡單,但是真的能解決大問題。

于是我就寫了一段代碼來測試一下:這種方案對程序的性能有多大的影響。

測試代碼

在測試代碼中,定義了一個全局變量:

volatile int test_data[DATA_TOTAL_NUM];

數(shù)組的長度是10000(宏定義:DATA_TOTAL_NUM),然后創(chuàng)建100個線程來并發(fā)訪問這個全局變量,每個線程訪問100000次。

然后執(zhí)行3個測試用例:

測試1:不使用鎖

00個線程同時操作全局變量,訪問的數(shù)據(jù)索引隨機(jī)產(chǎn)生,最后統(tǒng)計(jì)每個線程的平均執(zhí)行時間。

不使用鎖的話,最后的結(jié)果(全局變量中的數(shù)據(jù)內(nèi)容)肯定是錯誤的,這里僅僅是為了看一下時間消耗。

測試2:使用一把全局鎖(大鎖)

100個線程使用一把鎖。

每個線程在操作全局變量之前,首先要獲取到這把鎖,然后才能操作全局變量,否則的話只能阻塞著等其它線程釋放鎖。

測試3:使用分段鎖

根據(jù)全局變量的長度,分配多把鎖。

每個線程在訪問的時候,根據(jù)訪問的數(shù)據(jù)索引,獲取不同的鎖,這樣就降低了競爭的幾率。

在這個測試場景中,全局變量test_data的長度是10000,每100個數(shù)據(jù)分配一把鎖,那么一共需要100把鎖。

比如,在某個時刻:

  • 線程1想訪問test_data[110]。
  • 線程2想訪問test_data[120]。
  • 線程3想訪問test_data[9900]。

首先根據(jù)每個線程要訪問的數(shù)據(jù)索引進(jìn)行計(jì)算:這個索引對應(yīng)的哪一把鎖?

計(jì)算方式:訪問索引 % 每把鎖對應(yīng)的數(shù)據(jù)長度

經(jīng)過計(jì)算得知:線程1、線程2就會對第二把鎖進(jìn)行競爭;

而線程3就可以獨(dú)自獲取最后一把鎖,這樣的話線程3就避開了與線程1、線程2的競爭。

測試結(jié)果

$ ./a.out 
test1_naked: average = 2876 ms
test2_one_big_lock: average = 11233 ms
test3_segment_lock: average = 3216 ms

從測試結(jié)果上看,分段加鎖比使用一把全局鎖,對于程序性能的提高確實(shí)很明顯。

當(dāng)然了,測試結(jié)果與不同的系統(tǒng)環(huán)境、業(yè)務(wù)場景有關(guān),特別是線程的競爭程度、在臨界區(qū)中的執(zhí)行時間等。

測試代碼簡介

測試代碼沒有考慮跨邊界的情況。

比如:某個線程需要訪問190 ~ 210這些索引上的數(shù)據(jù),這個區(qū)間正好跨越了200這個分界點(diǎn)。

第0把鎖:0 ~ 99。

第1把鎖:100 ~ 199。

第2把鎖:200 ~ 299。

因此,訪問190 ~ 210就需要同時獲取到第1、2把鎖。

在實(shí)際項(xiàng)目中需要考慮到這種跨邊界的情況,通過計(jì)算開始和結(jié)束索引,把這些鎖都獲取到才可以。

當(dāng)然了,為了防止發(fā)生死鎖,需要按照順序來獲取。

#define THREAD_NUMBER           100         // 線程個數(shù)
#define LOOP_TIMES_EACH_THREAD 100000 // 每個線程中 for 循環(huán)的執(zhí)行次數(shù)
#define DATA_TOTAL_NUM 10000 // 全局變量的長度
#define SEGMENT_LEN 100 // 多少個數(shù)據(jù)分配一把鎖
volatile int test_data[DATA_TOTAL_NUM]; // 被競爭的全局變量
void main(void)
{
test1_naked();
test2_one_big_lock();
test3_segment_lock();
while (1)
sleep(3); // 主線程保持運(yùn)行,也可以使用getchar();
}
// 測試1:子線程執(zhí)行的函數(shù)
void *test1_naked_function(void *arg)
{
struct timeval tm1, tm2;
gettimeofday(&tm1, NULL);
for (unsigned int i = 0; i < LOOP_TIMES_EACH_THREAD; i++)
{
do_some_work(); // 模擬業(yè)務(wù)操作
unsigned int pos = rand() % DATA_TOTAL_NUM;
test_data[pos] = i * i; // 隨機(jī)訪問全局變量中的某個數(shù)據(jù)
}
gettimeofday(&tm2, NULL);
return (tm2 - tm1);
}
// 測試2:子線程執(zhí)行的函數(shù)
void *test2_one_big_lock_function(void *arg)
{
test2_one_big_lock_arg *data = (test2_one_big_lock_arg *)arg;
struct timeval tm1, tm2;
gettimeofday(&tm1, NULL);
for (unsigned int i = 0; i < LOOP_TIMES_EACH_THREAD; i++)
{
pthread_mutex_lock(&data->lock); // 上鎖
do_some_work(); // 模擬業(yè)務(wù)操作
unsigned int pos = rand() % DATA_TOTAL_NUM;
test_data[pos] = i * i; // 隨機(jī)訪問全局變量中的某個數(shù)據(jù)

pthread_mutex_unlock(&data->lock); // 解鎖
}
gettimeofday(&tm2, NULL);

return (tm2 - tm1);
}
// 測試3:子線程執(zhí)行的函數(shù)
void *test3_segment_lock_function(void *arg)
{
test3_segment_lock_arg *data = (test3_segment_lock_arg *)arg;
struct timeval tm1, tm2;
gettimeofday(&tm1, NULL);
for (unsigned int i = 0; i < LOOP_TIMES_EACH_THREAD; i++)
{
unsigned int pos = rand() % DATA_TOTAL_NUM; // 產(chǎn)生隨機(jī)訪問的索引
unsigned int lock_index = pos / SEGMENT_LEN; // 根據(jù)索引計(jì)算需要獲取哪一把鎖
pthread_mutex_lock(data->lock + lock_index); // 上鎖
do_some_work(); // 模擬業(yè)務(wù)操作
test_data[pos] = i * i; // 隨機(jī)訪問全局變量中的某個數(shù)據(jù)

pthread_mutex_unlock(data->lock + lock_index); // 解鎖
}
gettimeofday(&tm2, NULL);

return (tm2 - tm1);
}
void test1_naked()
{
創(chuàng)建 100 個線程,線程執(zhí)行函數(shù)是 test1_naked_function()
printf("test1_naked: average = %ld ms \n", ms_total / THREAD_NUMBER);
}
void test2_one_big_lock()
{
創(chuàng)建 100 個線程,線程執(zhí)行函數(shù)是 test2_one_big_lock_function(),需要把鎖作為參數(shù)傳遞給子線程。
printf("test2_one_big_lock: average = %ld ms \n", ms_total / THREAD_NUMBER);
}
void test3_segment_lock()
{
根據(jù)全局變量的長度,初始化很多把鎖。
創(chuàng)建 100 個線程,線程執(zhí)行函數(shù)是 test2_one_big_lock_function(),需要把鎖作為參數(shù)傳遞給子線程。
printf("test3_segment_lock: average = %ld ms \n", ms_total / THREAD_NUMBER);
}

在Linux系統(tǒng)中可以直接編譯、執(zhí)行,拿來即用。

祝您好運(yùn)!

本文轉(zhuǎn)載自微信公眾號「IOT物聯(lián)網(wǎng)小鎮(zhèn)」

責(zé)任編輯:姜華 來源: IOT物聯(lián)網(wǎng)小鎮(zhèn)
相關(guān)推薦

2020-04-02 11:16:28

Linux進(jìn)程高并發(fā)

2020-09-18 06:36:21

Linuxkernel高并發(fā)

2021-04-06 08:54:13

Random線程安全數(shù)生成器

2023-09-14 09:27:19

Java系統(tǒng)

2022-09-16 08:42:23

JavaAPI變量

2019-12-12 15:32:48

ITvCenterVMware

2023-03-10 21:48:52

Go語言消息隊(duì)列

2022-08-24 15:08:19

模型數(shù)據(jù)技術(shù)

2024-02-29 09:44:36

Java工具

2017-08-25 14:23:44

TensorFlow神經(jīng)網(wǎng)絡(luò)文本分類

2023-05-18 08:38:13

Java鎖機(jī)制

2023-03-02 08:19:43

不加鎖程序實(shí)時性

2022-10-28 10:23:27

Java多線程底層

2025-07-07 00:00:00

2010-04-30 01:17:37

unix鎖

2023-12-11 12:27:31

并發(fā)Zookeeper數(shù)據(jù)

2021-11-26 22:25:48

QQQQ音樂移動應(yīng)用

2016-08-04 14:59:56

分段路由器路由器

2023-03-17 16:44:44

Channel進(jìn)程模型

2022-12-13 08:15:42

緩存數(shù)據(jù)競爭
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

欧美日本国产精品| 国内精品小视频在线观看| 91淫黄看大片| 思思99re6国产在线播放| 久久中文在线| 久久亚洲电影天堂| 国产精品久久久久久亚洲色| 国产精品高清乱码在线观看| 国产精品色婷婷久久58| 99视频日韩| www成人在线| 色喇叭免费久久综合| 337p日本欧洲亚洲大胆精品| 情侣黄网站免费看| 成人看片免费| www久久精品| 成人信息集中地欧美| 男女视频免费看| 欧美韩国日本在线观看 | 国产精品传媒在线观看| 亚洲精品成人| 亚洲无限av看| 丰满人妻一区二区三区免费视频棣| 成人美女大片| 亚洲在线视频一区| 在线视频精品一区| 精品成人一区二区三区免费视频| 国产成人亚洲综合a∨婷婷| 国产91|九色| 青娱乐免费在线视频| 日韩在线视频精品| 亚洲女人被黑人巨大进入| www.偷拍.com| 啪啪av大全导航福利综合导航| 欧美视频在线观看免费| 在线看无码的免费网站| 久青草国产在线| 国产jizzjizz一区二区| 国产精品久久久久久久久久小说| 国产又色又爽又黄的| 午夜欧美视频| 久久久精品在线观看| 在线观看免费小视频| 欧美一级色片| 精品国产露脸精彩对白 | 亚洲一区二区91| 91不卡在线观看| 色噜噜国产精品视频一区二区| 自拍偷拍视频亚洲| 欧美在线导航| 精品国产一区二区三区久久久蜜月 | 性一交一乱一透一a级| 另类人妖一区二区av| 国产精品草莓在线免费观看 | 一区在线免费| 欧美激情在线播放| 欧美日韩偷拍视频| 欧美激情91| 久久99热精品这里久久精品| 日本a级片视频| 亚洲自拍偷拍网| 蜜臀久久99精品久久久无需会员| 免费三级在线观看| 中文不卡在线| 欧美精品激情blacked18| 精品99在线观看| 激情久久久久久| 欧美激情喷水视频| 香蕉视频一区二区| 99香蕉国产精品偷在线观看| 热99久久精品| 日批视频免费观看| 久久99最新地址| 亚洲在线视频观看| www.色播.com| 91亚洲国产成人精品一区二区三| 欧美人xxxxx| 91亚洲精选| 亚洲色图制服丝袜| 高清无码一区二区在线观看吞精| 男人添女人下部高潮视频在线观看| 亚洲国产综合人成综合网站| 久久精品国产精品亚洲色婷婷| 波多视频一区| 欧美人牲a欧美精品| 精品国产午夜福利在线观看| 大陆精大陆国产国语精品| 亚洲精品久久久久中文字幕二区| 国产在线久久久| 日产中文字幕在线精品一区| 波多野结衣一区二区| 国产精品美日韩| 米仓穗香在线观看| 精品捆绑调教一区二区三区| 91久久精品一区二区三区| 中文字幕22页| 韩国女主播一区二区三区| 亚洲欧美另类在线观看| 五月天色婷婷丁香| 国产欧美午夜| 成人性生交xxxxx网站| 人妻妺妺窝人体色www聚色窝| 久久免费美女视频| 欧美a级黄色大片| 天堂√8在线中文| 欧美精品久久一区二区三区| 日b视频在线观看| 四季av在线一区二区三区| 久久久久久噜噜噜久久久精品| 欧美一区二区三区网站| 国产精品羞羞答答xxdd| 欧美激情视频一区二区三区| 黄色av免费在线| 色综合久久99| 精品无码av一区二区三区| 波多野结衣在线观看一区二区 | 国产精品天天干| 特级西西444www大胆免费看| 亚洲va在线| 91av在线看| 国产aⅴ爽av久久久久成人| 久久亚区不卡日本| 欧美乱做爰xxxⅹ久久久| 九九九伊在线综合永久| 亚洲第一免费网站| 97成人资源站| 免费黄网站欧美| 欧美欧美一区二区| bbw在线视频| 91精品国产品国语在线不卡| 国产精品www爽爽爽| 在线日韩电影| 91久久中文字幕| а天堂8中文最新版在线官网| 欧美视频免费在线| 日韩精品人妻中文字幕有码| 欧美激情第二页| 91影视免费在线观看| 国产大片在线免费观看| 五月天国产精品| 日韩大尺度视频| 68国产成人综合久久精品| 国产精品视频一区二区三区四 | 亚洲精品日韩成人| 久久久一本精品| 精品无人区乱码1区2区3区在线| 欧美日韩综合一区二区| 国产一区在线视频| 亚洲一区二区在| 粉嫩av一区二区三区四区五区| 亚洲区免费影片| 久久人妻免费视频| 久久人人超碰精品| 精品久久久久av| 伊人春色精品| 国产精品第8页| 黄色av网站在线看| 欧美性大战久久久久久久蜜臀 | 综合国产视频| 全亚洲最色的网站在线观看| 欧美精品激情视频| 91在线视频国产| 国产精品久线观看视频| 午夜两性免费视频| 日韩毛片视频| 91精品久久久久久久久青青| 老司机av在线免费看| 欧美一区二区三区四区久久| 玖玖爱这里只有精品| 国产成人自拍网| 日韩黄色短视频| 欧美一区自拍| 国产精品久久久久秋霞鲁丝| 欧美日韩欧美| 日韩欧美精品在线| 91看片在线播放| 国产午夜精品理论片a级大结局| 国产视频在线视频| 欧美高清视频在线观看mv| 91手机在线播放| 草草在线观看| 尤物tv国产一区| 国产亲伦免费视频播放| 亚洲综合一区二区三区| 欧美丰满少妇人妻精品| 日韩中文字幕亚洲一区二区va在线| 亚洲高清在线播放| 日韩亚洲精品在线观看| 91精品国产91久久久久久不卡| 国产在线视频福利| 欧美一区三区二区| 99热只有这里有精品| 国产精品视频麻豆| 久草免费资源站| 天堂在线一区二区| 青草全福视在线| 欧美大胆视频| 成人h视频在线| 99爱在线观看| xxxx性欧美| 无码国产伦一区二区三区视频 | 久久黄色av网站| 黄色aaa大片| 欧美亚洲愉拍一区二区| 国产亚洲欧美精品久久久久久| 久久久久久久久久久99999| 日本一二三四区视频| 亚洲免费在线| 男人天堂网站在线| 中文字幕永久免费| 狠狠爱综合网| 一区二区冒白浆视频| 久久a爱视频| 国产一区二区视频在线观看| sm久久捆绑调教精品一区| 日日狠狠久久偷偷四色综合免费 | 久久99精品国产91久久来源| 国产毛片视频网站| 亚洲蜜桃视频| 日韩欧美视频一区二区三区四区| 超碰97久久国产精品牛牛| 国产精品久久久久免费a∨大胸 | 9l视频白拍9色9l视频| 在线亚洲观看| 日本香蕉视频在线观看| 91亚洲一区| 日韩精品在在线一区二区中文| 国产另类在线| 亚洲精品日产aⅴ| 国产精品4hu.www| 日韩美女视频在线观看| 色黄视频在线观看| 欧美激情精品久久久久久黑人| 米奇精品一区二区三区| 国产亚洲aⅴaaaaaa毛片| 天堂网av2014| 亚洲激情视频在线播放| www.xxx国产| 91精品麻豆日日躁夜夜躁| 中文字幕在线观看你懂的| 日韩欧美在线免费观看| 国产免费av一区二区| 亚洲国产毛片aaaaa无费看| 顶臀精品视频www| 国产精品美女久久福利网站| 公肉吊粗大爽色翁浪妇视频| 久久久激情视频| 午夜在线观看一区| 久久久久久97三级| 亚洲日本精品视频| 久久久久久久久久久久久夜| 加勒比一区二区| 久久久99久久| 欧洲av一区二区三区| 日本一区二区三区国色天香| 亚洲а∨天堂久久精品2021| 日本一区二区三区dvd视频在线 | 国产精品国产精品国产专区不蜜 | 成人av在线资源网| 免费看三级黄色片| 国产91色综合久久免费分享| 美女露出粉嫩尿囗让男人桶| 成人激情免费网站| 无码人妻精品一区二区三应用大全| 99久久久国产精品| 美女久久久久久久久久| 日本一区二区免费在线| 美女网站视频色| 中文字幕日本不卡| 免费在线观看黄色av| 亚洲成人免费视| 日本va欧美va国产激情| 色天天综合久久久久综合片| 中文字幕av网站| 欧美一级淫片007| 黄频网站在线观看| 亚洲精品丝袜日韩| 婷婷成人激情| 欧美激情极品视频| xxxxx性欧美特大| 国产有码在线一区二区视频| 亚洲国产精品免费视频| 国产日韩在线一区二区三区| 免费久久久久久久久| 亚洲免费不卡| 欧美午夜在线| 亚洲精品无码久久久久久| 日本v片在线高清不卡在线观看| 亚洲高清视频免费| av亚洲产国偷v产偷v自拍| 亚洲精品国产91| 亚洲人成7777| aaaaaa毛片| 91精品在线观看入口| 天天躁日日躁狠狠躁喷水| 亚洲一区www| av在线不卡免费| 国产精品成人aaaaa网站| 日韩免费精品| 日韩av高清在线播放| 一区二区电影在线观看| 鲁一鲁一鲁一鲁一色| 久久se精品一区二区| 国产传媒第一页| 亚洲精品综合在线| 五月天婷婷导航| 欧美成人一区二区三区片免费| 久久精品色图| 欧美精品国产精品日韩精品| 国产一区影院| 精品午夜一区二区三区| 国产精品久久久久久影院8一贰佰 国产精品久久久久久麻豆一区软件 | 人交獸av完整版在线观看| 亚洲精品www久久久久久广东| 亚洲美女自拍偷拍| 欧美日韩国产欧| 我要看一级黄色大片| 成人av在线资源网| 紧身裙女教师波多野结衣| 在线视频欧美精品| 殴美一级特黄aaaaaa| xxx欧美精品| 日本欧美一区| 农村寡妇一区二区三区| 激情六月综合| 黄页网站在线看| 亚洲欧洲av另类| 91丨九色丨海角社区| 亚洲男人天堂手机在线| 91超碰在线免费| 99中文视频在线| 正在播放日韩欧美一页| 中文字幕有码av| 国产日韩影视精品| 在线免费黄色av| 日韩精品中文在线观看| 3344国产永久在线观看视频| www.久久草| 欧美一区91| 韩国一区二区在线播放| 国产精品久久久久aaaa| 亚洲天堂网视频| 色综久久综合桃花网| 久久av影院| 午夜午夜精品一区二区三区文| 久久在线精品| 精品人妻中文无码av在线| 日本精品一级二级| 国产黄在线看| 国产精品久久久久久久久久免费| 国产精品免费大片| 韩国一区二区av| 国产亚洲女人久久久久毛片| 黄色片中文字幕| 亚洲欧美制服综合另类| 欧美va在线| 亚洲视频小说| 久久99精品网久久| 中文字幕影音先锋| 欧美va亚洲va| 久草在线资源福利站| 欧美精品七区| 日本在线播放一区二区三区| 欧美日韩生活片| 欧美浪妇xxxx高跟鞋交| 超碰在线观看免费版| 国产精品久久久久久久小唯西川| 亚洲黄色免费| 免费在线观看你懂的| 欧美影视一区在线| 久久精品视频免费看| 成人动漫在线观看视频| 欧美亚洲自偷自偷| 99国产精品无码| 日韩亚洲欧美一区二区三区| 福利小视频在线| 久久亚洲精品欧美| 蜜臀久久99精品久久久久久9| 中文字幕五月天| 亚洲第一网站男人都懂| 欧美18—19sex性hd| 一区二区三区国产福利| 粉嫩欧美一区二区三区高清影视| 国产精品第5页| xxx欧美精品| 日本三级久久| 天天干天天干天天干天天干天天干| 亚洲久本草在线中文字幕| 视频在线观看免费高清| 亚洲精品影视| 成熟人妻av无码专区| 日韩欧美自拍偷拍| 免费看av不卡| 青青草免费在线视频观看| 91麻豆精品秘密| 国产乱色精品成人免费视频| 日本久久91av| 欧美视频一区| 伊人影院综合网| 精品久久久久久亚洲综合网|