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

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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

什么是段錯誤?

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

掃碼添加小助手

加入工程師交流群

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

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

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

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

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

試圖訪問一個不存在的內存地址(在進程的地址空間)

試圖訪問內存的程序沒有權利(如內核結構流程上下文)

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

1、訪問不存在的內存地址

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

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

#include 《stdio.h》int main (void){ int *ptr = NULL; *ptr = 0; return 0;}輸出結果:段錯誤(核心已轉儲)

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

2、訪問系統(tǒng)保護的內存地址

#include 《stdio.h》 int main (void){ int *ptr = (int *)0; *ptr = 100; return 0;}輸出結果:段錯誤(核心已轉儲)

3、訪問只讀的內存地址

寫入只讀存儲器提出了一個 segmentation fault,這個發(fā)生在程序寫入自己的一部分代碼段或者是只讀的數(shù)據(jù)段,這些都是由操作系統(tǒng)加載到只讀存儲器。

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

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

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

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

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

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

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

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

即使不能修改字符串(相反,這在C標準未定義行為,在C char *類型,所以沒有隱式轉換原始代碼,在c++的 const char *類型,因此有一個隱式轉換,所以編譯器通常會抓住這個特定的錯誤。

4、空指針廢棄

因為是一個很常見的程序錯誤空指針廢棄(讀或寫在一個空指針,用于C的意思是“沒有對象指針”作為一個錯誤指示器),大多數(shù)操作系統(tǒng)內存訪問空指針的地址,這樣它會導致段錯誤。

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

這個示例代碼創(chuàng)建了一個空指針,然后試圖訪問它的值(讀值)。在運行時在許多操作系統(tǒng)中,這樣做會導致段錯誤。

非關聯(lián)化一個空指針,然后分配(寫一個值到一個不存在的目標)也通常會導致段錯誤。

#include 《stdio.h》 int main (void){ int *ptr = NULL; *ptr = 1; return 0;}輸出結果:段錯誤(核心已轉儲)

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

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

還有,比如malloc 動態(tà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;}輸出結果:hello段錯誤 (核心已轉儲)

5、堆棧溢出

#include 《stdio.h》#include 《string.h》 int main (void){ main (); return 0;}輸出結果:段錯誤(核心已轉儲)

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

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

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

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

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

    關注

    183

    文章

    7642

    瀏覽量

    144530
  • 編程
    +關注

    關注

    90

    文章

    3707

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    路由器TACACS+賬號登錄時經(jīng)常報用戶密碼錯誤的問題分析

    某地M6000-S開啟TACACS+賬號登錄認證后,發(fā)現(xiàn)設備登錄經(jīng)常會上報用戶密碼錯誤,過一時間才恢復正常。
    的頭像 發(fā)表于 11-14 09:55 ?186次閱讀
    路由器TACACS+賬號登錄時經(jīng)常報用戶密碼<b class='flag-5'>錯誤</b>的問題分析

    Cortex-M0+處理器的HardFault錯誤介紹

    在ARM處理器中,如果一個程序產(chǎn)生了錯誤并且被處理器檢測到,就會產(chǎn)生錯誤異常。Cortex-M0+處理器只有一種異常用以處理錯誤:HardFault。
    的頭像 發(fā)表于 10-14 10:50 ?2918次閱讀
    Cortex-M0+處理器的HardFault<b class='flag-5'>錯誤</b>介紹

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

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

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

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

    如何驗證CAN控制器的錯誤響應機制?

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

    IGBT IPM的錯誤輸出功能

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

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

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

    程序中斷的100種寫法

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

    常見xgboost錯誤及解決方案

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

    基于Vector工具進行CAN協(xié)議錯誤幀的分析實踐

    廣播發(fā)送的短幀結構,還體現(xiàn)在其錯誤檢測機制上。通過總線數(shù)據(jù)以及總線波形來分析總線故障時,CAN協(xié)議錯誤檢測機制中豐富的錯誤幀類型能讓定位問題的效率更高。錯誤幀是CA
    的頭像 發(fā)表于 01-15 10:03 ?981次閱讀
    基于Vector工具進行CAN協(xié)議<b class='flag-5'>錯誤</b>幀的分析實踐

    電橋電路的常見錯誤分析

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

    GPIO錯誤排查與解決

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

    RTOS中的錯誤檢查機制

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

    常見電位測量錯誤及解決方案

    常見電位測量錯誤及解決方案 1. 接觸不良 錯誤描述: 在電位測量中,接觸不良是最常見的問題之一。這可能是由于探針接觸不良、氧化層、污垢或腐蝕造成的。 解決方案: 清潔探針和被測點,確保它們之間有
    的頭像 發(fā)表于 12-28 14:08 ?1875次閱讀

    EEPROM編程常見錯誤及解決方案

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