电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

通過Java視角簡單談談局部性原理

瀏覽:115日期:2022-08-09 09:14:20
局部性原理

程序在訪問數據時,都趨于聚集在一片連續的區域中,這被稱為局部性原理。

按時間和空間劃分為兩類:

時間局部性:如果一個數據正在被訪問,那么近期它很可能再次被訪問。 空間局部性:如果某一個位置的數據被訪問,那么這個問題附近的數據很可能被訪問。

針對局部性原理,CPU和操作系統都有具體的實現。

本文主要總結梳理CPU和操作系統的局部性原理在Java后端中的影響與意義。

CPU空間局部性

如下圖是Java的內存模型

通過Java視角簡單談談局部性原理

我們知道CPU為提高從內存中讀數據的性能,有L1、L2、L3三個級別的高速緩存。

CPU利用局部性原理,在從內存讀取數據項到緩存時,將該內存附近的數據塊也一并讀取到緩存中,這一過程稱為預讀。

即讀取連續空間的內存要比內存隨機訪問的性能要高,這一點用Java程序可以證明。

public static void main(String[] args) {int[][] arr = new int[10000][10000];int sum = 0;long startTime = System.currentTimeMillis();for (int i = 0; i < arr.length; i++) { for (int j = 0; j < arr[0].length; j++) {sum += arr[i][j]; }}System.out.println('數組順序訪問耗時:' + (System.currentTimeMillis() - startTime) + 'ms');sum = 0;startTime = System.currentTimeMillis();for (int i = 0; i < arr.length; i++) { for (int j = 0; j < arr[0].length; j++) {sum += arr[j][i]; }}System.out.println('數組非順序訪問耗時:' + (System.currentTimeMillis() - startTime) + 'ms'); }

這是一段對二維數組循環讀取的代碼。

程序的上半部分是按數組的第二維開始順序讀取,即二維數組逐行按內存連續空間順序訪問。

下半部分則是按數組的第一維按列讀取,不是順序訪問。

分別經過10000*10000次的數組訪問后,其運行結果如下:

通過Java視角簡單談談局部性原理

由此可見,對內存的順序訪問性能優于隨機訪問。

磁盤空間局部性

在Java日常開發中,很多的中間件都需要跟磁盤文件打交道,這些磁盤數據的高性能訪問也都依托于局部性原理,比如:

MySql的日志文件 MQ消息數據

我們知道MySql的數據最終都保存在磁盤中,為減少磁盤IO提高性能,InnoDB引擎底層依托BufferPoll+redo log機制來提高mySql讀寫性能(具體可參考MySql原理總結)。而針對redo log、undo log、binlog的讀寫避免不了磁盤IO,那么這里就利用操作系統的PageCache機制,對磁盤數據順序讀寫,使得磁盤IO的性能近乎于內存性能。

我們常說kafka和rocketMQ是高性能的消息中間件,其中一部分高性能就依托于對磁盤文件的順序讀寫。比如commit log的順序寫入,kafka中partition、rockerMQ中consumerQueue中消息的順序讀寫。同樣的也是利用操作系統的PageCache機制。

PageCache

頁緩存(PageCache)是OS對文件的緩存,用于加速對文件的讀寫。一般來說,程序對文件進行順序讀寫的速度幾乎接近于內存的讀寫速度,主要原因就是由于OS使用PageCache機制對讀寫訪問操作進行了性能優化,將一部分的內存用作PageCache。

對于數據的寫入,OS會先寫入至Cache內,隨后通過異步的方式由pdflush內核線程將Cache內的數據刷盤至物理磁盤上。

對于數據的讀取,如果一次讀取文件時出現未命中PageCache的情況,OS從物理磁盤上訪問讀取文件的同時,會順序對其他相鄰塊的數據文件進行預讀取。

而PageCache就是局部性原理的實現。

時間局部性

時間局部性可能在我們日常業務開發中體現得更明顯。

類似LRU緩存都是其具體實現。

另外CPU的指令重排序也貼點邊,比如對一個數據的訪問計算,優先將于這數據有關的指令排在一起處理。

參考

知乎:如何理解操作系統中的局部性原理 gitHub:RocketMQ設計文檔總結

