chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

什么是段錯(cuò)誤?

工程師 ? 來源:聚優(yōu)致成 ? 作者:聚優(yōu)致成 ? 2020-09-11 14:04 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

來源:聚優(yōu)致成

一、什么是段錯(cuò)誤?一旦一個(gè)程序發(fā)生了越界訪問,cpu 就會(huì)產(chǎn)生相應(yīng)的保護(hù),于是 segmentation fault 就出現(xiàn)了,通過上面的解釋,段錯(cuò)誤應(yīng)該就是訪問了不可訪問的內(nèi)存。

這個(gè)內(nèi)存區(qū)要么是不存在的,要么是受到系統(tǒng)保護(hù)的,還有可能是缺少文件或者文件損壞。

二、段錯(cuò)誤產(chǎn)生的原因下面是一些典型的段錯(cuò)誤的原因:

非關(guān)聯(lián)化空指針——這是特殊情況由內(nèi)存管理硬件

試圖訪問一個(gè)不存在的內(nèi)存地址(在進(jìn)程的地址空間)

試圖訪問內(nèi)存的程序沒有權(quán)利(如內(nèi)核結(jié)構(gòu)流程上下文)

試圖寫入只讀存儲(chǔ)器(如代碼段)

1、訪問不存在的內(nèi)存地址

在C代碼,分割錯(cuò)誤通常發(fā)生由于指針的錯(cuò)誤使用,特別是在C動(dòng)態(tài)內(nèi)存分配。非關(guān)聯(lián)化一個(gè)空指針總是導(dǎo)致段錯(cuò)誤。

但野指針和懸空指針指向的內(nèi)存,可能會(huì)或可能不會(huì)存在,而且可能或不可能是可讀的還是可寫的,因此會(huì)導(dǎo)致瞬態(tài)錯(cuò)誤。

#include 《stdio.h》int main (void){ int *ptr = NULL; *ptr = 0; return 0;}輸出結(jié)果:段錯(cuò)誤(核心已轉(zhuǎn)儲(chǔ))

現(xiàn)在,非關(guān)聯(lián)化這些變量可能導(dǎo)致段錯(cuò)誤:非關(guān)聯(lián)化空指針通常會(huì)導(dǎo)致段錯(cuò)誤,閱讀時(shí)從野指針可能導(dǎo)致隨機(jī)數(shù)據(jù)但沒有段錯(cuò)誤,和閱讀從懸空指針可能導(dǎo)致有效數(shù)據(jù),然后隨機(jī)數(shù)據(jù)覆蓋。

2、訪問系統(tǒng)保護(hù)的內(nèi)存地址

#include 《stdio.h》 int main (void){ int *ptr = (int *)0; *ptr = 100; return 0;}輸出結(jié)果:段錯(cuò)誤(核心已轉(zhuǎn)儲(chǔ))

3、訪問只讀的內(nèi)存地址

寫入只讀存儲(chǔ)器提出了一個(gè) segmentation fault,這個(gè)發(fā)生在程序?qū)懭胱约旱囊徊糠执a段或者是只讀的數(shù)據(jù)段,這些都是由操作系統(tǒng)加載到只讀存儲(chǔ)器。

#include 《stdio.h》#include 《string.h》 int main (void){ char *ptr = “test”; strcpy (ptr, “TEST”); return 0;}輸出結(jié)果:段錯(cuò)誤(核心已轉(zhuǎn)儲(chǔ))

#include 《stdio.h》 int main (void){ char *ptr = “hello”; *ptr = ‘H’; return 0;}輸出結(jié)果:段錯(cuò)誤(核心已轉(zhuǎn)儲(chǔ))

上述例子ANSI C代碼通常會(huì)導(dǎo)致段錯(cuò)誤和內(nèi)存保護(hù)平臺(tái)。它試圖修改一個(gè)字符串文字,這是根據(jù)ANSI C標(biāo)準(zhǔn)未定義的行為。大多數(shù)編譯器在編譯時(shí)不會(huì)抓,而是編譯這個(gè)可執(zhí)行代碼,將崩潰。

包含這個(gè)代碼被編譯程序時(shí),字符串“hello”位于rodata部分程序的可執(zhí)行文件的只讀部分?jǐn)?shù)據(jù)段。

