Portál AbcLinuxu, 4. května 2025 17:51

Dotaz: Valgrind, proč tyhle chyby?

Beda0 avatar 17.12.2012 13:03 Beda0 | skóre: 29
Valgrind, proč tyhle chyby?
Přečteno: 419×
Odpovědět | Admin
Dělám poměrně rozsáhlý program v C++ a Qt, použil jsem Valgrind k odhalení příčiny pádů aplikace, což se sice podařilo, ale Valgrind mi ukázal chyby, kterým nerozumím.
==7096== Invalid write of size 8
==7096==    at 0x5CA1AA3: Trida::Trida(char const*) (Trida.cpp:17)
==7096==    by 0x47D284: JinaTrida::JinaTrida(QString, QString, QWidget*) (in /cesta/program)
==7096==    by 0x45AFC5: EsteJinaTrida::mujQtSLOT(trida)(QString, QString) (in /cesta/program)
==7096==    by 0x45CE9E: EsteJinaTrida::EsteJinaTrida(QWidget*) (in /cesta/program)
==7096==    by 0x413733: main (in /cesta/program)
==7096==  Address 0x13c4c2b0 is 8 bytes after a block of size 8 alloc'd
==7096==    at 0x4C2BA77: operator new(unsigned long) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==7096==    by 0x47D276: JinaTrida::JinaTrida(QString, QString, QWidget*) (in /cesta/program)
==7096==    by 0x45AFC5: EsteJinaTrida::mujQtSLOT(trida)(QString, QString) (in /cesta/program)
==7096==    by 0x45CE9E: EsteJinaTrida::EsteJinaTrida(QWidget*) (in /cesta/program)
==7096==    by 0x413733: main (in /cesta/program)
==7096== 
==7096== Invalid write of size 8
==7096==    at 0x5CA1ABA: Trida::Trida(char const*) (Trida.cpp:18)
==7096==  Address 0x13c4c2a8 is 0 bytes after a block of size 8 alloc'd
==7096==    at 0x4C2BA77: operator new(unsigned long) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==7096== 
==7096== Invalid read of size 8
==7096==    at 0x5CA1AC2: Trida::Trida(char const*) (Trida.cpp:19)
==7096==  Address 0x13c4c2b0 is 8 bytes after a block of size 8 alloc'd
==7096==    at 0x4C2BA77: operator new(unsigned long) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==7096== 
==7096== Invalid read of size 8
==7096==    at 0x5CA1ACF: Trida::Trida(char const*) (Trida.cpp:19)
==7096==  Address 0x13c4c2a8 is 0 bytes after a block of size 8 alloc'd
==7096==    at 0x4C2BA77: operator new(unsigned long) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==7096== 
==7096== Invalid write of size 4
==7096==    at 0x5CA1AED: Trida::Trida(char const*) (Trida.cpp:24)
==7096==  Address 0x13c4c2bc is 20 bytes after a block of size 8 alloc'd
==7096==    at 0x4C2BA77: operator new(unsigned long) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
(U většiny jsem smazal "by", protože bylo stejné, jako u prvního)

Následující kód má způsobovat chyby - je v dynamické knihovně.

class Trida {
public:
    Trida(const char *archive);
    virtual ~Trida();
private:
    char* archive;
    char* tmpDir;
    int curDev;
}

Trida::Trida(const char *archive) {
    tmpDir = (char*) malloc(256);                  //radek 17
    this->archive = strdup(archive);               //radek 18
    if(tmpDir == NULL || this->archive == NULL)    //radek 19
    {
        printf("\n Allocating memory failed.");
    }

    curDev = 0;                                    //radek 24
    srand(time(NULL));
}

Trida::~Trida() {
    free(archive);
    free(tmpDir);
}

V když tohle dám do samostatného programu, Valgrind si nestěžuje.

Nechápu, kde vidí Valgrind problém a jestli to je opravdu problém nebo jen falešný poplach.

Řešení dotazu:


Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

17.12.2012 13:14 George O.
Rozbalit Rozbalit vše Re: Valgrind, proč tyhle chyby?
Odpovědět | | Sbalit | Link | Blokovat | Admin
Tak kouknu a vidim, ze treba uz na radku 18 nemas alokovany this->archive a v destructoru na nem volas free :-) A to jsem jenom nakoukl...
Beda0 avatar 17.12.2012 13:46 Beda0 | skóre: 29
Rozbalit Rozbalit vše Re: Valgrind, proč tyhle chyby?
strdup neni strcpy. Alokaci dělá sám a má se uvloňovat pomocí free, alespoň podle toho, co jsem se dočetl třeba tady.
17.12.2012 14:02 George O.
Rozbalit Rozbalit vše Re: Valgrind, proč tyhle chyby?
Zkus udelat rucni malloc/new a strcpy nebo pouzit std::string, jestli se neco zmeni :-)
Beda0 avatar 17.12.2012 14:11 Beda0 | skóre: 29
Rozbalit Rozbalit vše Re: Valgrind, proč tyhle chyby?
Ruční malloc je na řádku 17 a na ten si taky stěžuje. Pokud rozepíšu strdup na malloc a strcpy, tak si stěžuje u malloc (invalid write) i strcpy (invalid read). Pokud použiju new a delete, stěžuje si stejně.

Pokud vezmu jen ukázkový kód a dám ho do samostatného programu,tak funguje a valgrind si na nic nestěžuje.
17.12.2012 14:28 Michal Kubeček | skóre: 72 | Luštěnice
Rozbalit Rozbalit vše Re: Valgrind, proč tyhle chyby?
Odpovědět | | Sbalit | Link | Blokovat | Admin
Ta chabová hláška vypadá, jako by před vykonáním konstruktoru byla alokovaná jen tabulka virtuálních metod a ne blok pro data. Co vám (tam, kde to zlobí) ukáže sizeof(Trida)? Není možné, že to linkujete proti jiné verzi knihovny, než od které máte ten hlavičkový soubor?
Beda0 avatar 17.12.2012 15:17 Beda0 | skóre: 29
Rozbalit Rozbalit vše Re: Valgrind, proč tyhle chyby?
Díky moc, měl jsem nepořádek v hlavičkových souborech a používal jsem jinou hlavičku pro vytváření knihovny a jinou pro include do programu.
17.12.2012 16:22 DK
Rozbalit Rozbalit vše Re: Valgrind, proč tyhle chyby?
Odpovědět | | Sbalit | Link | Blokovat | Admin
a proc nepouzit QString a QStringList, kdyz uz pouzivas Qt?
Beda0 avatar 18.12.2012 07:18 Beda0 | skóre: 29
Rozbalit Rozbalit vše Re: Valgrind, proč tyhle chyby?
Tohle je zrovna část, která je v knihovně bez Qt, kde se počítá s použitím i v jiných aplikacích. Spíš by asi bylo vhodnější použít std::string když už to je C++ a ne jen C, jenže ten mi nějak nepřirostl k srdci...

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.