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

Zmienna wskaźnikowa w klasie

Object Storage Arubacloud
0 głosów
511 wizyt
pytanie zadane 14 marca 2019 w C i C++ przez Curiosis Użytkownik (540 p.)

Witajcie. Czy dobrze wykonałem poniższe polecenie?

Utwórz klasę zawierającą zmienną wskaźnikową bez konstruktora kopiującego.
#include "pch.h"
#include "Cukierki.h"
#include <cstdlib>

int main()
{
	Cukierki C1("zielony", 8);
	Cukierki C2;
	system("PAUSE");
}


============================================================

#pragma once
#include <iostream>
#include <string>


class Cukierki
{
private:
	std::string kolorCukierka;
	int *liczbaCukierkow;


public:
	Cukierki(std::string kolorCukierka = "czerwony", int liczbaCukierkow = 5);
	virtual ~Cukierki();
};


=========================================================



#include "pch.h"
#include "Cukierki.h"


Cukierki::Cukierki(std::string kolor, int liczba):
	kolorCukierka(kolor), liczbaCukierkow(&liczba)
{
	this->kolorCukierka = kolorCukierka;
	this->liczbaCukierkow = liczbaCukierkow;
	std::cout << std::endl << "Zadzialal konstruktor" << std::endl;
	std::cout << kolorCukierka << liczba << std::endl;
}


Cukierki::~Cukierki()
{

}

 

1 odpowiedź

0 głosów
odpowiedź 14 marca 2019 przez adrian17 Ekspert (344,860 p.)

Nie. Niektóre kompilatory mogą znaleźć problemy za mnie, więc pozwolę sobię pomóc:

<source>:21:44: warning: initializing pointer member 'liczbaCukierkow' with the stack address of parameter 'liczba' [-Wdangling-field]
    kolorCukierka(kolor), liczbaCukierkow(&liczba)
                                           ^~~~~~

Przypisujesz do `liczbaCukierkow` wskaźnik na zmienną tymczasową. Nie ma to wiele sensu. (W zadaniu nie chodzi aby o to, by ta klasa trzymała jakąś zmienną zaalokowaną dynamicznie pod tym adresem?)

<source>:23:25: warning: assigning field to itself [-Wself-assign-field]
    this->kolorCukierka = kolorCukierka;
                        ^
<source>:24:27: warning: assigning field to itself [-Wself-assign-field]
    this->liczbaCukierkow = liczbaCukierkow;
                          ^

Przipisujesz pole do samego siebie. Nie wiem czemu. W końcu linię wyżej już ustawiłeś wartości zmiennych.

Podobne pytania

0 głosów
2 odpowiedzi 272 wizyt
pytanie zadane 29 listopada 2018 w C i C++ przez Ciecho Nowicjusz (150 p.)
0 głosów
1 odpowiedź 527 wizyt
pytanie zadane 26 października 2020 w C i C++ przez komboboost0 Użytkownik (570 p.)
0 głosów
1 odpowiedź 516 wizyt
pytanie zadane 29 stycznia 2019 w C i C++ przez Giero112 Nowicjusz (170 p.)

92,556 zapytań

141,403 odpowiedzi

319,559 komentarzy

61,942 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.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...