begin process at 2012 05 29 09:27:48
  Trouver un code source :
 
dans
 
Accueil > Forum > 

Archive C/C++

 > 

Archives

 > 

Au secours

 > 

If problème


Derniers messages déposésPoser une question dans le forum ou lancer une discussion

If problème

samedi 5 avril 2003 à 17:01:38 | If problème

Hades53

Membre Club
J'ai un problème avec If :


char*variable1;
variable1 = "bonjour";
if (variable1 == "bonjour") cout << "variable1 est égale à bonjour" << endl;

Ce code n'affiche pas "variable1 est égale à bonjour" , pourquoi ?
samedi 5 avril 2003 à 17:11:03 | Re : If problème

BruNews

Administrateur CodeS-SourceS
char szBONJOUR[] = "bonjour";
char*variable1;
variable1 = szBONJOUR;
if (variable1 == szBONJOUR) cout << "variable1 est égale à bonjour" << endl;
Devrait aller mieux. variable1 est un pointeur !!!
BruNews, ciao...


-------------------------------
Réponse au message :
-------------------------------

> J'ai un problème avec If :
>
>

> char*variable1;
> variable1 = "bonjour";
> if (variable1 == "bonjour") cout << "variable1 est égale à bonjour" << endl;
>

> Ce code n'affiche pas "variable1 est égale à bonjour" , pourquoi ?
samedi 5 avril 2003 à 18:50:53 | Re : If problème

Haldwin

Tu as comme l'a dit BruNews un probleme de pointeurs:
Un pointeur est une adresse memoire dans laquelle tu peux mettre une adresse d'une autre case memoire... Or ici dans ton pointeur tu veux mettre une chaine de caracteres!!!
Il faut donc faire une allocation de memoire:

#include <iostream.h>
#include <string.h>

int main(void)
{
char *variable1;
variable1 = new char[7+1]; // le "+1" permet de rajouter un \0 a la fin de ta chaine de caracteres .... Indispensable!
strcpy(variable1,"bonjour\0"); // Copie "bonjour" dans ton tableau(chaine de caracteres) "variable1"

// strcmp permet de comparer deux chaines de caracteres
if( (strcmp(variable1,"bonjour\0"))==0)
cout << "variable1 est égale à bonjour" << endl;

// Il faut a la fin de ton programme desalloué la memoire que tu as utilisé:
delete [] variable1;
return 0;

}

Il s'agit d'une autre facon que celle proposée par BruNews.
Dans celle ci tu utilises l'allocation dynamique de memoire ce qui est tres important en programmation...
Voila si tu as des questions n'hesites pas,
Bon dev,
<<-- H@ldwin -->>
samedi 5 avril 2003 à 22:22:16 | Re : If problème

vieuxLion


en réponse à Haldwin

la ligne
strcpy(variable1,"bonjour\0");
peut prêter à confusion
ton allocation est faite correctement avec
variable1 = new char[7+1];
la place est donc réservée pour 'b' 'o' 'n' 'j' 'o' 'u' 'r' '\0'
la chaine "bonjour" EST EXACTEMENT REPRESENTEE comme cela
si tu rajoute un \0, après bonjour, tu en as alors deux.
Regardes la fenêtre "memory" sur la variable str suivante
char str[]="bonjour\0"; pour le voir
Heureusement que la fonction strcpy s'arrête de copier au premier '\0' sinon, tu aurais un écrasement mémoire

-------------------------------
Réponse au message :
-------------------------------

> Tu as comme l'a dit BruNews un probleme de pointeurs:
> Un pointeur est une adresse memoire dans laquelle tu peux mettre une adresse d'une autre case memoire... Or ici dans ton pointeur tu veux mettre une chaine de caracteres!!!
> Il faut donc faire une allocation de memoire:
>
> #include <iostream.h>
> #include <string.h>
>
> int main(void)
> {
> char *variable1;
> variable1 = new char[7+1]; // le "+1" permet de rajouter un \0 a la fin de ta chaine de caracteres .... Indispensable!
> strcpy(variable1,"bonjour\0"); // Copie "bonjour" dans ton tableau(chaine de caracteres) "variable1"
>
> // strcmp permet de comparer deux chaines de caracteres
> if( (strcmp(variable1,"bonjour\0"))==0)
> cout << "variable1 est égale à bonjour" << endl;
>
> // Il faut a la fin de ton programme desalloué la memoire que tu as utilisé:
> delete [] variable1;
> return 0;
>
> }
>
> Il s'agit d'une autre facon que celle proposée par BruNews.
> Dans celle ci tu utilises l'allocation dynamique de memoire ce qui est tres important en programmation...
> Voila si tu as des questions n'hesites pas,
> Bon dev,
> <<-- H@ldwin -->>
samedi 5 avril 2003 à 23:40:01 | Re : If problème