到此這篇通過Java視角簡單談談局部性原理的文章就介紹到這了,更多相關Java局部性原理內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Java
相關文章:
主站蜘蛛池模板: 稳尚教育加盟-打造高考志愿填报平台_新高考志愿填报加盟_学业生涯规划加盟 | 耐火浇注料价格-高强高铝-刚玉碳化硅耐磨浇注料厂家【直销】 | 浙江寺庙设计-杭州寺院设计-宁波寺庙规划_汉匠 | 定制/定做冲锋衣厂家/公司-订做/订制冲锋衣价格/费用-北京圣达信 | 沈阳真空机_沈阳真空包装机_沈阳大米真空包装机-沈阳海鹞真空包装机械有限公司 | 苏州工作服定做-工作服定制-工作服厂家网站-尺品服饰科技(苏州)有限公司 | 对照品_中药对照品_标准品_对照药材_「格利普」高纯中药标准品厂家-成都格利普生物科技有限公司 澳门精准正版免费大全,2025新澳门全年免费,新澳天天开奖免费资料大全最新,新澳2025今晚开奖资料,新澳马今天最快最新图库 | 米顿罗计量泵(科普)——韬铭机械 | 商标转让-购买商标专业|放心的商标交易网-蜀易标商标网 | 皮带式输送机械|链板式输送机|不锈钢输送机|网带输送机械设备——青岛鸿儒机械有限公司 | 酒吧霸屏软件_酒吧霸屏系统,酒吧微上墙,夜场霸屏软件,酒吧点歌软件,酒吧互动游戏,酒吧大屏幕软件系统下载 | 众品家具网-家具品牌招商_家具代理加盟_家具门户的首选网络媒体。 | 塑料造粒机「厂家直销」-莱州鑫瑞迪机械有限公司 | 深圳宣传片制作-企业宣传视频制作-产品视频拍摄-产品动画制作-短视频拍摄制作公司 | 液压升降货梯_导轨式升降货梯厂家_升降货梯厂家-河南东圣升降设备有限公司 | 北京公司注册_代理记账_代办商标注册工商执照-企力宝 | 高压包-点火器-高压发生器-点火变压器-江苏天网 | 合肥白癜风医院_[治疗白癜风]哪家好_合肥北大白癜风医院 | 膜结构车棚|上海膜结构车棚|上海车棚厂家|上海膜结构公司 | 传动滚筒,改向滚筒-淄博建凯机械科技有限公司 | 不锈钢复合板厂家_钛钢复合板批发_铜铝复合板供应-威海泓方金属复合材料股份有限公司 | 电镀电源整流器_高频电解电源_单脉双脉冲电源 - 东阳市旭东电子科技 | 高速混合机_锂电混合机_VC高效混合机-无锡鑫海干燥粉体设备有限公司 | 软瓷_柔性面砖_软瓷砖_柔性石材_MCM软瓷厂家_湖北博悦佳软瓷 | 气力输送_输送机械_自动化配料系统_负压吸送_制造主力军江苏高达智能装备有限公司! | 法钢特种钢材(上海)有限公司 - 耐磨钢板、高强度钢板销售加工 阀门智能定位器_电液动执行器_气动执行机构-赫尔法流体技术(北京)有限公司 | 安全光栅|射频导纳物位开关|音叉料位计|雷达液位计|两级跑偏开关|双向拉绳开关-山东卓信机械有限公司 | 东莞市踏板石餐饮管理有限公司_正宗桂林米粉_正宗桂林米粉加盟_桂林米粉加盟费-东莞市棒子桂林米粉 | 沈阳网站建设_沈阳网站制作_沈阳网页设计-做网站就找示剑新零售 沈阳缠绕膜价格_沈阳拉伸膜厂家_沈阳缠绕膜厂家直销 | 北京中航时代-耐电压击穿试验仪厂家-电压击穿试验机 | 气弹簧定制-气动杆-可控气弹簧-不锈钢阻尼器-工业气弹簧-可调节气弹簧厂家-常州巨腾气弹簧供应商 | 高压无油空压机_无油水润滑空压机_水润滑无油螺杆空压机_无油空压机厂家-科普柯超滤(广东)节能科技有限公司 | 干粉砂浆设备_干混砂浆生产线_腻子粉加工设备_石膏抹灰砂浆生产成套设备厂家_干粉混合设备_砂子烘干机--郑州铭将机械设备有限公司 | 不锈钢钢格栅板_热浸锌钢格板_镀锌钢格栅板_钢格栅盖板-格美瑞 | 广州网站建设_小程序开发_番禺网站建设_佛山网站建设_粤联网络 | 喷码机,激光喷码打码机,鸡蛋打码机,手持打码机,自动喷码机,一物一码防伪溯源-恒欣瑞达有限公司 | 不锈钢螺丝 - 六角螺丝厂家 - 不锈钢紧固件 - 万千紧固件--紧固件一站式采购 | 网站制作优化_网站SEO推广解决方案-无锡首宸信息科技公司 | 岩棉板|岩棉复合板|聚氨酯夹芯板|岩棉夹芯板|彩钢夹芯板-江苏恒海钢结构 | 石油/泥浆/不锈钢防腐/砂泵/抽砂泵/砂砾泵/吸砂泵/压滤机泵 - 专业石油环保专用泵厂家 | 机械立体车库租赁_立体停车设备出租_智能停车场厂家_春华起重 |