Du bist nicht angemeldet.

Stilllegung des Forums
Das Forum wurde am 05.06.2023 nach über 20 Jahren stillgelegt (weitere Informationen und ein kleiner Rückblick).
Registrierungen, Anmeldungen und Postings sind nicht mehr möglich. Öffentliche Inhalte sind weiterhin zugänglich.
Das Team von spieleprogrammierer.de bedankt sich bei der Community für die vielen schönen Jahre.
Wenn du eine deutschsprachige Spieleentwickler-Community suchst, schau doch mal im Discord und auf ZFX vorbei!

Werbeanzeige

bigappleQ

Frischling

  • »bigappleQ« ist der Autor dieses Themas

Beiträge: 7

Beruf: Schüler

  • Private Nachricht senden

1

30.10.2005, 11:20

"riesen" Problem mit Strukturen

:huhu: Hallo Leute, das ist mein aller erste Frage...Ich lese das Buch von Heiko Kalista C++ Für Spieleprogrammierer. Ich stecke schon seite mehreren Tagen in Kap.5 fest.
(Das Problem kann ich nicht deuten, ich verstehe es ja nicht)
Hier mein Quelltext:

[cpp]
//Telefonbuch////////
#include<iostream>
using namespace std;
/////////////////////

//GlobaleStrukturen/////////
struct S_Daten
{
char Nummer;
char Name[40];
};
//GlobaleStrukturen/////////

//GlobaleVariablen//////////
S_Daten Person[50];
int x=0;
//GlobaleVariablen//////////

//Prototypen////////////////
void DatenEingeben();
//Prototypen////////////////


//Main//////////////////////////////////////////////
int main()
{

//LokaleVariablen///////
int Auswahl;
//LokaleVariablen///////

do
{
cout<<"Telefonbuch 2000"<<endl;
cout<<endl;
cout<<"1-Telefonnummer ansehen"<<endl;
cout<<"2-Telefonnmummer eingeben"<<endl;
cout<<"3-Telefonliste angucken"<<endl;
cout<<"4-Daten loeschen"<<endl;
cout<<"5-Programm beenden"<<endl;
cout<<endl;
cout<<"Auswahl: ";
cin>>Auswahl;
cout<<endl;
cout<<endl;
switch (Auswahl)
{
case (1):
{
}break;
case (2):
{
DatenEingeben();
cin.ignore();
}break;
case (3):
{
}break;
case (4):
{
}break;
case (5):
{
}break;
default:
{
cout<<"Falsche Eingabe!"<<endl;
cout<<endl;
}
}

}while (Auswahl!=5);

return 0;
}
//Main//////////////////////////////////////////////


//Funktionen//////////////////////////
void DatenEingeben()
{
x+=1;
cout<<"Name der Person eingeben: ";
cin.get (Person[x].Name,39);
cout<<endl;

}
//Funktionen//////////////////////////
[/cpp]

Das soll einamal eine kleine Telefonnummer Verwaltung werden.
Das Problem: Wenn ich 2 als Auswahl waehle dann müsste ich ja den Namen für Person[x] eingeben können...Aber das Programm sturtzt einfach ab. Was ist da falsch??
Danke für deine/eure Hilfe!!
Ps. Sollte mein Quelltext hier etwas unubersichtlich gedruckt werden,dann sorry ich kanns noch nicht besser...

Anonymous

unregistriert

2

30.10.2005, 11:48

Hi,

hab Dein Problem gefunden ;)

sieh dir mal folgenden Code an:

C-/C++-Quelltext

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
//Telefonbuch//////// 

#include<iostream> 
using namespace std; 
///////////////////// 


//GlobaleStrukturen///////// 

struct S_Daten 
{ 
    char Nummer; 
    char Name[40]; 
}; 
//GlobaleStrukturen///////// 


//GlobaleVariablen////////// 


    S_Daten Person[50];

    int x=0; 

//GlobaleVariablen////////// 


//Prototypen//////////////// 

    void DatenEingeben(); 
//Prototypen//////////////// 



//Main////////////////////////////////////////////// 

int main() 
{ 

//LokaleVariablen/////// 

    int Auswahl; 
//LokaleVariablen/////// 


do 
{ 
    cout<<"Telefonbuch 2000"<<endl; 
    cout<<endl; 
    cout<<"1-Telefonnummer ansehen"<<endl; 
    cout<<"2-Telefonnmummer eingeben"<<endl; 
    cout<<"3-Telefonliste angucken"<<endl; 
    cout<<"4-Daten loeschen"<<endl; 
    cout<<"5-Programm beenden"<<endl; 
    cout<<endl; 
    cout<<"Auswahl: "; 
    cin>>Auswahl; 
    cout<<endl; 
    cout<<endl; 

switch (Auswahl) 
{ 
    case (1): 
    { 
        break; 
    }

    case (2): 
    { 
        DatenEingeben();
        break;
    }

    case (3): 
    {
        break;
    } 

    case (4): 
    {
        break;
    } 
    
    case (5): 
    {
        break;
        
    } 
    
    default: 
    { 
        cout<<"Falsche Eingabe!"<<endl; 
        cout<<endl; 
    } 
} 


}while (Auswahl!=5); 

return 0; 
} 
//Main////////////////////////////////////////////// 



//Funktionen////////////////////////// 

void DatenEingeben() 
{ 
x+=1; 
cout<<"Name der Person eingeben: "; 

// CIN.IGNORE MUSS VOR CIN.GET STEHEN !!!!

cin.ignore();
cin.get (Person[x].Name,39); 
cout<<endl; 

} 
//Funktionen//////////////////////////


Das cin.ignore() muss vor cin.get() stehen!

Könnte sein, das evtl. noch Speicherreste im Buffer sind.

P.S: Globale Variablen sollte man NICHT benutzen ! :)

__stdcall*

__stdcall*

Treue Seele

Beiträge: 101

Wohnort: Dauchingen

Beruf: Schüler

  • Private Nachricht senden

3

30.10.2005, 11:54

der Obige Beitrag war von mir ;)

wurde während dem Schreiben irgendwie getrennt warscheinlich weil
mein Dad irgendwas an der FritzBox herumgefummelt hat ;)

bigappleQ

Frischling

  • »bigappleQ« ist der Autor dieses Themas

Beiträge: 7

Beruf: Schüler

  • Private Nachricht senden

4

30.10.2005, 15:48

Danke!!

Werbeanzeige