Bei mir kommt, wenn ich es so schreibe wie im Video dieser Fehler: #include using namespace std; int main() { char name[] = "Bla"; char *test = "Test"; cout
Eine etwas späte Antwort, aber ich hoffe sie hilft noch: Mit dem besagten "const char *" ist die Zeichenkette "Test" gemeint. Denn "Test" wird als const char * interpretiert. Der hier deklarierte pointer *test wurde aber als char * deklariert (nicht als const char *). Und man kann keinen const char * einem char * zuweisen. Das widerspricht der Definition eines const datentyps *. Damit dieser Fehler nicht mehr erscheint müsste die Zeile folgendermaßen lauten: const char *test = "Test"; Damit wird ein const char * einem const char * zugewiesen und der compiler ist happy. Wenn man will, dass der pointer Typ char * bleibt muss man "Test" in ein char * konvertieren. Dies geht wie folgt: char *test = (char*) "Test"; Damit wird der als const char * angesehene "Test" als char * konvertiert dem pointer zugewiesen. Der Kern der Problematik besteht darin, dass hier versucht wurde einem konstanten Datentyp (const char *) einen variablen Datentyp (char *) zuzuweisen. Wir haben in Tutorial 12 gelernt, dass man die Speicheradresse sowie den Wert der Variablen auch über pointer verändern kann. Man könnte also mit dem pointer test die Zeichenfolge "Test" verändern. Und genau hier ist das Problem. Man könnte also dadurch eine konstante Variable verändern, denn "Test" ist konstant. Dies meinte ich mit "Das widerspricht der Definition eines const datentyps *". Denn const Datentypen können und dürfen nach ihrer Deklarierung/ Definierung nicht mehr verändert werden. Aber es gibt einige Compiler, die diese "Hintertür" anscheinend übersehen und es doch zulassen. Wobei ich mich dann frage was passiert, wenn man dann den const char * "Test" über den pointer test versucht zu verändern. PS: Anderen Datentypen kann man natürlich const variablen zuweisen. Wie z.B. int oder float, weil es über diese nicht möglich ist, die const variablen zu verändern. Z.B. int a = 0; //Hier ist 0 sogar bereits ein const int const int b = 42; a = b; //Dies ist legitim. a = 42. Man kann also einem int (a) ein const int (b) zuweisen. Und b kann über a nicht verändert werden. Denn: b = a; //Wird sofort vom compiler geblockt. Man kann b nicht einen neuen Wert zuweisen, da b als const int deklariert wurde. Nur ein Datentyp der Stellvertretend für b steht könnte b verändern. Und dieser Stellvertreter wäre ein pointer, wie wir in Tutorial 12 gelernt haben. Was uns jedoch wieder zum Anfang meiner Nachricht bringt, dass man ein const int * keinem int * bzw. const char * keinem char * zuweisen kann. Ich hoffe meine Erklärung konnte weiterhelfen :D
Hallo, Bis jezt hatte ich nie Probleme mit deiner Tutorial reihe aber jetzt bekomme ich einen Eror wenn ich char name_c[ ] = "Bla"; char *test = "Test"; cout
Achso und ich bekomme denn Eror: Schweregrad Code Beschreibung Projekt Datei Zeile Unterdrückungszustand Fehler (aktiv) E0144 Ein Wert vom Typ ""const char *"" kann nicht zum Initialisieren einer Entität vom Typ ""char *"" verwendet werden.
Der Fehler liegt daran, dass es bei mit "" itialisierten Strings um Stringkonstanten handelt (const char). Diese const Eigenschaft ignorieren wir allerdings wenn wir es in einen char umwandeln. Durch einen expliziten cast kann man den Fehler ganz einfach beheben. Einfach char* name = (const char*) "Bla"; nutzen. Alternativ kannst du die Variable aber auch zu einem const char ändern.
@@sturmente ich hab das Problem gefixt, indem ich nicht char* test = (const char*)"Test"; geschrieben habe, sondern: char* test = (char*)"Test"; Ich hoffe ich konnte dir irgendwie helfen
Das Problem ist, dass in C++ der Speicher selbst gemanaged werden muss. Das kann insbesondere bei strings anfangs etwas verwirrend werden. In deinem Fall muss dein source string genug Speicher reserviert haben, damit der andere string reinpasst. Aus diesem Grund würde ich dir inbesondere am Anfang dringend dazu raten, den C++ std::string für so etwas zu verwenden. Im Endeffekt hast du zwei Möglichkeiten: Am einfachsten wäre ein cout
Hey, eine Frage: Ich habe als Umgebung VS in Win10 und habe das ganze mit dem strcat() leider nicht hinbekommen. Außerdem lässt sich dort eine Zeichenkette nicht wie in deinem Beispiel einem char zuordnen, ich brauche dort zwingend const char... Mache ich da etwas falsch? string.h ist drin...
Kann ich jetzt erstmal auch nichts direkt zu sagen, vil. hat Visual Studio die C Bibliotheken nicht eingebunden oder so. Wenn du mir den genauen Fehlertext + Quellcode schicken kannst kann ich vil etwas mehr zu sagen.
strncat und strcat, funktionieren in der Art wie im Video gezeigt nicht. #include #include using namespace std; int main() { char name[] = "Bla"; const char *test = "Test"; cout
Der allerdings counter hat mich gekillt xD so macht lernen spaß!:)
3:00 nur so funktioniert es bei mir: #include
using namespace std;
int main()
{
char name[] = "Bla";
char test[] = "Test";
cout
ALLERDINGS hätte ich das selbe Phänomen :D
Besser statt wäre . Läuft dann ohne Probleme.
strcat und strncat nicht zum laufen gebracht. auch wenn ich den char name[100!] vergrössere stürzt das programm leider
immer ab.
Richtig geiles Video
Bei mir kommt, wenn ich es so schreibe wie im Video dieser Fehler:
#include
using namespace std;
int main()
{
char name[] = "Bla";
char *test = "Test";
cout
den Fehler bekomme ich auch normal, kann es jedoch dennoch ausführen. Das ist soweit kein Problem... ruf einfach anstatt cout
Eine etwas späte Antwort, aber ich hoffe sie hilft noch:
Mit dem besagten "const char *" ist die Zeichenkette "Test" gemeint. Denn "Test" wird als const char * interpretiert.
Der hier deklarierte pointer *test wurde aber als char * deklariert (nicht als const char *).
Und man kann keinen const char * einem char * zuweisen. Das widerspricht der Definition eines const datentyps *.
Damit dieser Fehler nicht mehr erscheint müsste die Zeile folgendermaßen lauten:
const char *test = "Test";
Damit wird ein const char * einem const char * zugewiesen und der compiler ist happy.
Wenn man will, dass der pointer Typ char * bleibt muss man "Test" in ein char * konvertieren. Dies geht wie folgt:
char *test = (char*) "Test";
Damit wird der als const char * angesehene "Test" als char * konvertiert dem pointer zugewiesen.
Der Kern der Problematik besteht darin, dass hier versucht wurde einem konstanten Datentyp (const char *) einen variablen Datentyp (char *) zuzuweisen.
Wir haben in Tutorial 12 gelernt, dass man die Speicheradresse sowie den Wert der Variablen auch über pointer verändern kann. Man könnte also mit dem pointer test die Zeichenfolge "Test" verändern.
Und genau hier ist das Problem. Man könnte also dadurch eine konstante Variable verändern, denn "Test" ist konstant. Dies meinte ich mit "Das widerspricht der Definition eines const datentyps *".
Denn const Datentypen können und dürfen nach ihrer Deklarierung/ Definierung nicht mehr verändert werden.
Aber es gibt einige Compiler, die diese "Hintertür" anscheinend übersehen und es doch zulassen. Wobei ich mich dann frage was passiert, wenn man dann den const char * "Test" über den pointer test versucht zu verändern.
PS:
Anderen Datentypen kann man natürlich const variablen zuweisen.
Wie z.B. int oder float, weil es über diese nicht möglich ist, die const variablen zu verändern.
Z.B.
int a = 0; //Hier ist 0 sogar bereits ein const int
const int b = 42;
a = b; //Dies ist legitim. a = 42. Man kann also einem int (a) ein const int (b) zuweisen. Und b kann über a nicht verändert werden. Denn:
b = a; //Wird sofort vom compiler geblockt. Man kann b nicht einen neuen Wert zuweisen, da b als const int deklariert wurde.
Nur ein Datentyp der Stellvertretend für b steht könnte b verändern. Und dieser Stellvertreter wäre ein pointer, wie wir in Tutorial 12 gelernt haben. Was uns jedoch wieder zum Anfang meiner Nachricht bringt, dass man ein const int * keinem int * bzw. const char * keinem char * zuweisen kann.
Ich hoffe meine Erklärung konnte weiterhelfen :D
Hallo,
Bis jezt hatte ich nie Probleme mit deiner Tutorial reihe aber jetzt bekomme ich einen Eror wenn ich
char name_c[ ] = "Bla";
char *test = "Test";
cout
Achso und ich bekomme denn Eror: Schweregrad Code Beschreibung Projekt Datei Zeile Unterdrückungszustand
Fehler (aktiv) E0144 Ein Wert vom Typ ""const char *"" kann nicht zum Initialisieren einer Entität vom Typ ""char *"" verwendet werden.
Der Fehler liegt daran, dass es bei mit "" itialisierten Strings um Stringkonstanten handelt (const char). Diese const Eigenschaft ignorieren wir allerdings wenn wir es in einen char umwandeln. Durch einen expliziten cast kann man den Fehler ganz einfach beheben. Einfach char* name = (const char*) "Bla"; nutzen. Alternativ kannst du die Variable aber auch zu einem const char ändern.
@@sturmente ich hab das Problem gefixt, indem ich nicht
char* test = (const char*)"Test";
geschrieben habe, sondern:
char* test = (char*)"Test";
Ich hoffe ich konnte dir irgendwie helfen
@@Pilzschaf Warum musst du in deinem Video nicht casten?
strcat spuckt mir einen fehler aus :( "Debug Assertion Failes!"
Sobald ich versuche irgendeinen variante dieses befehls auszuführen:
cout
Das Problem ist, dass in C++ der Speicher selbst gemanaged werden muss. Das kann insbesondere bei strings anfangs etwas verwirrend werden. In deinem Fall muss dein source string genug Speicher reserviert haben, damit der andere string reinpasst. Aus diesem Grund würde ich dir inbesondere am Anfang dringend dazu raten, den C++ std::string für so etwas zu verwenden. Im Endeffekt hast du zwei Möglichkeiten: Am einfachsten wäre ein cout
@@Pilzschaf Danke funktioniert😁
Hey, eine Frage: Ich habe als Umgebung VS in Win10 und habe das ganze mit dem strcat() leider nicht hinbekommen. Außerdem lässt sich dort eine Zeichenkette nicht wie in deinem Beispiel einem char zuordnen, ich brauche dort zwingend const char... Mache ich da etwas falsch? string.h ist drin...
Kann ich jetzt erstmal auch nichts direkt zu sagen, vil. hat Visual Studio die C Bibliotheken nicht eingebunden oder so. Wenn du mir den genauen Fehlertext + Quellcode schicken kannst kann ich vil etwas mehr zu sagen.
@@Pilzschaf ich habe den gleichen Fehler. Fehlercode 1: E0144 2: C2440
Hallo,
du musst statt dem zweiten char einfach: const char* test = "Test"; schreiben
@@Pilzschaf Hab das Problem herausgefunden man muss einfach: const char* test = "Test"; schreiben
@@raphfiantv5547 danke ;)
Wie hast du dir Programmieren beigebracht und wie bist du auf das Thema gekommen?
strncat und strcat, funktionieren in der Art wie im Video gezeigt nicht.
#include
#include
using namespace std;
int main()
{
char name[] = "Bla";
const char *test = "Test";
cout
Noch eine kleine Anmerkung.
#include
#include
using namespace std;
int main()
{
char name[] = "Bla";
const char *test = "Test";
cout
korrektes c++ ist aber nicht include sondern include
danke für nices video
Der cstring mit dem Wert "ich bin ein string" müsste zweimal ausgegeben werden und nicht nur einmal!
nein?