當(dāng)加載時(shí),操作系統(tǒng)與其他字符串和地方常數(shù)只讀段的內(nèi)存中的數(shù)據(jù)。當(dāng)執(zhí)行時(shí),一個(gè)變量 ptr 設(shè)置為指向字符串的位置,并試圖編寫一個(gè)H字符通過變量進(jìn)入內(nèi)存,導(dǎo)致段錯(cuò)誤。

編譯程序的編譯器不檢查作業(yè)的只讀的位置在編譯時(shí),和運(yùn)行類unix操作系統(tǒng)產(chǎn)生以下運(yùn)行時(shí)發(fā)生 segmentation fault。

可以糾正這個(gè)代碼使用一個(gè)數(shù)組而不是一個(gè)字符指針,這個(gè)棧上分配內(nèi)存并初始化字符串的值:

#include 《stdio.h》 int main (void){ char ptr[] = “hello”; ptr[0] = ‘H’; return 0;}

即使不能修改字符串(相反,這在C標(biāo)準(zhǔn)未定義行為,在C char *類型,所以沒有隱式轉(zhuǎn)換原始代碼,在c++的 const char *類型,因此有一個(gè)隱式轉(zhuǎn)換,所以編譯器通常會(huì)抓住這個(gè)特定的錯(cuò)誤。

4、空指針廢棄

因?yàn)槭且粋€(gè)很常見的程序錯(cuò)誤空指針廢棄(讀或?qū)懺谝粋€(gè)空指針,用于C的意思是“沒有對(duì)象指針”作為一個(gè)錯(cuò)誤指示器),大多數(shù)操作系統(tǒng)內(nèi)存訪問空指針的地址,這樣它會(huì)導(dǎo)致段錯(cuò)誤。

#include 《stdio.h》 int main (void){ int *ptr = NULL; printf (“%d\n”, *ptr); return 0;}輸出結(jié)果:段錯(cuò)誤(核心已轉(zhuǎn)儲(chǔ))

這個(gè)示例代碼創(chuàng)建了一個(gè)空指針,然后試圖訪問它的值(讀值)。在運(yùn)行時(shí)在許多操作系統(tǒng)中,這樣做會(huì)導(dǎo)致段錯(cuò)誤。

非關(guān)聯(lián)化一個(gè)空指針,然后分配(寫一個(gè)值到一個(gè)不存在的目標(biāo))也通常會(huì)導(dǎo)致段錯(cuò)誤。

#include 《stdio.h》 int main (void){ int *ptr = NULL; *ptr = 1; return 0;}輸出結(jié)果:段錯(cuò)誤(核心已轉(zhuǎn)儲(chǔ))

下面的代碼包含一個(gè)空指針,但當(dāng)編譯通常不會(huì)導(dǎo)致段錯(cuò)誤,值是未使用的。因此,廢棄通常會(huì)被優(yōu)化掉,死代碼消除。

#include 《stdio.h》 int main (void){ int *ptr = NULL; *ptr; return 0;}

還有,比如malloc 動(dòng)態(tài)分配內(nèi)存,釋放、置空完成后,不可再使用該指針。

#include 《stdio.h》#include 《stdlib.h》#include 《string.h》 int main(){ char* str=(char* )malloc(100); if(*str) { return; } strcpy(str,“hello”); printf(“%s\n”,str); free(str); str=NULL; strcpy(str,“abcdef”); return 0;}輸出結(jié)果:hello段錯(cuò)誤 (核心已轉(zhuǎn)儲(chǔ))

5、堆棧溢出

#include 《stdio.h》#include 《string.h》 int main (void){ main (); return 0;}輸出結(jié)果:段錯(cuò)誤(核心已轉(zhuǎn)儲(chǔ))

上述例子的無限遞歸,導(dǎo)致的堆棧溢出會(huì)導(dǎo)致段錯(cuò)誤,但無線遞歸未必導(dǎo)致堆棧溢出,優(yōu)化執(zhí)行的編譯器和代碼的確切結(jié)構(gòu)。在這種情況下,遙不可及的代碼(返回語句)行為是未定義的。

因此,編譯器可以消除它,使用尾部調(diào)用優(yōu)化,可能導(dǎo)致沒有堆棧使用。其他優(yōu)化可能包括將遞歸轉(zhuǎn)換成迭代,給出例子的結(jié)構(gòu)功能永遠(yuǎn)會(huì)導(dǎo)致程序運(yùn)行,雖然可能不是其他堆棧溢出。

