Подтвердить что ты не робот

Программа С++ всегда сбой При выполнении задания std::string

Я пытаюсь отладить сбой в моем приложении, который сбой (т.е. утверждает * обнаружен glibc * free(): недопустимый указатель: 0x000000000070f0c0 ***), в то время как я пытаюсь выполнить простой присвойт строке. Обратите внимание, что я компилирую в Linux-системе с gcc 4.2.4 с уровнем оптимизации, установленным на -O2. С -O0 приложение больше не сработает.

например.

std::string abc;

abc = "testString";

но если я изменил код следующим образом, он больше не сбрасывает

std::string abc("testString");

Итак, я снова почесал голову! Но интересная картина заключалась в том, что в приложении произошел сбой позже, AGAIN в другой строке. Мне показалось странным, что приложение постоянно терпело крах при назначении строки. Типичная обратная траверса выглядела бы следующим образом:

#0  0x00007f2c2663bfb5 in raise () from /lib64/libc.so.6
(gdb) bt
#0  0x00007f2c2663bfb5 in raise () from /lib64/libc.so.6
#1  0x00007f2c2663dbc3 in abort () from /lib64/libc.so.6
#2  0x00000000004d8cb7 in people_streamingserver_sighandler (signum=6) at src/peoplestreamingserver.cpp:487
#3  <signal handler called>
#4  0x00007f2c2663bfb5 in raise () from /lib64/libc.so.6
#5  0x00007f2c2663dbc3 in abort () from /lib64/libc.so.6
#6  0x00007f2c26680ce0 in ?? () from /lib64/libc.so.6
#7  0x00007f2c270ca7a0 in std::string::assign (this=0x7f2c21bc8d20, __str=<value optimized out>)
    at /home/bbazso/ThirdParty/sources/gcc-4.2.4/x86_64-pc-linux-gnu/libstdc++-v3/include/bits/basic_string.h:238
#8  0x00007f2c21bd874a in PEOPLESProtocol::GetStreamName (this=<value optimized out>,
    pRawPath=0x2342fd8 "rtmp://127.0.0.1/mp4:pop.mp4", [email protected])
    at /opt/trx-HEAD/gcc/4.2.4/lib/gcc/x86_64-pc-linux-gnu/4.2.4/../../../../include/c++/4.2.4/bits/basic_string.h:491
#9  0x00007f2c21bd9daa in PEOPLESProtocol::SignalProtocolCreated (pProtocol=0x233a4e0, [email protected])
    at peoplestreamer/src/peoplesprotocol.cpp:240

Это было действительно странное поведение, и поэтому я начал еще дальше крутиться в своем приложении, чтобы увидеть, есть ли какая-то ошибка памяти (куча или стек), которая может возникнуть, что может вызвать это странное поведение. Я даже проверил на коррупцию и проиграл с пустыми руками. В дополнение к визуальному контролю кода я также попробовал следующие инструменты:

  • Valgrind использует как memcheck, так и exp-ptrcheck
  • электрический забор
  • Libsafe
  • Я скомпилировал с -fstack-protector-all в gcc
  • Я попытался установить MALLOC_CHECK_ на 2
  • Я запускал свой код с помощью чеков lint, а также cppcheck (для проверки ошибок).
  • И я прошел через код с помощью gdb

Итак, я пробовал много вещей и все еще приходил с пустыми руками. Поэтому мне было интересно, может ли это быть чем-то вроде проблемы с компоновщиком или какой-то проблемой библиотеки, которая может вызвать эту проблему. Существуют ли какие-либо проблемы с информацией в std::string, которые делают возможным сбой в -O2 или, возможно, это не имеет никакого отношения к уровню оптимизации? Но единственный образец, который я вижу до сих пор в моей проблеме, состоит в том, что он всегда кажется, что он падает на строку, и поэтому мне было интересно, знают ли кто-нибудь о каких-либо проблемах, которые могут быть причиной такого поведения.

Спасибо большое!

4b9b3361

Ответ 1

Это предварительное предположение, использующее всю информацию, которую я могу извлечь из вашей обратной трассы.

Скорее всего, вы смешиваете и сопоставляете gcc-версию, компоновщик и libstdС++, что приводит к необычному поведению на главной машине:

  • libc - это система: /lib64/libc.so.6
  • libstdС++ находится в каталоге "ThirdParty" - это подозрения, поскольку он говорит мне, что он может быть скомпилирован в другом месте с другой целью - /home/bbazso/ThirdParty/sources/gcc-4.2.4/x86_64-pc-linux-gnu/libstdc++-v3/
  • Еще один libstdС++ в /opt: /opt/trx-HEAD/gcc/4.2.4/lib/gcc/x86_64-pc-linux-gnu/4.2.4/../../../../include/c++/4.2.4/bits/basic_string.h:491

Кроме того, GCC может смешивать систему ld вместо себя, что может вызвать дальнейшее использование более странных карт памяти.

Ответ 2

Можете ли вы повторить сбой с помощью базовой двухстрочной программы?

#include <string>

int main()
{
    std::string abc;
    abc = "testString";
}

Если это сбой, отправьте свои точные параметры компиляции/ссылки?

Если нет, начните обработку кода. Удалите строки строк за раз, пока ошибка не исчезнет. После того, как вы измените другие, которые вы можете добавить, чтобы вызвать сбой и удалить, чтобы он исчез, это поможет вам найти проблему.

Ответ 3

Как вы сказали, это странное поведение.

Чтобы быть честным, я думаю, что вы тратите время на поиск возможной ошибки со std:: strings. Строки абсолютно безопасны, если вы используете их хорошо.

В любом случае, с информацией, которую вы даете: Во-первых, вы используете потоки? Это может быть проблема с потоком. Во-вторых, вы проверяете свою программу с помощью valgrind. У вас вообще нет предупреждений?

Примечание. Наиболее важными предупреждениями valgrind являются недопустимые чтения и недопустимые записи.

PS: Как сказано в комментарии, вы, вероятно, должны использовать g++ для компиляции кода на С++;)

Ответ 4

Случилось мне из-за использования malloc для класса, в котором в качестве элементов данных были std:: strings. Tricky.