Problém s kopírovacím konstruktorem v kompilátoru Dev c++ 4.9.9.2 – C / C++ – Fórum – Programujte.com
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu
Reklama
Reklama

Problém s kopírovacím konstruktorem v kompilátoru Dev c++ 4.9.9.2 – C / C++ – Fórum – Programujte.comProblém s kopírovacím konstruktorem v kompilátoru Dev c++ 4.9.9.2 – C / C++ – Fórum – Programujte.com

 

Hledá se programátor! Plat 1 800 € + bonusy (firma Boxmol.com)
VereWolf
~ Anonymní uživatel
4 příspěvky
25. 6. 2012   #1
-
0
-

Zdravím, mám problémy s kopírovacím konstructorem, který se nevolá, když požiju kteroukoliv funkci v třídě. Mám přečtenou knihu Naučte se C++ za 21 dní (2007).Zde je příklad:

 

#include <iostream>

using namespace std;

class Division
{
      public:
            Division ();
            Division (Division&);
            ~Division ();
            float GetDownValue () const {return itsDownValue;}
            float GetResultValue () const {return itsResultValue;}
            float GetUpValue () const {return itsUpValue;}
            void SetDownValue (float downValue) {itsDownValue = downValue;}
            void SetUpValue (float upValue) {itsUpValue = upValue;}
            class xNullDownValue {};
      private:
              float itsDownValue;
              float itsResultValue;
              float itsUpValue;
};

Division::Division ():
                      itsDownValue(1),
                      itsResultValue(0),
                      itsUpValue(0)
                      {
                                   cout << "Constructor" << endl;
                      }

Division::Division (Division&)
                              {
                                   cout << "copy Constructor" << endl;
                                   if (itsDownValue == 0)
                                   {
                                      throw xNullDownValue();
                                   }
                                   itsResultValue = itsUpValue/itsDownValue;
                               }
                               
Division::~Division ()
                      {
                               cout << "Destructor" << endl;
                      }
                               

int main(int argc, char *argv[])
{
    try
    {
        Division first;
        cout << first.GetResultValue () << endl;
    }
    catch (Division::xNullDownValue)
    {
        cout << "Down value is Null!" << endl;
    }
    catch (...)
    {
        cout << "error!" << endl;
    }
    cout << "Press the enter key to continue ...";
    cin.get();
    return 0;
}
Nahlásit jako SPAM
IP: 88.100.108.–
Reklama
Reklama
fnenks+1
Stálý člen
25. 6. 2012   #2
-
+1
-
Zajímavé

kopirovaci konstruktor se vola, kdyz objektu prirazujes kopii jineho objektu stejneho typu

Nahlásit jako SPAM
IP: 88.101.84.–
fnenks+1
Stálý člen
25. 6. 2012   #3
-
0
-

 zkus tohle:

#include <iostream>

using namespace std;

class Division
{
      public:
            Division ();
            Division (Division&);
            ~Division ();
            float GetDownValue () const {return itsDownValue;}
            float GetResultValue () const {return itsResultValue;}
            float GetUpValue () const {return itsUpValue;}
            void SetDownValue (float downValue) {itsDownValue = downValue;}
            void SetUpValue (float upValue) {itsUpValue = upValue;}
            class xNullDownValue {};
      private:
              float itsDownValue;
              float itsResultValue;
              float itsUpValue;
};

Division::Division ():
                      itsDownValue(1),
                      itsResultValue(0),
                      itsUpValue(0)
                      {
                                   cout << "Constructor" << endl;
                      }

Division::Division (Division& objekt)
                              {
                                   cout << "copy Constructor" << endl;
                                   if (objekt.itsDownValue == 0)
                                   {
                                      throw 0;
                                   }
                                   itsResultValue = itsUpValue/itsDownValue;
                               }
                               
Division::~Division ()
                      {
                               cout << "Destructor" << endl;
                      }
                               

int main(int argc, char *argv[])
{
    try
    {
        Division first;
        first.SetDownValue(0);
        Division two = first;
    }
    catch (int)
    {
        cout << "Down value is Null!" << endl;
    }
    catch (...)
    {
        cout << "error!" << endl;
    }
    cout << "Press the enter key to continue ...";
    cin.get();
    return 0;
}
Nahlásit jako SPAM
IP: 88.101.84.–
VereWolf
~ Anonymní uživatel
4 příspěvky
26. 6. 2012   #4
-
0
-

#3 fnenks
Ok dík. Proč jste měnil to throw, když to funguje stejně? No prostě bych rád pokračoval dál v studiu, a když občas narazím na něco, co mi není jasné, tak bych se rád zeptal nebo vyhledal. :-)

