Probleme mit Klassen / meine erste Klasse......
-
volkard schrieb:
int Klasse1::speicherAlter(int wald) { alter = wald; }
Hat "wald" irgendne Bedeutung oder beziehst du dich auf
einen Namen geben und diesen sinnvoll verwenden.
#include <iostream> // neue header, niemals *.h! // cstring weggelassen, c-stringfunktionen werden nicht benötigt // tipp: nimm <string> anstelle class Klasse1 // foo gefällt mir besser :) { int alter; public: inline int leseAlter() const // inline (empfehlung) + const methode { return alter; } int speicherAlter(int); }; int Klasse1::speicherAlter(int wald) // schon wieder wald? :) { alter = wald; // wald ist modern return alter; // zurück geben } int main() { std::cout << "Alter: "; // std:: <- namensraum int wald; std::cin >> wald; // wald!! Klasse1 foo; // ist nicht static, daher erst ein object erstellen foo.speicherAlter(wald); // methode aufrufen }
alles klar nun?
-
ChrissiB schrieb:
Hat "wald" irgendne Bedeutung
nein. es durfte nur nicht alter oder alt heißen, damit man den übergabeparameter nicht mit einer anderen variablen verwechselt.
würde sie alter heißen. wäre der code alter=alter komisch. würde sie alt heißen, wäre nicht klar, wie es kommt, daß alt auß der main auf einmal alt in der funktion ist. nur um komplikationen vorzubeugen, wähle ich wald.
-
Mir kommt es vor, du bist nicht volkard. Ihh glaube zu meinen, volkard sagte mal, dass er nur angemeldet postet. Naja, mal sehen.. Bei Doppeldeutungen nehme ich das (Unterstrich):
int foo(int alter_) { alter = alter_; }
-
dann doch lieber:
void foo(int alter) { this->alter = alter; }
-
int Klasse1::speicherAlter(int wald) // schon wieder wald?
{
alter = wald; // wald ist modern
return alter; // zurück geben
}was soll denn das?
warum soll alter zurpckgegeben werden? soll man das irgendwie sinnvoll auswerten können?
entweder
void Klasse1::speicherAlter( unsigned alter )
oder [cpp] int Klasse1.... { return 0; // z.b. }
ich würd anders machen, sodass es etwas prof. ist.
// 1. die membervarialbe am besten so nennen unsigned int m_alter; dann als fkt bool speichereAlter( unsigned int _value ); // man kann als namen auch ruhig alter nehmen // warum ich immer _value nehme, weil es bei setterfkt nichts gibt was da missverstanden wäre // deswegen würd ich auch english schreiben bool setAge( unsigned int _value); // weiss nicht was man hier missverstehen sollte // in der fkt dann bool Klasse1::setAge( unsigned int _value) { m_age = _value; // hier english als membervariable auch nehmen return true; // das hat dir gefällt - Studiologe - "ein rückgabewert" }
inline würd ich nicht schreiben. muss nicht sein, da der compiler das eh optimieren muesste. aber ok, tipp ruhig mehr code ( wer nach count of codes bezahlt wird )
-
newkid_ schrieb:
int Klasse1::speicherAlter(int wald) // schon wieder wald?
{
alter = wald; // wald ist modern
return alter; // zurück geben
}was soll denn das?
warum soll alter zurpckgegeben werden? soll man das irgendwie sinnvoll auswerten können?
entweder
void Klasse1::speicherAlter( unsigned alter )
oder [cpp] int Klasse1.... { return 0; // z.b. }
Stimmt, beim Schreiben habe ich zu wenig gedacht und mir noch schnell den Post von mir davor durchgelesen. Dann nimmt man lieber void als Rückgabewert.
ich würd anders machen, sodass es etwas prof. ist.
// 1. die membervarialbe am besten so nennen unsigned int m_alter; // <- hm, m_ muss doch nicht sein, ich nehme es nicht! Man sieht doch eh immer, dass es ein Member ist. Doppeldeutigkeit bei aRgumente und Member haben die ARgumente ein _ nachgestellt, die Member heißen normal. Das ist ok so, und ich komme nich durcheinander dann als fkt bool speichereAlter( unsigned int _value ); // man kann als namen auch ruhig alter nehmen // <- jo, wäre besser sogar // warum ich immer _value nehme, weil es bei setterfkt nichts gibt was da missverstanden wäre // <- hmm, sind die _*-Namen nicht nur für die Compiler registriet laut Standard? // deswegen würd ich auch english schreiben bool setAge( unsigned int _value); // weiss nicht was man hier missverstehen sollte // <- englisch ist immer besser *g* // in der fkt dann bool Klasse1::setAge( unsigned int _value) { m_age = _value; // hier english als membervariable auch nehmen return true; // das hat dir gefällt - Studiologe - "ein rückgabewert" } // dann lieber doch void returnen, notfalls ne exception werfen, wobei: was soll hier passieren?
inline würd ich nicht schreiben. muss nicht sein, da der compiler das eh optimieren muesste. aber ok, tipp ruhig mehr code ( wer nach count of codes bezahlt wird )
Hehe. Naja, ich ergänze es halt gern, obwohl ich weiß, dass der Compiler das normalerweise selber weiß, dass er hier inlinen kann. Hier habe ich es auch geschrieben, damit es deutlich wird, was der Compiler anstellt.
-
ChrissiB schrieb:
Mir kommt es vor, du bist nicht volkard. Ihh glaube zu meinen, volkard sagte mal, dass er nur angemeldet postet. Naja, mal sehen..
heute mal, wegen der serverumstellung (ist doch heute?) vergisst er andauernd meine cookies.
-
volkard schrieb:
ChrissiB schrieb:
Mir kommt es vor, du bist nicht volkard. Ihh glaube zu meinen, volkard sagte mal, dass er nur angemeldet postet. Naja, mal sehen..
heute mal, wegen der serverumstellung (ist doch heute?) vergisst er andauernd meine cookies.
Achso, alles klar.
-
ChrissiB schrieb:
volkard schrieb:
ChrissiB schrieb:
Mir kommt es vor, du bist nicht volkard. Ihh glaube zu meinen, volkard sagte mal, dass er nur angemeldet postet. Naja, mal sehen..
heute mal, wegen der serverumstellung (ist doch heute?) vergisst er andauernd meine cookies.
Achso, alles klar.
immernoch. die haben wiedermal was kaputtgespielt.
-
Hallo,
habe das Programm von ChrissiB noch ein wenig abgeändert, das läuft jetzt super, Großes Dank an ChrissiB und allen anderen, die sich so stark bemühen....aber nun habe ich doch noch ein Paar Fragen:
-
wo genau liegt der Unterschied, ob ich nun cout oder std::cout nehme ???
für das cout wird #include <iostream.h> benötigt für std::cout
#include <iostream>
Wo liegt der Unterschied ? -
Habe das Programm um name erweitert, was aber noch nicht ganz klappt.
Verwende ich char name; ist alles OK keine Fehler/ Warnungen beim Compil.
jedoch wird dann nur der Erste Buchstabe vom eingegebenem Namen wieder
zurückgegeben.
Nehme ich aber anstelle von char name; char name[15] kommt es zu mehreren
Fehlern beim compil.#include <iostream.h> class Klasse1 { private: int alter; // Variablendeklaration alter char name; public: inline int leseAlter() const // inline (Empfehlung) + const methode { return alter; // Rückgabewert alter } inline char leseName() const // inline (Empfehlung) + const methode { return name; } int speicherAlter(int); // Funktionsprototyp char speicherName(char); // Funktionsprototyp }; int Klasse1::speicherAlter(int wald)// Funktion zum speichern von alter { alter = wald; // alter gleich übergebener Variable wald return alter; // Rückgabewert alter } char Klasse1::speicherName(char baum)// Funktion zum speichern von name { name = baum; // alter gleich übergebener Variable baum return name; // Rückgabewert alter } int main() { cout << "Alter: "; // Ausgeben int wald; // Variablendeklaration wald cin >> wald; // Einlesen Klasse1 foo; // ist nicht static, daher erst ein object erstellen foo.speicherAlter(wald); // methode aufrufen cout << foo.leseAlter() << "\n"; /*Ausgeben von object foo, der public Funktion leseAlter*/ cout << "Name: "; // Ausgeben char baum; // Variablendeklaration baum cin >> baum; // Einlesen Klasse1 joo; // ist nicht static, daher erst ein object erstellen joo.speicherName(baum); // methode aufrufen cout << joo.leseName() << "\n"; /*Ausgeben von object foo, der public Funktion leseName*/ return 0; }
Besten Dank für Eure Bemühungen
-
-
Also ein char speichert ja nur einen buchstaben
ein feld of char z.b. *c speichert mehr, aber um wie und wo ect. willst du dich nicht wirklich kümmern
deswegen mach es wie alle
nimm string
std::string name;
da haste dann auch sehr viele methoden dafuer um bestimme sachen zu suchenz.b. string s1 = "hallo du Heinz wie gehts?";
und dann kannste nach "Heinz" suchen ect.
-
Ach ja da wäre doch noch ne klitzekleine Kleinigkeit...
was hat es denn mit
inline int leseAlter() const // inline (Empfehlung) + const methode
der Inline-Methode auf sich und was mit const
also Unterschied zwischeninline int leseAlter() const // und int leseAlter()
THX
-
inline für compiler google mal. brauchst du aber nicht, da der compiler imho sowieso entscheidet ob er was inline macht oder nicht. inline wird grob gesagt bei kurzen fkt. genommen die... google einfach mal da sind da prof. antworten
const bedeutet in dem fall, imho das die methode keine membervaribalen verändern kann, in diesem fall ist es ja gewollt, da wir nur lesen möchten nicht die membervaribale alter verändern wollen
std::cout und cout ist das gleiche
cout liegt in einem namensraum ist keine "globale" sache wie
int, char, #include ect
ebenso string
der namensraum heisst std
du kannst deshalb den namensraum jedes mal angeben std::cout
oder oben einmal
using namespace std; machen dann nimmt er bei allen sachen std:: automatisch davor
du kannst auch deine klasse in einem eigenen namensraum setzen
z.b. testnamensraum
und jedes mal das dann davorschreibenwarum man das alles macht?
weil es sehr sehr viele klassen gibt und man konflikte aus dem weg gehen will
z.b. deine find() methode und die von string.find
-
ja nur das problem ist, das wenn ich
using namespace std;
hineinschreibe, dann gibts keim compil. imer fehler, so dass ich das wieder raus nehmen muss
-
Ohne Fehlermeldung des Compilers können wir nicht helfen..
Also, was spuckt er aus? Es muss gehen, ansonsten hält sich dein Compiler nicht an den Standard. Daher: notfalls Compilertausch
-
Die Fehlermeldung sieht folgendermaßen aus
C:\Eigene Dateien\Test Sourcecodes\Binary.cpp(5) : error C2871: 'std' : Existiert nicht oder ist kein Namespace
Fehler beim Ausführen von cl.exe.Binary.exe - 1 Fehler, 0 Warnung(en)
dann nehme ich das using namespace std; wieder raus und alles ist ok....
was hat das zu bedeuten ? Muß der Compiler getauscht werden, wenn ja wie ??DANKE
-
mache ich in den code die Variablendeklaration folgendermaßen:
char name[15]; char baum[15];
kommen folgende Fehlermeldungen...
--------------------Konfiguration: Class03 - Win32 Debug--------------------
Kompilierung läuft...
Class03.cpp
C:\Eigene Dateien\Test Sourcecodes\Class03.cpp(18) : error C2440: 'return' : 'const char [15]' kann nicht in 'char' konvertiert werden
Diese Konvertierung erfordert einen reinterpret_cast-Operator oder eine Typumwandlung im C- oder Funktionsformat
C:\Eigene Dateien\Test Sourcecodes\Class03.cpp(35) : error C2440: 'return' : 'char [15]' kann nicht in 'char' konvertiert werden
Diese Konvertierung erfordert einen reinterpret_cast-Operator oder eine Typumwandlung im C- oder Funktionsformat
C:\Eigene Dateien\Test Sourcecodes\Class03.cpp(52) : error C2664: 'speicherName' : Konvertierung des Parameters 1 von 'char [15]' in 'char' nicht moeglich
Diese Konvertierung erfordert einen reinterpret_cast-Operator oder eine Typumwandlung im C- oder Funktionsformat
Fehler beim Ausführen von cl.exe.Class03.exe - 3 Fehler, 0 Warnung(en)
Ohne diese Deklaration gab es dann vorher nicht den eingegebenen Name zurück, sondern nur den ersten Buchstaben, jetzt wiederrum nur ein Zeichen aus der ASCII Tabelle(DEZ:204 HEX:CC) Son Rahmenbaustein.....
was hat das nun wieder zu bedeuten ?
-
Vergiss char[], nimm std::string!
So kannst du es machen.
#include <iostream> #include <string> class Person { private: int alter; std::string name; public: int leseAlter() const { return alter; } const std::string& leseName() const { return name; } void speicherAlter(int); void speicherName(std::string); }; void Person::speicherAlter(int alter_) { alter = alter_; } void Person::speicherName(std::string name_) { name = name_; } int main() { std::cout << "Alter: " << std::flush; int alter; std::cin >> alter; std::cout << "Name: " << std::flush; std::string name; std::cin >> name; Person cool_person; cool_person.speicherAlter(alter); cool_person.speicherName(name); std::cout << cool_person.leseAlter() << std::endl << cool_person.leseName() << std::endl; }
using namespace std;
müss gehen. Hast du ein uralten Compiler??
-
Ja vielen Dank ChrissiB
jetzt läuft das Programm endlich... und damit ist meine erste sinnvoll verwendbar Klasse fertig*MegaFreu*
nur leider kann ich dir nix über die Compiler Version sagen... weiß nicht wie ich herausfinde, welche Vers. das ist.. Wo steht das genau ??
Kann dir nur soviel sagen, das ich Visual C++ 6.0 verwende...
Und was genau bedeutet folgende Zeile:
const std::string& leseName() const
wofür steht Const und string&
THX
-
Du gibts eine Refernz auf ein konstanten String zurück. So verhinderst du mit const, dass man von außen dein internen Name abändern kann ohne Erlaubnis. (siehe setter-Funktionen). Das const dahinter sagt aus, dass die Funktion nichts ändern darf, d.h. in der Methode darf nichts zugewiesen werden und dergleichen. Schau in deinem Buch nach für nähere Details. Vielleicht ist es besser, den Dev C++ zu nehmen.