偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

計(jì)算機(jī)中的流水線技術(shù)到底是個(gè)啥?

開(kāi)發(fā) 前端
作者個(gè)人研發(fā)的在高并發(fā)場(chǎng)景下,提供的簡(jiǎn)單、穩(wěn)定、可擴(kuò)展的延遲消息隊(duì)列框架,具有精準(zhǔn)的定時(shí)任務(wù)和延遲隊(duì)列處理功能。

[[379639]]

作者個(gè)人研發(fā)的在高并發(fā)場(chǎng)景下,提供的簡(jiǎn)單、穩(wěn)定、可擴(kuò)展的延遲消息隊(duì)列框架,具有精準(zhǔn)的定時(shí)任務(wù)和延遲隊(duì)列處理功能。自開(kāi)源半年多以來(lái),已成功為十幾家中小型企業(yè)提供了精準(zhǔn)定時(shí)調(diào)度方案,經(jīng)受住了生產(chǎn)環(huán)境的考驗(yàn)。為使更多童鞋受益,現(xiàn)給出開(kāi)源框架地址:https://github.com/sunshinelyz/mykit-delay

寫(xiě)在前面

流水線技術(shù)是計(jì)算機(jī)中的一種相當(dāng)重要的技術(shù)。簡(jiǎn)單的說(shuō),流水線技術(shù)的出現(xiàn)使得計(jì)算機(jī)能夠支持并行計(jì)算,能夠并行執(zhí)行任務(wù)。盡管流水線技術(shù)非常重要,但是很多小伙伴對(duì)流水線技術(shù)還是一知半解,甚至很多小伙伴根本不知道什么是流水線技術(shù),今天,我們就一起來(lái)說(shuō)說(shuō)什么是流水線技術(shù)。

文章已收錄到:

https://github.com/sunshinelyz/technology-binghe

https://gitee.com/binghe001/technology-binghe

流水線概念

流水線是指在程序執(zhí)行時(shí),多條指令重疊進(jìn)行操作的一種準(zhǔn)并行處理的實(shí)現(xiàn)技術(shù)。各種部件同時(shí)處理是針對(duì)不同指令而言的,它們同時(shí)為多條指令的不同部分進(jìn)行工作,以提高各部件的利用率和指令的平均執(zhí)行速度。

流水線的相關(guān)參數(shù)計(jì)算包括:流水線執(zhí)行時(shí)間計(jì)算、流水線吞吐率、流水線加速比、流水線效率。

在計(jì)算機(jī)中,對(duì)于指令的操作主要分為三個(gè)部分:取指、分析和執(zhí)行。如下所示。

如果執(zhí)行取值、分析和執(zhí)行各需要1ms的話,則串行執(zhí)行三條指令的時(shí)間總共需要9ms。這是因?yàn)橐粭l執(zhí)行的操作需要經(jīng)過(guò)取指、分析和執(zhí)行三個(gè)步驟,每個(gè)步驟需要1ms,執(zhí)行一條指令的時(shí)間為3ms,則串行執(zhí)行三條指令的時(shí)間為9ms。我們可以用下圖來(lái)表示這個(gè)過(guò)程。

在上圖的表示中,貌似執(zhí)行三條指令使用9ms是沒(méi)啥問(wèn)題的。但是,如果我們把圖形改造一下,我們就會(huì)發(fā)現(xiàn)相應(yīng)的問(wèn)題。我們使用下面的圖形來(lái)表示執(zhí)行三條指令的情況。

此時(shí),我們發(fā)現(xiàn),在上圖執(zhí)行指令操作的過(guò)程中,有很多空白的格子,而空白的格子表示在執(zhí)行執(zhí)行的過(guò)程中有空余的時(shí)間片資源沒(méi)有利用起來(lái)。很顯然,沒(méi)有必要等待指令1完全執(zhí)行完畢后再執(zhí)行指令2,同樣的,沒(méi)有必要等待指令2完全執(zhí)行完畢后再執(zhí)行指令3。而且,我們發(fā)現(xiàn)按照上圖執(zhí)行完三條指令需要9ms時(shí)間。