Nahlásit jako SPAM
IP: 88.100.108.–
VereWolf
~ Anonymní uživatel
4 příspěvky
26. 6. 2012   #5
-
0
-

Ještě by mě zajímalo, jak nejlépe udělat to dělení. Abych to nemusel dávat do kopírovacího constructoru. Když jsem se vzorec pokusil vložit do funkce GetResultValue (), tak mě to napsalo:

30 C:\Users\VereWolf2\Desktop\Untitled1.cpp:49 assignment of member 'Division::itsResultValue' in read-only object

#include <iostream>

using namespace std;

class Division
{
      public:
            Division ();
            Division (Division&);
            ~Division ();
            float GetDownValue () const {return itsDownValue;}
            float GetResultValue () const;
            float GetUpValue () const {return itsUpValue;}
            void SetDownValue (float downValue) {itsDownValue = downValue;}
            void SetUpValue (float upValue) {itsUpValue = upValue;}
            class xNullDownValue {};
      private:
              float itsDownValue;
              float itsResultValue;
              float itsUpValue;
};

Division::Division ():
                      itsDownValue(1),
                      itsResultValue(0),
                      itsUpValue(0)
                      {
                                   cout << "Constructor" << endl;
                      }

Division::Division (Division& object)
                              {
                                   cout << "copy Constructor" << endl;
                                   if (object.itsDownValue == 0)
                                   {
                                      throw xNullDownValue();
                                   }
                                   itsDownValue = object.GetDownValue ();
                                   itsUpValue = object.GetUpValue ();
                                   itsResultValue = itsUpValue / itsDownValue;
                               }
                               
Division::~Division ()
                      {
                               cout << "Destructor" << endl;
                      }
float Division::GetResultValue () const
{
    itsResultValue = itsUpValue / itsDownValu;
    return itsResultValue;
}

int main(int argc, char *argv[])
{
    try
    {
        float down,up;
        Division first;
        cout << "Napis horni hodnotu: ";
        cin >> up;
        cout << endl;
        first.SetUpValue(up);
        cout << "Napis dolni hodnotu: ";
        cin >> down;
        cout << endl;
        first.SetDownValue(down);
        Division two = first;
        cout << first.GetResultValue () << endl;
        cout << two.GetResultValue () << endl;
    }
    catch (Division::xNullDownValue)
    {
        cout << "Down value is Null!" << endl;
    }
    catch (...)
    {
        cout << "error!" << endl;
    }
    cout << "Press the enter key to continue ...";
    cin.get();
    cin.get();
    return 0;
}
Nahlásit jako SPAM
IP: 88.100.108.–
Martin Kozibrátka0
Stálý člen
26. 6. 2012   #6
-
0
-

Všude za GetResultValue odstraň const

Nahlásit jako SPAM
IP: 88.83.169.–
Savana.cz - neomezený webhosting za pár kaček :)
VereWolf
~ Anonymní uživatel
4 příspěvky
26. 6. 2012   #7
-
0
-

#6 Martin Kozibrátka
Dík.

Nahlásit jako SPAM
IP: 88.100.108.–
Zjistit počet nových příspěvků

Přidej příspěvek

Toto téma je starší jak čtvrt roku – přidej svůj příspěvek jen tehdy, máš-li k tématu opravdu co říct!

Ano, opravdu chci reagovat → zobrazí formulář pro přidání příspěvku

×Vložení zdrojáku

×Vložení obrázku

Vložit URL obrázku Vybrat obrázek na disku
Vlož URL adresu obrázku:
Klikni a vyber obrázek z počítače:

×Vložení videa

Aktuálně jsou podporována videa ze serverů YouTube, Vimeo a Dailymotion.
×
 
Podporujeme Gravatara.
Zadej URL adresu Avatara (40 x 40 px) nebo emailovou adresu pro použití Gravatara.
Email nikam neukládáme, po získání Gravatara je zahozen.
-
Pravidla pro psaní příspěvků, používej diakritiku. ENTER pro nový odstavec, SHIFT + ENTER pro nový řádek.
Sledovat nové příspěvky (pouze pro přihlášené)
Sleduj vlákno a v případě přidání nového příspěvku o tom budeš vědět mezi prvními.
Reaguješ na příspěvek:

Uživatelé prohlížející si toto vlákno

Uživatelé on-line: 0 registrovaných, 99 hostů

Podobná vlákna

Problem s Dev++ — založil Nostredemus

Dev-C++ problém — založil libira

Problém s dev-c++ — založil Leito

Moderátoři diskuze

 

Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032016 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý