IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C++ Discussion :

Erreurs de compilation : Help


Sujet :

C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé

    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 448
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 448
    Par défaut Erreurs de compilation : Help
    Je me suis remis au C++ depuis peu (quelques heures) et malgrès le fait de lire et relire les parties consacrés dans 3 des cours que j'ai trouvé ici même, je ne comprends pas ce qu'on me reproche (je suis inocent, monsieur l'agent).

    Voici donc le header et le code.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
     
     
    typedef unsigned char pixel[4];
     
    class RasterLike {
    private :
    	pixel **data;
    	const unsigned int width;
    	const unsigned int height;
    public :
    	RasterLike(unsigned int _width, unsigned int _height);
    	~RasterLike(void);
    	void setPixel(unsigned int x, unsigned int y, pixel pix);
    	pixel getPixel (unsigned int x, unsigned int y) const;
    }
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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
    
    #include "cov001.h"
    
    RasterLike::RasterLike(unsigned int _width, unsigned int _height) :
    	width(_width), height(_height)
    {
    	this->data = new pixel* [this->width];
    	for (unsigned int x = 0; x < this->height; x++) {
    		this->data[x] = new pixel[this->height];
    	}
    	return;
    }
    
    RasterLike::~RasterLike() {
    	for (unsigned int x = 0; x < this->height; x++) {
    		delete[] this->data[x];
    	}
    	delete this->data;
    }
    
    void RasterLike::setPixel(unsigned int x, unsigned int y, pixel pix) {
    	this->data[x][y] = &pix;
    }
    
    pixel RasterLike::getPixel(unsigned int x, unsigned int y) const {
    	return this->data[x][y];
    }
    
    int main() {
    	RasterLike a = new RasterLike(320,240);
    }
    (en fushia, les lignes 10 et 28)

    Et je bute à la récetion des méssages d'erreurs suivant à la compilation :

    cov001.cpp
    f:\program files\avisynth 2.5\avisynth_256_src\avsdll\cov001.h(19) : error C2090: tableau retourné par la fonction
    f:\program files\avisynth 2.5\avisynth_256_src\avsdll\cov001.cpp(10) : error C2533: 'RasterLike::{ctor}' : type de retour non autorisé pour les constructeurs
    f:\program files\avisynth 2.5\avisynth_256_src\avsdll\cov001.cpp(28) : error C2440: '=' : impossible de convertir de 'unsigned char *__w64 []' en 'pixel'
    Aucune conversion en types tableau, même s'il y a des conversions en références ou en pointeurs de tableau

    [...]
    Merci.

    PS : compilé sous M$ Visual Studio 2005 Express.

  2. #2
    Rédacteur

    Avatar de Matthieu Brucher
    Profil pro
    Développeur HPC
    Inscrit en
    Juillet 2005
    Messages
    9 810
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Développeur HPC
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2005
    Messages : 9 810
    Par défaut
    Normal, tu fais un return dans un constructeur, alors qu'il ne peut rien retourner.

  3. #3
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 395
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    L'erreur n'est pas là : point-virgule oublié après la déclaration de classe.

    Et tu dois remplacer "this->data[x][y] = &pix;" par "memcpy(this->data[x][y], pix, sizeof(pixel);" ou un truc du genre: Il n'y a pas d'opérateur d'affectation pour les tableaux.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  4. #4
    Membre éprouvé

    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 448
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 448
    Par défaut
    Le return du constructeur, je ne l'ai mis qu'en désespoire de cause en suivant scrupuleusement la déclaration que l'on trouve dans le cours de C. Casteyde.
    J'imagine donc que ce n'est pas une erreur en soit (une manie ?).

    Citation Envoyé par Médinoc
    L'erreur n'est pas là : point-virgule oublié après la déclaration de classe.

    Et tu dois remplacer "this->data[x][y] = &pix;" par "memcpy(this->data[x][y], pix, sizeof(pixel);" ou un truc du genre: Il n'y a pas d'opérateur d'affectation pour les tableaux.
    Merci, je suis dans Java depuis tellement longtemps maintenant que je ne pouvais pas concevoir l'impossibilité d'assigner des tableaux.

  5. #5
    Rédacteur

    Avatar de Matthieu Brucher
    Profil pro
    Développeur HPC
    Inscrit en
    Juillet 2005
    Messages
    9 810
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Développeur HPC
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2005
    Messages : 9 810
    Par défaut
    En C, il y a un type de retour pour toutes les fonctions. En C++, il n'y en a pas pour les constructeurs, donc pas de return.

  6. #6
    Membre Expert
    Avatar de Pragmateek
    Homme Profil pro
    Formateur expert .Net/C#
    Inscrit en
    Mars 2006
    Messages
    2 635
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Formateur expert .Net/C#
    Secteur : Conseil

    Informations forums :
    Inscription : Mars 2006
    Messages : 2 635
    Par défaut
    Citation Envoyé par Miles
    En C, il y a un type de retour pour toutes les fonctions. En C++, il n'y en a pas pour les constructeurs, donc pas de return.
    Le "return" sert à indiquer le rétablissement du contexte avant appel de la fonction et accessoirement renvoyer un résultat; même si il n'est pas obligatoire, l'accolade finale de la fonction étant suffisante pour indiquer le retour dans le cas où la fonction ne renvoie rien, le mettre reste cohérent; ainsi ceci compile:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    class A
    {
         public:A(){return;}     
    };

  7. #7
    Membre émérite
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    633
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 633
    Par défaut
    Bonjour,

    et après ceci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    int main() {
    	RasterLike a = new RasterLike(320,240);
    }
    n'oublie pas de libérer la mémoire

  8. #8
    Membre chevronné
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    258
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Bas Rhin (Alsace)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 258
    Par défaut
    Citation Envoyé par Médinoc
    Et tu dois remplacer "this->data[x][y] = &pix;" par "memcpy(this->data[x][y], pix, sizeof(pixel);" ou un truc du genre: Il n'y a pas d'opérateur d'affectation pour les tableaux.
    Dans ce genre de cas, mieux vaut définir une structure simple pour le pixel, ce qui évite de se trimbaler des tableaux et des pointeurs et ce qui permet d'utiliser un vrai operateur d'affectation.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Erreur de compilation après modification du Uses
    Par DevelOpeR13 dans le forum Langage
    Réponses: 5
    Dernier message: 30/10/2007, 14h23
  2. Réponses: 2
    Dernier message: 23/09/2003, 14h32
  3. Réponses: 10
    Dernier message: 22/09/2003, 21h58
  4. Réponses: 4
    Dernier message: 27/08/2003, 21h34
  5. Réponses: 2
    Dernier message: 04/03/2003, 23h24

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo