在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

為什么很少有人按列去遍歷訪問二維數(shù)組呢?

學(xué)益得智能硬件 ? 來源:學(xué)益得智能硬件 ? 2023-02-12 09:47 ? 次閱讀

poYBAGPoReuAZSOOAAFbl1gz_lg854.jpg

分享一道360的C語言筆試題。x是一個行列均為1000的二維數(shù)組,下面代碼運(yùn)行效率最高的是哪個?

二維數(shù)組大家都很熟悉,正常人遍歷二維數(shù)組都是一行一行來的,為什么很少有人按列去遍歷?

這道筆試題其實(shí)考察的就是遍歷效率的問題。

選項(xiàng)A,j是行,i是列,很顯然 x[i][j] 是按列訪問,先是第一列第一個元素,然后第一列第二個元素,以此類推。

pYYBAGPoRdWAVHvyAAC5aBaWhVM911.jpg

選項(xiàng)B和選項(xiàng)C都存在按列訪問。

只有選項(xiàng)D,屬于正常的按行遍歷。

那么問題來了,為什么二維數(shù)組按行遍歷比按列遍歷來的快?

這個涉及的問題就太多了,得從CPU高速緩存講起。

e3189b6e-a9e3-11ed-bfe3-dac502259ad0.png

CPU處理速度很快,但是訪問內(nèi)存太慢,嚴(yán)重影響了機(jī)器運(yùn)行效率。

于是就出現(xiàn)了高速緩存。

從名字應(yīng)該能看出,訪問它速度確實(shí)快。

當(dāng)CPU發(fā)出內(nèi)存訪問請求時,會首先查看緩存內(nèi)是否有請求的數(shù)據(jù),如果有,直接返回,如果沒有,就要先把內(nèi)存中的數(shù)據(jù)載入緩存,再把它返回給處理器。

由于緩存比內(nèi)存貴很多,所以它的大小一般都以KB或者M(jìn)B為單位,如果是一級緩存,那就更小了。

題目中的二維數(shù)組大小接近4M,CPU在訪問的時候,緩存先從內(nèi)存抓取數(shù)據(jù),而且一般都是抓取相鄰整個數(shù)據(jù)塊,簡單點(diǎn)理解,就是當(dāng)前行以及后面的部分?jǐn)?shù)據(jù),這也符合內(nèi)存訪問局部性特征。

如果二維數(shù)組按列遍歷,就需要不斷的抓取內(nèi)存的數(shù)據(jù),降低程序效率,這也將會失去緩存的意義。






審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 處理器
    +關(guān)注

    關(guān)注

    68

    文章

    19825

    瀏覽量

    233747
  • cpu
    cpu
    +關(guān)注

    關(guān)注

    68

    文章

    11049

    瀏覽量

    216144
  • C語言
    +關(guān)注

    關(guān)注

    180

    文章

    7630

    瀏覽量

    140557

原文標(biāo)題:為什么二維數(shù)組都是一行一行訪問?

