• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Przeciążenie operatora new

Aruba Cloud VPS - 50% taniej przez 3 miesiące!
+1 głos
736 wizyt
pytanie zadane 19 czerwca 2021 w C i C++ przez wndtcw Nowicjusz (130 p.)

Mam problem z wywołaniem konstruktora domyślnego przy tworzeniu nowych obiektów za pomocą operatora new. Chciałbym zaimplementować dynamiczną tablice wskaźników obiektów klasy Komorka. 

Komorka** K;
K = new Komorka*[Komorka::ilosc];

Przeciążyłem operator w ten sposób: 

void* operator new[](size_t size)
    {
        void* bufor = ::operator new(size);
        return bufor;
    }

ale moje przeciążenie operatora nie jest nawet wywoływane. 

Czy ktoś mógłby wytłumaczyć jak rozwiązać ten problem. 

komentarz 19 czerwca 2021 przez j23 Mędrzec (195,220 p.)
Jaki konstruktor domyślny? Tworzysz tablicę wskaźników, a tu nie ma konstruktora domyślnego.
komentarz 20 czerwca 2021 przez Oscar Nałogowiec (29,340 p.)

@wndtcw,
 Czy na pewno w miejscu gdzie robisz new[] kompilator zna tą twoją wersję operatora? Jak sprawdziłeś, że jest/nie jest wywoływany?

komentarz 20 czerwca 2021 przez wndtcw Nowicjusz (130 p.)
Myślę, że na pewno kompilator nie zna tej wersji operatora, a sprawdzałem to za pomocą debuggera.
komentarz 20 czerwca 2021 przez j23 Mędrzec (195,220 p.)

Globalnie przeciążasz, czy tylko dla klasy Komorka?

komentarz 20 czerwca 2021 przez wndtcw Nowicjusz (130 p.)
Tylko dla klasy.
komentarz 20 czerwca 2021 przez j23 Mędrzec (195,220 p.)

No to tak jak pisałem, tworzysz tablicę wskaźników, nie obiektów, zatem przeciążony new nie będzie wywołany.

Tu masz przykład, kiedy będzie wywołany:

struct foo {
    void* operator new[] (size_t size) 
    {
        std::cout << "overloaded new[]\n";
        return operator new(size);
    }
};

int main(void)
{
    auto p = new foo[666];
    
    delete[] p;
}

 

1 odpowiedź

+2 głosów
odpowiedź 19 czerwca 2021 przez tkz Nałogowiec (42,020 p.)
Powód należy do tych z grubsza oczywistych. Używając new, alokujesz pamięć na wskaźnik, nie na obiekt(mowa o konkretnie tym przypadku), co implikuje na nie-utworzenie obiektu. Następnym krokiem, którego nie pokazałeś jest przeiterowanie przez ową tablicę wskaźników i "prawdziwa" alokacja obiektu. Pamiętaj o zwolnieniu pamięci.

Jako taka uwaga poboczna. Skoro korzystasz z klas, to skorzystaj z wzorca RAII.
komentarz 20 czerwca 2021 przez wndtcw Nowicjusz (130 p.)
No dobra to rozumiem już w czym jest problem, tylko nadal za bardzo nie wiem jak przeprowadzić tą "prawdziwą" alokacje.
komentarz 20 czerwca 2021 przez tkz Nałogowiec (42,020 p.)
#include <iostream>
class C
{
    public:
    C()
    {
        std::cout<<"domyslny\n";
    }
    void* operator new[](size_t size)
    {
        void* bufor = ::operator new(size);
        return bufor;
    }
};
int main()
{
    C** c = new C*[10];
    for(int i=0; i<10;++i)
    {
        c[i] = new C[2];
    }
    for(int i=0; i<10;++i)
    {
        delete[] c[i];
    }
    delete[] c;
}

 

Podobne pytania

+1 głos
2 odpowiedzi 376 wizyt
pytanie zadane 14 czerwca 2021 w C# przez everstudybee Użytkownik (670 p.)
0 głosów
1 odpowiedź 506 wizyt
pytanie zadane 1 kwietnia 2020 w C i C++ przez kacper1445 Mądrala (5,050 p.)
0 głosów
1 odpowiedź 255 wizyt

93,106 zapytań

142,082 odpowiedzi

321,604 komentarzy

62,447 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj

Wprowadzenie do ITsec, tom 1 Wprowadzenie do ITsec, tom 2

Można już zamawiać dwa tomy książek o ITsec pt. "Wprowadzenie do bezpieczeństwa IT" - mamy dla Was kod: pasja (użyjcie go w koszyku), dzięki któremu uzyskamy aż 15% zniżki! Dziękujemy ekipie Sekuraka za fajny rabat dla naszej Społeczności!

...