此時(shí),如果將空余的時(shí)間片利用起來(lái),則可以使用下圖來(lái)表示。

此時(shí),在執(zhí)行三條指令的過(guò)程中,取指操作對(duì)指令1執(zhí)行完取指后,馬上對(duì)指令2進(jìn)行取指,然后又馬上對(duì)指令3進(jìn)行取指;分析操作同樣是對(duì)指令1執(zhí)行完分析后,馬上對(duì)指令2進(jìn)行分析,然后又馬上對(duì)指令3進(jìn)行分析;執(zhí)行操作也是對(duì)指令1執(zhí)行完畢后,馬上對(duì)指令2進(jìn)行執(zhí)行操作,然后又馬上對(duì)指令3進(jìn)行執(zhí)行操作。期間,將空余的時(shí)間片資源充分的利用起來(lái)了。而且,我們發(fā)現(xiàn),充分利用空余的時(shí)間片后,執(zhí)行三條指令的時(shí)間由原來(lái)的9ms變?yōu)楝F(xiàn)在的5ms。

從另一個(gè)角度,我們發(fā)現(xiàn)執(zhí)行完第一條指令時(shí),需要3ms,執(zhí)行完第二條指令時(shí),只需要在執(zhí)行完第一條指令的基礎(chǔ)上增加1ms。同樣的,執(zhí)行完第三條指令時(shí),只需要在執(zhí)行完第二條指令的基礎(chǔ)上增加1ms。以后每增加一條指令,只需要增加1ms的時(shí)間便可以執(zhí)行完此條指令。

這就是計(jì)算機(jī)中的流水線技術(shù)。接下來(lái),我們就說(shuō)說(shuō)流水線技術(shù)的相關(guān)計(jì)算問(wèn)題。

流水線計(jì)算

關(guān)于流水線計(jì)算,我們先來(lái)看一個(gè)圖。

在上圖中,我們可以看出,執(zhí)行完第一條指令時(shí),需要3ms時(shí)間,執(zhí)行完第二條指令時(shí),只需要在執(zhí)行完第一條指令的基礎(chǔ)上增加1ms;執(zhí)行完第三條指令時(shí),只需要在執(zhí)行完第二條指令的基礎(chǔ)上增加1ms。以此類(lèi)推,執(zhí)行完第n條指令時(shí),只需要在執(zhí)行第n-1條指令的基礎(chǔ)上增加1ms。說(shuō)到這里,不知道小伙伴們有沒(méi)有思考這樣一個(gè)問(wèn)題,流水線技術(shù)的這種規(guī)律就涉及到一個(gè)非常重要的概念,叫作 流水線周期。

流水線周期為執(zhí)行時(shí)間最長(zhǎng)的一段,上圖中的流水線周期為1ms

流水線的計(jì)算公式為:

  1. 1條指令執(zhí)行時(shí)間 + (指令條數(shù) -1)* 流水線周期 

流水線的理論公式如下所示。

  1. (t1 + t2 + ... + tk) + (n-1) * △t 

其中t1,t2...tk表示執(zhí)行一條指令的每個(gè)步驟分別需要的時(shí)間,n為指令的條數(shù),△t為流水線周期。

流水線的實(shí)踐公式如下所示。

  1. k*△t + (n-1) * △t 

其中,k為執(zhí)行一條指令的步驟數(shù),n為指令的條數(shù),△t為流水線周期。

這里,給小伙伴們舉一個(gè)例子。

例如,一條執(zhí)行的執(zhí)行過(guò)程可以分解為取指,分析和執(zhí)行三步,在取指時(shí)間t取指=3△t,分析時(shí)間分析=2△t,執(zhí)行時(shí)間t執(zhí)行=4△t的情況下,若按照串行方式執(zhí)行,則10條指令全部執(zhí)行完需要多少△t?若按照流水線方式執(zhí)行,流水線周期為多少△t?使用流水線方式時(shí),執(zhí)行完10條指令需要多少△t?