文章出處:【微信號:學(xué)益得智能硬件,微信公眾號:學(xué)益得智能硬件】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    二維數(shù)組按照某進(jìn)行重新排序

    來到這邊很久了,也從來沒自己發(fā)過帖。今天面試,出了一個對二維數(shù)組按照某進(jìn)行重新排序。小弟本來對數(shù)組這方面不是特別熟悉,想了半天結(jié)果沒做出
    發(fā)表于 03-09 22:22

    怎么求二維數(shù)組均值啊

    `怎么、行求得二維數(shù)組的均值啊`
    發(fā)表于 09-06 12:45

    二維數(shù)組循環(huán)更新程序

    程序?qū)崿F(xiàn)了把生成的一數(shù)組更新二維數(shù)組功能。基本實(shí)現(xiàn)了LabVIEW二維
    發(fā)表于 10-13 13:20

    任意數(shù)指定排序2數(shù)組

    本帖最后由 ltoad 于 2015-12-9 23:11 編輯 輸入為一個二維數(shù)組A,數(shù)不定要求以指定進(jìn)行排序,比如指定第0,
    發(fā)表于 12-09 23:02

    C語言二維數(shù)組的定義和引用

    線性排列的。如何在一存儲器中存放二維數(shù)組,可有兩種方式:一種是行排列, 即放完一行之
    發(fā)表于 07-12 08:55

    二維數(shù)組冒泡排序

    Labview中對于一數(shù)組可以直接排序,但如果是二維數(shù)組時,特別是字符串類型二維數(shù)組,某一
    發(fā)表于 09-30 16:06

    請問C語言怎么實(shí)現(xiàn)在二維數(shù)組里循環(huán)遍歷

    怎么用C語言實(shí)現(xiàn)在二維數(shù)組里循環(huán)遍歷
    發(fā)表于 03-17 04:35

    C語言程序設(shè)計(jì)教程之二維數(shù)組如何應(yīng)用二維數(shù)組的資料概述

    本文檔的主要內(nèi)容詳細(xì)介紹的是C語言程序設(shè)計(jì)教程之二維數(shù)組如何應(yīng)用二維數(shù)組的資料概述主要內(nèi)容包括了:1 了解二維
    發(fā)表于 10-26 16:48 ?3次下載

    螺旋遍歷二維數(shù)組漫畫講解

    來自公眾號:程序員小灰 第天 什么意思?我們來舉個例子,給定下面這樣一個二維數(shù)組: 我們需要從左上角的元素1開始,按照順時針進(jìn)行螺旋遍歷
    的頭像 發(fā)表于 11-26 14:01 ?1955次閱讀

    二維數(shù)組數(shù)組指針以及指針數(shù)組

    二維數(shù)組數(shù)組指針以及指針數(shù)組
    的頭像 發(fā)表于 08-16 09:02 ?3077次閱讀

    C語言—二維數(shù)組介紹

    定義一個兩行三二維數(shù)組,總共有6個元素
    的頭像 發(fā)表于 09-11 14:51 ?1180次閱讀
    C語言—<b class='flag-5'>二維</b><b class='flag-5'>數(shù)組</b>介紹

    二維數(shù)組存儲最小元素是怎么實(shí)現(xiàn)的?

    二維數(shù)組存儲最小元素是怎么實(shí)現(xiàn)的?? 在計(jì)算機(jī)編程中,數(shù)組是一種非常重要的數(shù)據(jù)結(jié)構(gòu)之一。它用于存儲一系列相同類型的變量,這些變量被放入單一的數(shù)組中并通過一個唯一的編號(稱為
    的頭像 發(fā)表于 09-13 11:17 ?755次閱讀

    python怎么創(chuàng)建二維數(shù)組

    它們的優(yōu)缺點(diǎn)和一些常見的操作。 使用嵌套列表創(chuàng)建二維數(shù)組: 嵌套列表是Python中創(chuàng)建二維數(shù)組最簡單和最基本的方法之一。每個內(nèi)部的列表都代表了一行或者一
    的頭像 發(fā)表于 11-21 15:10 ?4462次閱讀

    python如何定義二維數(shù)組

    在Python中,可以通過使用列表嵌套的方式來定義二維數(shù)組。具體步驟如下: Step 1: 創(chuàng)建一個空的二維列表 要創(chuàng)建一個空的二維數(shù)組,
    的頭像 發(fā)表于 11-21 15:12 ?2251次閱讀

    將一數(shù)組轉(zhuǎn)為二維python

    過程。接下來,我將為你詳盡、詳實(shí)、細(xì)致地介紹四種常用的方法。 方法一:使用列表推導(dǎo)式(List Comprehension) 這是一種簡單而又優(yōu)雅的方法,可以快速將一數(shù)組轉(zhuǎn)換為二維數(shù)組
    的頭像 發(fā)表于 11-23 14:54 ?5919次閱讀
    主站蜘蛛池模板: 亚洲欧洲一二三区 | 国产成人精品三级 | 噜噜噜噜噜久久久久久91 | 美女免费视频一区二区三区 | 国产无套粉嫩白浆 | 亚洲精品卡1卡二卡3卡四卡 | 中国一级特黄aa毛片大片 | 伊人97在线| 成人三级毛片 | 六月丁香深爱六月综合激情 | 国产精品热久久毛片 | 亚洲一区在线视频 | 欧美有码视频 | 成人伊人青草久久综合网 | 亚洲最大色网站 | 日本三级强在线观看 | 国产资源在线观看 | h视频在线观看免费网站 | 四虎最新紧急入口 | 一级片aaa| sihu永久在线播放地址 | 国产高清不卡一区二区 | 精品一区二区三区免费毛片爱 | 99热成人精品热久久669 | 国产伦精品一区二区三区女 | 九九久久国产精品大片 | 中文字幕人成不卡一区 | 亚洲禁片 | 免费免播放器在线视频观看 | 中文天堂 | 老司机狠狠k免费毛片 | 在线免费看片a | 性生交酡| 狠狠狠狠狠狠 | 手机看片国产精品 | 插菊综合网 | 亚洲午夜大片 | 丁香月婷婷 | 人人做人人澡人人人爽 | h在线免费| 来啊mm影院亚洲mm影院 |