CONNEXION
  • RetourJeux
    • Sorties
    • Hit Parade
    • Les + populaires
    • Les + attendus
    • Soluces
    • Tous les Jeux
    • Gaming
  • RetourActu Gaming
    • News
    • Astuces
    • Tests
    • Previews
    • Toute l'actu gaming
  • RetourBons plans
    • Bons plans
    • Bons plans Smartphone
    • Bons plans Hardware
    • Bons plans Image et Son
    • Bons plans Amazon
    • Bons plans Cdiscount
    • Bons plans Decathlon
    • Bons plans Fnac
    • Tous les Bons plans
  • RetourJVTech
    • Actus High-Tech
    • Intelligence Artificielle
    • Smartphones
    • Mobilité urbaine
    • Hardware
    • Image et son
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTech
  • RetourCulture
    • Actus Culture
    • Culture
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch 2
    • Xbox Series
    • Switch
    • Pokemon pocket
    • FC 25 Ultimate Team
    • League of Legends
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • Switch 2
  • PS4
  • One
  • Switch
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Liste des sujets

[MSVCRT.dll] Defaillante

elhuron
elhuron
Niveau 6
15 janvier 2008 à 21:08:43

Bonsoir.

Voici une fonction inutile et simple, mais qui pose probleme :

char* inutile(char chaine[30])
{
char autreChaine[20] = "Une autre chaine";
return autreChaine;
}

Ca compile, ca fonctionne, mais j´obtient un warning pour renvoyer une variable locale, pour l´eviter, j´agit ainsi :

char* inutile(char chaine[30])
{
char autreChaine[20] = "Une autre chaine";
strcpy(chaine, autreChaine);
return chaine;
}

Plus de warning, ca compile, mais dans la fonction strcpy, j´obtient un message d´erreur : "NomDuProgramme a provoqué une erreur dans MSVCRT.DLL. Le programme nomDuProgramme va maintenant être arrêté. Si vous continuez a

elhuron
elhuron
Niveau 6
15 janvier 2008 à 21:12:41

Désolé pour la coupure, je suis revenu dans la page precedente sans faire expres...

Plus de warning, ca compile, mais dans la fonction strcpy, j´obtient un message d´erreur : "NomDuProgramme a provoqué une erreur dans MSVCRT.DLL. Le programme nomDuProgramme va maintenant être arrêté. Si vous continuez à rencontrer des problèmes, essayez de redémarrer votre ordinateur".

PS : Je suis sour CodeBlocks, WindowsMe, le redemarrage de l´ordinateur ne fait absolument rien. Merci de m´aider :)

godrik
godrik
Niveau 30
15 janvier 2008 à 22:29:20

quand tu ecris:
"char autreChaine[20] = "Une autre chaine";
return autreChaine;"
Le tableau de caractere est alloué sur la pile, il est alors dangereux de retourner ce pointeur.

Lorsque tu ecris:
"
char* inutile(char chaine[30])
{
char autreChaine[20] = "Une autre chaine";
strcpy(chaine, autreChaine);
return chaine;
} "
L´erreur dans msvcrt.dll vient du fait qu´il y a un depassement de tableau. En effet, la chaine passé en parametre peut contenir jusqu´a 30 caracteres tandis que la chaine declarer dans la foncton ne peut en contenir que 20.

dnob700
dnob700
Niveau 10
15 janvier 2008 à 23:47:21

donne le code complet de ton programme.

elhuron
elhuron
Niveau 6
16 janvier 2008 à 14:55:23

Mouarf, dans l´exemple c´est vrai, une chaine est plus grande que l´autre, mais pas dans mon code.

J´ai trouvé le probleme.
En fait, en voulant ne plus renvoyer ma chaine locale, j´ai voulu renvoyer une chaine entrée en parametre, j´envoyait pas de variable, mais juste une chaine de caracteres.

Ca sera plus clair avec un code :

(CODE PROVOQUANT UN ERREUR)

  1. include <iostream>

using namespace std;

char* renvoi(char chaine[30]) {
char autreChaine[30] = "...";
strcpy(chaine, autreChaine);
return chaine; }

int main() {
cout << renvoi("salut");
return 0; }

(CODE DIT NORMAL)

  1. include <iostream>

using namespace std;

char* renvoi(char chaine[30]) {
char autreChaine[30] = "...";
strcpy(chaine, autreChaine);
return chaine; }

int main() {
char chaine[30]="salut";
cout << renvoi(chaine);
return 0; }

Pas super pratique pour renvoyer une chaine, je pense qu´au lieu de renvoyer une chaine, je vais plutot modifier la chaine dans la fonction, et ne rien renvoyer.

Sous forums
  • Aide à l'achat Mac
  • Internet
  • Macintosh
  • Création de sites web
  • Création de Jeux
  • Linux
  • Programmation
  • Steam Deck
  • Hardware
La vidéo du moment