From: spider <spider@lsi.bas-net.by>
To: ALT Linux Community <community@lists.altlinux.org>
Subject: Re: [Comm] Segmentation fault
Date: Tue, 20 Dec 2005 01:50:31 +0200
Message-ID: <43A74747.9070200@lsi.bas-net.by> (raw)
In-Reply-To: <43A76008.3000305@rambler.ru>
Dmitry A. Kharitonov wrote:
> Segmentation fault - что это такое и как с этим бороться?
>
Обращение к тем участкам адресного пространства, которое не
отображено на реальную память, вызывает исключение процессора
SIGSEGV. Это происходит исключительно из-за небрежного
программирования. Чаще всего встречается при залезании за границу
запрошенного участка памяти, например, при обработке массивов.
Есть тулза в дистрибутиве AM 2.4 -- valgrind. Она позволяет оттрассировать
программу на предмет небрежного программирования.
Бороться в С с SIGSEGV очень просто:
-- проверять в обязательном порядке возврат от *всех* системных вызовов;
-- это же делать и для своих вызовов:
-- аккуратно работать с памятью -- каждому malloc() надо дать по free().
Никогда не вставайте из-за компьютера, если для каждого malloc() не
написан его free(), даже поссать не вставайте и даже гуще:-).
-- если работаете с массивами, тщательно проверяйте работу на их краях под
отладчиком, записывайте адреса, которые Вы виите в отладчике на бумажку,
не ленитесь.
-- есть дурная манера запустить наскоро собранную программу и получив
SIGSEGV лезть в отладчик -- надот в обязательном порядке начать с
отладчика
-- в этом случае Вы можете не получить SIGSEGV совсем. Вспомним, как от
первого в жизни стакана водки или от первой цигарки нас валило на забор
и тошнило, так и с программированием -- надо пересилить себя поначалу и
получать потом кайф по полной программе от работы под отладчиком.
-- часто бывает, что под отладчиком все работает, а без него валится --
это 100 %
вылет за границу массива, просто всегда есть запас от нуля до нескольких
байт
сзади нашего массива, ведь аллокатор нам наливает округляя по машинное слово
в большую сторону, за счет чего можно и незаметить как последний байт
залетел
за линию;
-- используйте тулзы типа valgrind для контроля сформированного кода на
предмет
состояния кучи -- если какая либо библиотека имеет проблемы, что часто
бывает,
используйте ее очень осторожно, а лучше найдите замену.
-- пишите на С в стиле фортрана -- не выпендривайтесь и не экономьте на
нажатиях
клавиш. Не пишите if((bits=malloc(...))!=NULL). Разбейте это на внятные
части, и напишите
каждую в своей строке. Не лепите в одну строку скобки, возвраты, брики
-- каждому
оператору по своей строчке.
-- в каждой строке не более одного выражения или оператора -- отладчик
работает с
отдельными строками исходного кода, а не элементами языка, и Вы просто
не сможете
остановиться там, где хотите.
-- самое главное правило -- ни кусочка кода, который бы Вы не прокачали
через
отладчик.
-- 2 опции -W -Walll -- обязательны. Добейтесь абсолютно чистой компиляции.
-- никогда не опускайте того, что язык С позволяет опустить -- всегда
все определяйте явно.
Особенно это важно для деклараций. Неявные возвраты -- еще одна причина
проблем.
Все определяйте явно и отдельно. Если у вас даже сотня целых, не
перечисляйте
их за одним int, а запишите каждый в отдельной строке. Если это Вам
трудно --
это просто у Вас плохой редактор.
-- забудьте навсегда про оптимизацию -- за всю историю компиляторов для
C эта
фича работала без ошибок на PC только в Watcom и TopSpeed. Для gcc это
вообще
не светит. Да и на PC с ее тремя все время занятыми регистрами
оптимизация --
просто обман.
next prev parent reply other threads:[~2005-12-19 23:50 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2005-12-20 1:36 Dmitry A. Kharitonov
2005-12-19 23:50 ` spider [this message]
2005-12-20 7:14 ` Dmitry A. Kharitonov
2005-12-20 8:49 ` Gleb Stiblo
2005-12-20 9:44 ` Genix
2005-12-22 18:58 ` [Comm] " Michael Shigorin
2005-12-22 18:58 ` Michael Shigorin
2005-12-20 15:22 ` [Comm] " Alexey Morsov
2005-12-20 8:41 ` [Comm] Re: [Hardware] " Michael Shigorin
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=43A74747.9070200@lsi.bas-net.by \
--to=spider@lsi.bas-net.by \
--cc=community@lists.altlinux.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
ALT Linux Community general discussions
This inbox may be cloned and mirrored by anyone:
git clone --mirror http://lore.altlinux.org/community/0 community/git/0.git
# If you have public-inbox 1.1+ installed, you may
# initialize and index your mirror using the following commands:
public-inbox-init -V2 community community/ http://lore.altlinux.org/community \
mandrake-russian@linuxteam.iplabs.ru community@lists.altlinux.org community@lists.altlinux.ru community@lists.altlinux.com
public-inbox-index community
Example config snippet for mirrors.
Newsgroup available over NNTP:
nntp://lore.altlinux.org/org.altlinux.lists.community
AGPL code for this site: git clone https://public-inbox.org/public-inbox.git