日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > 嵌入式 > 嵌入式分享
[導(dǎo)讀]因?yàn)镃語(yǔ)言不檢查數(shù)組越界,而數(shù)組又是我們經(jīng)常用的數(shù)據(jù)結(jié)構(gòu)之一,所以程序中經(jīng)常會(huì)遇到數(shù)組越界的情況,并且后果輕者讀寫(xiě)數(shù)據(jù)不對(duì),重者程序crash。

因?yàn)?a href="/tags/C語(yǔ)言" target="_blank">C語(yǔ)言不檢查數(shù)組越界,而數(shù)組又是我們經(jīng)常用的數(shù)據(jù)結(jié)構(gòu)之一,所以程序中經(jīng)常會(huì)遇到數(shù)組越界的情況,并且后果輕者讀寫(xiě)數(shù)據(jù)不對(duì),重者程序crash。下面我們來(lái)分析一下數(shù)組越界的情況:

1) 堆中的數(shù)組越界

因?yàn)槎咽俏覀冏约悍峙涞模绻浇?,那么?huì)把堆中其他空間的數(shù)據(jù)給寫(xiě)掉,或讀取了其他空間的數(shù)據(jù),這樣就會(huì)導(dǎo)致其他變量的數(shù)據(jù)變得不對(duì),如果是一個(gè)指針的話,那么有可能會(huì)引起crash

2) 棧中的數(shù)組越界

因?yàn)闂J窍蛳略鲩L(zhǎng)的,在進(jìn)入一個(gè)函數(shù)之前,會(huì)先把參數(shù)和下一步要執(zhí)行的指令地址(通過(guò)call實(shí)現(xiàn))壓棧,在函數(shù)的入口會(huì)把ebp壓棧,并把esp賦值給ebp,在函數(shù)返回的時(shí)候,將ebp值賦給esp,pop先前棧內(nèi)的上級(jí)函數(shù)棧的基地址給ebp,恢復(fù)原?;?,然后把調(diào)用函數(shù)之前的壓入棧的指令地址pop出來(lái)(通過(guò)ret實(shí)現(xiàn))。

棧是由高往低增長(zhǎng)的,而數(shù)組的存儲(chǔ)是由低位往高位存的 ,如果越界的話,會(huì)把當(dāng)前函數(shù)的ebp和下一跳的指令地址覆蓋掉,如果覆蓋了當(dāng)前函數(shù)的ebp,那么在恢復(fù)的時(shí)候esp就不能指向正確的地方,從而導(dǎo)致未可知的情況,如果下一跳的地址也被覆蓋掉,那么肯定會(huì)導(dǎo)致crash。

所謂的數(shù)組越界,簡(jiǎn)單地講就是指數(shù)組下標(biāo)變量的取值超過(guò)了初始定義時(shí)的大小,導(dǎo)致對(duì)數(shù)組元素的訪問(wèn)出現(xiàn)在數(shù)組的范圍之外,這類錯(cuò)誤也是C語(yǔ)言程序中最常見(jiàn)的錯(cuò)誤之一。

在C語(yǔ)言中,數(shù)組必須是靜態(tài)的。換而言之,數(shù)組的大小必須在程序運(yùn)行前就確定下來(lái)。由于C語(yǔ)言并不具有類似Java等語(yǔ)言中現(xiàn)有的靜態(tài)分析工具的功能,可以對(duì)程序中數(shù)組下標(biāo)取值范圍進(jìn)行嚴(yán)格檢查,一旦發(fā)現(xiàn)數(shù)組上溢或下溢,都會(huì)因拋出異常而終止程序。也就是說(shuō),C語(yǔ)言并不檢驗(yàn)數(shù)組邊界,數(shù)組的兩端都有可能越界,從而使其他變量的數(shù)據(jù)甚至程序代碼被破壞。

因此,數(shù)組下標(biāo)的取值范圍只能預(yù)先推斷一個(gè)值來(lái)確定數(shù)組的維數(shù),而檢驗(yàn)數(shù)組的邊界是程序員的職責(zé)。

一般情況下,數(shù)組的越界錯(cuò)誤主要包括兩種:數(shù)組下標(biāo)取值越界與指向數(shù)組的指針的指向范圍越界。

一、數(shù)組下標(biāo)越界簡(jiǎn)介

1、什么是數(shù)組訪問(wèn)越界?

在C語(yǔ)言中,我們可以直接通過(guò)數(shù)組下標(biāo)來(lái)訪問(wèn)數(shù)組中的元素;

如果一個(gè)數(shù)組定義為有n個(gè)元素,那么,對(duì)這n個(gè)元素(下標(biāo)為0 到 n-1的元素)的訪問(wèn)都合法,如果對(duì)這n個(gè)元素之外的訪問(wèn),就是非法的,稱為越界,例如:

int a[5] = {0}; //等價(jià) int a[5] = {0,0,0,0,0};

a[0] = 1; // ok

a[1] = 2; // ok

a[2] = 3; // ok

a[3] = 4; // ok

a[4] = 5; // ok

a[5] = 6; // 數(shù)組下標(biāo)越界

