segment fault
2019獨角獸企業(yè)重金招聘Python工程師標準>>>
一 造成segment fault,產(chǎn)生core dump的可能原因
容器使用越界問題
for(iter=q.begin();iter!=q.end();iter++)
???q.erase(iter);
deque<int> q; for(i=0;i<15;i++)q.push_back(i);//先輸出 deque<int>::iterator iter=q.begin(); for(iter=q.begin();iter!=q.end();iter++)cout<<*iter<<" "; cout<<"*q.end()為"<<*q.end()<<endl;//從這里可以看出*q.end()并不是14 //這里erase() for(iter=q.begin();iter!=q.end();iter++)q.erase(iter);這樣在erase最后一個之后會出問題,會溢出,雖然可以for(iter=q.begin();(iter+1)!=q.end();iter++)可以不溢出,但是不能erase最后一個元素。 //網(wǎng)上說因為erase后,iterator會移到它的下一個元素上,此時你在對它++, //相當于一次移動了2個位置,這樣可能會越界,就會出錯,這樣比較安會,但是還是沒有解決問題 for(iter=q.begin();iter!=q.end();)q.erase(iter++);
容器:vector、set、map常用操作,segment fault問題
1.內(nèi)存訪問越界
?a) 由于使用錯誤的下標,導致數(shù)組訪問越界
?b) 搜索字符串時,依靠字符串結束符來判斷字符串是否結束,但是字符串沒有正常的使用結束符
?c) 使用strcpy, strcat, sprintf, strcmp, strcasecmp等字符串操作函數(shù),將目標字符串讀/寫爆。應該使用strncpy, strlcpy, strncat, strlcat, snprintf, strncmp, strncasecmp等函數(shù)防止讀寫越界。
2 多線程程序使用了線程不安全的函數(shù)。
3 多線程讀寫的數(shù)據(jù)未加鎖保護。對于會被多個線程同時訪問的全局數(shù)據(jù),應該注意加鎖保護,否則很容易造成core dump
4 非法指針
a) 使用空指針
b) 隨意使用指針轉換。一個指向一段內(nèi)存的指針,除非確定這段內(nèi)存原先就分配為某種結構或類型,或者這種結構或類型的數(shù)組,否則不要將它轉換為這種結構或類型的指針,而應該將這段內(nèi)存拷貝到一個這種結構或類型中,再訪問這個結構或類型。這是因為如果這段內(nèi)存的開始地址不是按照這種結構或類型對齊的,那么訪問它時就很容易因為bus error而core dump.
5 堆棧溢出.不要使用大的局部變量(因為局部變量都分配在棧上),這樣容易造成堆棧溢出,破壞系統(tǒng)的棧和堆結構,導致出現(xiàn)莫名其妙的錯誤。
轉載于:https://my.oschina.net/u/347414/blog/173217
總結
以上是生活随笔為你收集整理的segment fault的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: I/O Performance HOWT
- 下一篇: 以色列全国路网遭到了网络攻击 造成交通拥