Schnittstellen ... < C/C++ < Programmiersprachen < Praxis < Informatik < Vorhilfe
|
Status: |
(Frage) beantwortet | Datum: | 20:21 Di 27.04.2010 | Autor: | marike |
Aufgabe 24. Was ist falsch an der Funktion im folgenden Quellcode?
#include <iostream>
using namespace std;
void myFunc(unsigned short int x);
void main()
{
unsigned short int x, y;
y = myFunc(int);
cout << "x: " << x << " y: " << y << [mm] "\n";
[/mm]
}
void myFunc(unsigned short int x)
{
return (4*x);
}
.. nun ich meine das y=myFunc(int) als anweisung nicht geht, eher
y=myFunk(x)
..und void als rückmeldung mit return nicht funktioniert also int
.. und x muss erstmals definiert und abgefragt werden...
mein vorschlag ist
#include <iostream>
using namespace std;
int myFunc(unsigned short int x);
void main()
{
unsigned short int x, y;
cout<<"Gib einen Wert für x ein";cin>>x;
y = myFunc(x);
cout << "x: " << x << " y: " << y << [mm] "\n";
[/mm]
}
int myFunc(unsigned short int x)
{
return (4*x);
}
stimmt das so oder habe ich was vergessen ?? vielen dank
|
|
|
|
Hallo!
Du hast den Fehler in dem Programm gefunden.
Allerdings wird da mit UNSIGNED SHORT INTs hantiert, deine Funktion gibt nun ein INT zurück. Weil das INT aber mächtiger (Nennt man das so? Es kann gößere Zahlen aufnehmen) ist, wird der compiler meckern, daß du ein INT einem U. S. INT zuweisen willst.
Du solltest das daher auch auf U.S. INT ändern.
Andererseits kann durch die Multiplikation ein Wert raus kommen, der die Kapazität eines U.S.INT übersteigt, daher wäre ein (U.) INT sicher ne Alternative als Rückgabewert, dann sollte das y aber auch entsprechend definiert sein.
Nebenbei ist es kein syntax-Fehler, wenn die Variable x nicht gefüllt wird - da steht erstmal Müll drin, mit dem sich auch rechnen läßt. Aber du hast natürlich recht, Sinn macht das nicht.
|
|
|
|