(1)串行方式比較簡(jiǎn)單,就是將每條指令的執(zhí)行時(shí)間進(jìn)行累加。

(3△t + 2△t + 4△t) * 10 = 90△t。

(2)在執(zhí)行一條指令的過(guò)程中,取指為3△t,分析為2△t,執(zhí)行為4△t。根據(jù)流水線中對(duì)于流水線周期的定義:流水線周期為執(zhí)行時(shí)間最長(zhǎng)的一段,所以,流水線周期為4△t。

(3)使用流水線方式時(shí),執(zhí)行完10條指令需要的時(shí)間可以使用如下方式進(jìn)行計(jì)算。

這里,我們分別計(jì)算下理論時(shí)間和實(shí)踐時(shí)間。

  • 理論時(shí)間

(3△t + 2△t + 4△t) + (10-1) * 4△t = 45△t。

  • 實(shí)踐時(shí)間

3 * 4△t + (10-1) * 4△t = 48△t。

超標(biāo)量流水線

關(guān)于超標(biāo)量流水線,我們可以使用下圖來(lái)表示。

在超標(biāo)量流水線中,有一個(gè)概念叫作度。度表示在超標(biāo)量流水線中,由幾條流水線組成。例如上面的圖中,超標(biāo)量流水線由兩條流水線組成,所以,度為2。此時(shí)的超標(biāo)量流水線可以同時(shí)進(jìn)行2個(gè)操作。也就是說(shuō),可以同時(shí)執(zhí)行兩個(gè)取指操作,可以同時(shí)執(zhí)行兩個(gè)分析操作,也可以同時(shí)執(zhí)行兩個(gè)執(zhí)行操作。

如果此時(shí)有10條指令需要執(zhí)行,使用以上超標(biāo)量流水線的話,只需要10 / 2 = 5 條指令的時(shí)間。

流水線吞吐率計(jì)算

流水線的吞吐率(TP)是指在單位時(shí)間內(nèi)流水線所完成的任務(wù)數(shù)量或輸出的結(jié)果數(shù)量。計(jì)算流水線吞吐流程的最基本的公式如下所示。

流水線最大吞吐率計(jì)算公式如下所示。

流水線的吞吐率計(jì)算問(wèn)題相對(duì)來(lái)說(shuō)還是比較簡(jiǎn)單的。

本文轉(zhuǎn)載自微信公眾號(hào)「冰河技術(shù)」,可以通過(guò)以下二維碼關(guān)注。轉(zhuǎn)載本文請(qǐng)聯(lián)系冰河技術(shù)公眾號(hào)。

 

責(zé)任編輯:武曉燕 來(lái)源: 冰河技術(shù)
相關(guān)推薦

2017-03-16 15:28:20

人工智能視覺(jué)識(shí)別

2022-04-10 19:26:07

TypeScript類(lèi)型語(yǔ)法

2024-07-12 15:08:23

Python@wraps函數(shù)

2024-08-26 14:23:56

2013-05-29 10:17:56

Hadoop分布式文件系統(tǒng)

2024-02-07 12:35:00

React并發(fā)模式concurrent

2017-03-02 14:12:13

流水線代碼Clojure

2021-12-16 15:11:59

Facebook天秤幣加密貨幣

2022-09-06 21:38:45

數(shù)字人數(shù)字孿生

2021-05-11 07:30:58

JNIJavaAPI

2022-05-04 08:38:32

Netty網(wǎng)絡(luò)框架

2021-01-28 17:41:32

Github網(wǎng)站Pull Reques

2017-02-28 15:40:30

Docker流水線Azure

2013-06-06 09:31:52

2023-10-11 18:30:39

Web系統(tǒng)程序

2021-12-26 00:01:51

Log4Shell漏洞服務(wù)器

2024-08-01 17:34:56

Promiseaxios請(qǐng)求

2021-06-26 14:22:34

Tekton流水線Kubernetes

2022-01-26 08:12:42

Jenkins開(kāi)源流水線

2020-03-07 09:47:48

AVL樹(shù)算法場(chǎng)景
點(diǎn)贊
收藏

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