6、內(nèi)存越界(數(shù)組越界,變量類型不一致等)

#include 《stdio.h》int main (void){ char test[10]; printf (“%c\n”, test[100000]); return 0;}輸出結(jié)果:段錯(cuò)誤(核心已轉(zhuǎn)儲(chǔ))

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

    關(guān)注

    183

    文章

    7634

    瀏覽量

    143895
  • 編程
    +關(guān)注

    關(guān)注

    89

    文章

    3704

    瀏覽量

    96253
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    【EASY EAI Orin Nano開發(fā)板試用體驗(yàn)】PP-OCRV5文字識(shí)別實(shí)例搭建與移植

    魯班貓RK3588s開發(fā)板)上安裝完畢: PaddleOCR 3.0提供了一用于測(cè)試軟件功能的Python實(shí)例,只要能運(yùn)行完畢,哪怕是出現(xiàn)了錯(cuò)誤,那也說明了軟件安裝成功:from
    發(fā)表于 08-18 16:57

    電商API常見錯(cuò)誤排查指南:避免集成陷阱

    ? 在電商平臺(tái)開發(fā)中,API集成是連接系統(tǒng)、實(shí)現(xiàn)數(shù)據(jù)交換的核心環(huán)節(jié)。然而,許多開發(fā)者在集成過程中常遇到錯(cuò)誤,導(dǎo)致項(xiàng)目延遲、數(shù)據(jù)丟失或用戶體驗(yàn)下降。本文將逐步介紹常見錯(cuò)誤類型、排查方法以及預(yù)防策略
    的頭像 發(fā)表于 07-11 14:21 ?1477次閱讀
    電商API常見<b class='flag-5'>錯(cuò)誤</b>排查指南:避免集成陷阱

    如何驗(yàn)證CAN控制器的錯(cuò)誤響應(yīng)機(jī)制?

    CAN節(jié)點(diǎn)的穩(wěn)定性、可靠性和安全性得益于其強(qiáng)大的錯(cuò)誤管理機(jī)制。上一篇文章我們介紹了CAN控制器的錯(cuò)誤管理機(jī)制的工作原理。本文將基于其工作原理及ISO16845-1:2016標(biāo)準(zhǔn),為大家介紹
    的頭像 發(fā)表于 04-30 18:24 ?425次閱讀
    如何驗(yàn)證CAN控制器的<b class='flag-5'>錯(cuò)誤</b>響應(yīng)機(jī)制?

    IGBT IPM的錯(cuò)誤輸出功能

    本文將介紹“保護(hù)功能和工作時(shí)序”系列的第五個(gè)功能——“錯(cuò)誤輸出功能(FO)”。
    的頭像 發(fā)表于 03-19 17:22 ?890次閱讀
    IGBT IPM的<b class='flag-5'>錯(cuò)誤</b>輸出功能

    快速搞懂C語言程序內(nèi)存分區(qū)!

    到動(dòng)態(tài)分配的數(shù)據(jù)等內(nèi)容。(內(nèi)存分區(qū)圖示)理解這些內(nèi)存分區(qū)的結(jié)構(gòu)和特性,不僅有助于編寫更高效的代碼,還能幫助排查和解決如錯(cuò)誤、內(nèi)存泄漏、棧溢出等常見問題。以下是常見的六
    的頭像 發(fā)表于 03-14 17:37 ?1089次閱讀
    快速搞懂C語言程序內(nèi)存分區(qū)!

    程序中斷的100種寫法

    。 信號(hào)處理:在Unix/Linux系統(tǒng)中,通過信號(hào)(signal)處理機(jī)制實(shí)現(xiàn)中斷。 異常處理:由程序中的異常(如除零錯(cuò)誤、錯(cuò)誤)觸發(fā)。 3. 中斷控制器配置 中斷向量表:在嵌入式系統(tǒng)中,通過配置
    發(fā)表于 01-28 08:25

    常見xgboost錯(cuò)誤及解決方案

    XGBoost(eXtreme Gradient Boosting)是一種流行的機(jī)器學(xué)習(xí)算法,用于解決分類和回歸問題。盡管它非常強(qiáng)大和靈活,但在使用過程中可能會(huì)遇到一些常見的錯(cuò)誤。以下是一些常見
    的頭像 發(fā)表于 01-19 11:22 ?4299次閱讀

    電橋電路的常見錯(cuò)誤分析

    電橋電路的常見錯(cuò)誤分析主要包括以下幾個(gè)方面: 一、電阻值不準(zhǔn)確 電阻值不準(zhǔn)確是電橋電路常見的錯(cuò)誤之一。這可能是由于電阻本身的誤差,如電阻的標(biāo)稱值與實(shí)際值存在偏差,或者電阻老化、溫度變化等因素導(dǎo)致
    的頭像 發(fā)表于 01-09 10:08 ?1623次閱讀

    GPIO錯(cuò)誤排查與解決

    在嵌入式系統(tǒng)和微控制器編程中,通用輸入輸出(GPIO)是最常見的接口之一。然而,在使用GPIO時(shí),我們可能會(huì)遇到各種錯(cuò)誤。 1. 理解GPIO GPIO是微控制器上的一組引腳,可以被配置為輸入或輸出
    的頭像 發(fā)表于 01-09 09:46 ?3291次閱讀

    RTOS中的錯(cuò)誤檢查機(jī)制

    在嵌入式應(yīng)用中,有可能發(fā)生各種各樣的錯(cuò)誤,系統(tǒng)必須能夠檢測(cè)到這些錯(cuò)誤并作出適當(dāng)?shù)捻憫?yīng)。RTOS通常內(nèi)置了一些錯(cuò)誤檢查功能,用于檢測(cè)錯(cuò)誤并向應(yīng)用提供響應(yīng)
    的頭像 發(fā)表于 01-03 14:44 ?923次閱讀

    EEPROM編程常見錯(cuò)誤及解決方案

    EEPROM(電可擦可編程只讀存儲(chǔ)器)在編程過程中可能會(huì)遇到多種錯(cuò)誤。以下是一些常見的EEPROM編程錯(cuò)誤及其解決方案: 常見錯(cuò)誤 數(shù)據(jù)寫入錯(cuò)誤 : 在寫入EEPROM時(shí),數(shù)據(jù)可能由于
    的頭像 發(fā)表于 12-16 17:08 ?6006次閱讀

    常見的GND連接錯(cuò)誤及解決方案

    GND(接地)連接在電子設(shè)計(jì)和硬件開發(fā)中至關(guān)重要,錯(cuò)誤的GND連接可能導(dǎo)致電路不穩(wěn)定、信號(hào)干擾甚至設(shè)備損壞。以下是一些常見的GND連接錯(cuò)誤及其解決方案: 一、GND網(wǎng)絡(luò)未連接 問題描述 : 在
    的頭像 發(fā)表于 11-29 16:02 ?7845次閱讀

    SQL錯(cuò)誤代碼及解決方案

    在SQL數(shù)據(jù)庫開發(fā)和管理中,常見的錯(cuò)誤代碼及其解決方案可以歸納如下: 一、語法錯(cuò)誤(Syntax Errors) 錯(cuò)誤代碼 :無特定代碼,但通常會(huì)在錯(cuò)誤消息中明確指出是語法
    的頭像 發(fā)表于 11-19 10:21 ?9648次閱讀

    常見傅里葉變換錯(cuò)誤及解決方法

    傅里葉變換是一種數(shù)學(xué)工具,用于將信號(hào)從時(shí)域轉(zhuǎn)換到頻域,以便分析其頻率成分。在使用傅里葉變換時(shí),可能會(huì)遇到一些常見的錯(cuò)誤。 1. 采樣定理錯(cuò)誤 錯(cuò)誤描述: 在進(jìn)行傅里葉變換之前,沒有正確地采樣信號(hào)
    的頭像 發(fā)表于 11-14 09:42 ?2517次閱讀

    socket編程中的錯(cuò)誤處理技巧

    Socket編程是網(wǎng)絡(luò)編程的基礎(chǔ),它允許程序之間通過TCP/IP協(xié)議進(jìn)行通信。然而,網(wǎng)絡(luò)通信是不穩(wěn)定的,可能會(huì)遇到各種問題,如網(wǎng)絡(luò)延遲、連接中斷、數(shù)據(jù)丟失等。 錯(cuò)誤處理的重要性 提高程序的健壯性
    的頭像 發(fā)表于 11-01 17:47 ?1886次閱讀