Haldwin

Je suis d'accord avec toi VieuxLion pis comme ton nom l'indique tu es toujours la pour nous remettre sur la voie lors d'un petit moment d'egarement et ça c'est coooool!
Il est vrai qu'ayant vu pas mal de probleme avec les '\0', je me mefie mais la, je me suis un peu trop mefier, il est vrai!!!
Et j'y repense, c'est vrai que c'est un peu nul ce que j'ai ecris... Toutes mes excuses pour avoir donné un code faux.. Donc pour Hades53:
#include <iostream.h>
#include <string.h>

int main(void)
{
char *variable1;
variable1 = new char[7+1]; // le "+1" permet de rajouter un \0 a la fin de ta chaine de caracteres .... Indispensable!
strcpy(variable1,"bonjour"); // Copie "bonjour" dans ton tableau(chaine de caracteres) "variable1"

// strcmp permet de comparer deux chaines de caracteres
if( (strcmp(variable1,"bonjour\0"))==0)
cout << "variable1 est égale à bonjour" << endl;

// Il faut a la fin de ton programme desalloué la memoire que tu as utilisé:
delete [] variable1;
return 0;

}

Voila la rectification est faites.... Et encore merci a toi Vieux Lion...
<<-- H@ldwin -->>
dimanche 6 avril 2003 à 13:20:45 | Re : If problème

Hades53

Membre Club
Je vous remerci , maintenant ca marche :p


Cette discussion est classée dans : problème, code, variable1, égale


Répondre à ce message

Sujets en rapport avec ce message

(MS VCpp) Problème de variables [ par YS1 ] J'ai créé une DLL C+PP que je souhaite utiliser dans un programe VB.La fonction principale de la DLL renvoie un certain nombre de variables, qui sont problème chaines de caractères [ par tintin72 ] BonjourJ'aimerai avoir un petit éclaircissement sur les chaines de caractères.Voici un programme tout bête... char prenom[100]; cout gets(pr Petit problème de code [ par mimyne ] Bonjour g le code suivant:void Resultat_Clicked(Object* pSender, EventArgs* pArgs){ int operation = 5; char* chaine[10]; if (pSender == Btnres) { //o Problème de code en c++ (fonction itoa) [ par mimyne ] voila g le code suivant:void Resultat_Clicked(Object* pSender, EventArgs* pArgs){ int operation = 5; char* chaine[2]; if (pSender == Btnres) { { ito Problème : Récupération des données d'un Buffer pour mettre dans une EditBox [ par Memerosti ] BonjourMon problème est le suivant : J'ai ouvert un fichier, lu ses données, et jusque là ça va. Mais ensuite je voudrais récupérer ces données, pour [C++][MFC] Problème avec les onglets [ par impress ] Bonjour, Après avoir parcouru différents forums et tutoriaux, j'ai réussi (enfin !) à créer des onglets de façon propre.Le problème, c'est que je n'ar pb stupide : diviser [ par guifr ] Alors là, je sens que je vais craquer, je suis à deux doigts de commettre un ordicide ! sois mon pc est complètement stupide, ou alors c'est moi (ce q Problème de link : LNK2001 [ par oberown ] J'utilise une API, dont j'utilise les variables.Je n'ai aucun problème pour les utiliser. Or quand je veux en utiliser une celle ci IID_IRTCUserSearch Problème Compilation Visual C++.Net :) [ par Joky ] Il m'arrive un truc esstraordinaire lolJe code tout bien pour l'affichage d'une fenêtre, code de base quoiJe compile, aucune erreur, mais lorsque j'ex Problème MySQL [ par Steph115 ] Bonjour ,J'ai placé un composant TSQLConnection et je l'initialise avec ces valeurs :ConnectionName = MySQLConnection;DriverName = MySQL;GetDriverFu


Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Mai 2012
LMMJVSD
 123456
78910111213
14151617181920
21222324252627
28293031   

Consulter la suite du CalendriCode

Photothèque

A découvrir



 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,671 sec (3)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales