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