在上面代碼中,聲明一個(gè)數(shù)組a[5],該數(shù)組中只能存放5個(gè)元素,下標(biāo)索引值取值范圍0~4,超過(guò)這個(gè)范圍就屬于下標(biāo)越界;

2、訪問(wèn)越界會(huì)出現(xiàn)什么結(jié)果?

首先,它并不會(huì) 造成編譯錯(cuò)誤!就是說(shuō),C,C++ 的編譯器并不判斷和指出你的代碼訪問(wèn)越界了。一個(gè)明明是錯(cuò)誤的東西,就這樣“順利”地通過(guò)了編譯;

數(shù)組訪問(wèn)越界在運(yùn)行時(shí),它的表現(xiàn)是不定的,有時(shí)似乎什么事也沒(méi)有,程序一直運(yùn)行(當(dāng)然,某些錯(cuò)誤結(jié)果已造成);有時(shí),則是程序一下子崩潰。因此在使用數(shù)組時(shí),一定要在編程中判斷是否越界以保證程序的正確性。

二、數(shù)組下標(biāo)越界案例

#include

int main()

{

int i, a[10];

for(i = 1; i <= 10; ++i)

a[i] = 0;

return 0;

}

數(shù)組中的下標(biāo)從0開(kāi)始,那么在上面代碼中只能訪問(wèn):a[1]、a[2]、a[3]、a[4]、a[5]、a[6]、a[7]、a[8]、a[9];當(dāng)i自加到10時(shí),a[10]屬于數(shù)組下標(biāo)越界。

三、防止數(shù)組下標(biāo)越界方法

如果數(shù)組的長(zhǎng)度和下標(biāo)訪問(wèn)值弄錯(cuò),都會(huì)造成數(shù)組下標(biāo)越界;數(shù)組的下標(biāo)是從0開(kāi)始的,最大的訪問(wèn)值是數(shù)組的長(zhǎng)度-1;

//如果是整形數(shù)組

int len = sizeof(array)/sizeof(int);

//如果是字符數(shù)組

int len = sizeof(array)/sizeof(char);

//如果是浮點(diǎn)數(shù)數(shù)組

int len = sizeof(array)/sizeof(double);

//如果是浮點(diǎn)數(shù)數(shù)組

int len = sizeof(array)/sizeof(float);

for(int i = 0;i < len ; i++)

{

//.....

}

四、數(shù)組內(nèi)存溢出簡(jiǎn)介

溢出:想象一個(gè)桶,桶的容積是有限的,你裝滿了水以后,如何還要往里面裝,那么水就溢出到地面了。

C語(yǔ)言中的溢出和這個(gè)原理一樣,桶的容積就表示你定義的某一數(shù)據(jù)的內(nèi)存大小,往里面寫(xiě)入數(shù)據(jù)就表示在裝水。

案例一:一個(gè)計(jì)時(shí)器,最大計(jì) 100s 的時(shí),你讓他跑了 120 秒,它就溢出了;

案例二:兩個(gè) unsigned char,一個(gè)200,一個(gè)也是200,相加,結(jié)果也就溢出,因?yàn)?unsigned char 最大就 255 ;

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動(dòng)電源

在工業(yè)自動(dòng)化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動(dòng)力設(shè)備,其驅(qū)動(dòng)電源的性能直接關(guān)系到整個(gè)系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動(dòng)勢(shì)抑制與過(guò)流保護(hù)是驅(qū)動(dòng)電源設(shè)計(jì)中至關(guān)重要的兩個(gè)環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動(dòng)性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動(dòng)電源

LED 驅(qū)動(dòng)電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個(gè)照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動(dòng)電源易損壞的問(wèn)題卻十分常見(jiàn),不僅增加了維護(hù)成本,還影響了用戶體驗(yàn)。要解決這一問(wèn)題,需從設(shè)計(jì)、生...

關(guān)鍵字: 驅(qū)動(dòng)電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動(dòng)電源的公式,電感內(nèi)電流波動(dòng)大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計(jì) 驅(qū)動(dòng)電源

電動(dòng)汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動(dòng)汽車的核心技術(shù)之一是電機(jī)驅(qū)動(dòng)控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動(dòng)系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動(dòng)汽車的動(dòng)力性能和...

關(guān)鍵字: 電動(dòng)汽車 新能源 驅(qū)動(dòng)電源

在現(xiàn)代城市建設(shè)中,街道及停車場(chǎng)照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢(shì)逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動(dòng)電源 LED

LED通用照明設(shè)計(jì)工程師會(huì)遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動(dòng)電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動(dòng)電源的電磁干擾(EMI)問(wèn)題成為了一個(gè)不可忽視的挑戰(zhàn)。電磁干擾不僅會(huì)影響LED燈具的正常工作,還可能對(duì)周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來(lái)解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動(dòng)電源

開(kāi)關(guān)電源具有效率高的特性,而且開(kāi)關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動(dòng)電源

關(guān)鍵字: LED 驅(qū)動(dòng)電源 開(kāi)關(guān)電源

LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動(dòng)電源
關(guān)閉