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 :

appel d'une fonction


Sujet :

C++

  1. #1
    Nouveau Candidat au Club
    Inscrit en
    Janvier 2009
    Messages
    1
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 1
    Points : 1
    Points
    1
    Par défaut appel d'une fonction
    Bonjour, je me joint à votre communauté car je débute un projet C++. Jusque là je me débrouillais avec les exemples de code déjà fais par mes collègues mais là je bloque sur un truc tout bête je pense, l'appel d'une fonction qui est dans une autre class. Je met le code
    ReadMATFID.h
    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
    33
    34
    35
    class CReadMATFID
    {
    	public:
    		/*------------------------------------------------------------------------------*/
    		/* Constructeur																	*/
    		/*------------------------------------------------------------------------------*/
     
    		CReadMATFID(int Size, char *PathFile, CLogHandler *pLog);
     
    		/*------------------------------------------------------------------------------*/
    		/* Destructeur																	*/
    		/*------------------------------------------------------------------------------*/
    		~CReadMATFID();
     
    		/* Lecture + mise en mémoire de la matrice */
    		void ReadMat();
     
    		int **GetMatFID (){return ArrayTable;}
     
    	private:
     
    		// Matrice	
    		int **ArrayTable;
     
    		// Nombre d'éléments du tableau
    		int nTable;
     
    		//chemin vers le fichier
    		char pPathFile[MAX_PATH+1];
     
    		//pointeur vers classe pour les log d'erreur
    		CLogHandler *pcLog;
    		//
    		int RetFileLength(FILE *pFile);
    };
    ReadMATFID.cpp
    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
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    /*-----------------------------------------------------------------------*/
    /* Constructeur de la classe                                             */
    /* Données d'entrée:													 */
    /* CWnd* pParentWnd: fenêtre parent                                      */
    /*-----------------------------------------------------------------------*/
    CReadMATFID::CReadMATFID(int Size, char *PathFile, CLogHandler *pLog)
    {
     
    	nTable=Size;
    	if (PathFile!=NULL)
    		strcpy(pPathFile, PathFile);
    	if (pLog !=NULL)
    		pcLog = pLog;
    	if (nTable>0)
    	{
    		ArrayTable  = new int*[nTable+1];
    		for (int k=0;k<nTable+1;k++)
    			ArrayTable[k] = new int[nTable+1];
    	}
    }
     
    /*-----------------------------------------------------------------------*/
    /* Destructeur de la classe                                              */
    /*-----------------------------------------------------------------------*/
    CReadMATFID::~CReadMATFID()
    {
    	int i;
    	//destruction char **ArrayTable
    	if(nTable)
    	{
    		for(i=0;i<nTable;i++)
    			delete /*[]*/ ArrayTable[i];
    		delete ArrayTable;
    	}
    }
     
    /*------------------------------------------------------------------------*/
    /* Lecture + mise en mémoire de la matrice                                */
    /*------------------------------------------------------------------------*/
    void CReadMATFID::ReadMat()
    {
    	BOOL bexport = TRUE;
    	int  i = 0, m = 1, n = 1, FileSize = 0;
    	char *file;
    	char *pTk;
    	char *pValue;
    	char errorTxt[512];
    	FILE *hFile;
     
     
    	//clear mémoire tableau
    	memset(*ArrayTable, 0, sizeof(ArrayTable));
     
    	// ouverture du fichier en lecture seul
    	//sprintf(pathFile, ".\\MATFID.csv");
    	if(hFile = fopen(pPathFile, "rb"))
    	{
    		// taille du fichier
    		FileSize = RetFileLength(hFile) - 1;
    		if(FileSize > 0)
    		{
    			// recup du contenu du fichier
    			file = new char[FileSize + 1];
    			file[0]='\0';
    			if(fread(file,1,FileSize,hFile))
    			{
    				if(file[0] != '\0')
    				{
    					// séparation des reqêtes
    					file[FileSize]='\0';
    					pTk = strtok (file,"\n");
    					while (pTk != NULL && bexport)
    					{
    						int ilenLine = strlen(pTk);
    						int iOldPos = 0;
    						// parcourir la chaine de caractères d'une ligne
    						for (int iPos=0; iPos<=ilenLine; iPos++)
    						{
    							// lorsque l'on trouve un ";"
    							if (pTk[iPos] == ';' && iPos>=iOldPos )
    							{
    								pValue = new char[iPos-iOldPos + 1];
    								pValue[0]='\0';
    								//copie de valeur entre la position du précédent ";" et la position actuelle
    								strncpy(pValue, pTk+iOldPos, iPos-iOldPos);
    								// conversion en int
    								if (pValue !=NULL) // test si pValue = NULL la fonction atoi() plante!!!
    									ArrayTable[m][n]= atoi(pValue);
    								else
    								{
    									sprintf(errorTxt, "pValue = NULL x=%d; y =%d", m, n);
    									if (pcLog !=NULL)
    										pcLog->LogError("CMatFile::ChargedMat", errorTxt);
    								}
    								n++;
    								iOldPos = iPos+1;
    								if (pValue !=NULL)
    									delete pValue;
    							}
    							// lorsque l'on arrive sur le dernier caractère
    							if (iPos==ilenLine && iPos>=iOldPos )
    							{
    								pValue = new char[iPos-iOldPos + 1];
    								pValue[0]='\0';
    								//copie de valeur entre la position du précédent ";" et la position actuelle
    								strncpy(pValue, pTk+iOldPos, iPos-iOldPos);
    								// conversion en int
    								if (pValue !=NULL) // test si pValue = NULL la fonction atoi() plante!!!
    									ArrayTable[m][n]= atoi(pValue);
    								else
    								{
    									sprintf(errorTxt, "pValue = NULL x=%d; y =%d", m, n);
    									if (pcLog !=NULL)
    										pcLog->LogError("CMatFile::ChargedMat", errorTxt);
    								}
    								if (pValue !=NULL)
    									delete pValue;
    							}
    						}
    						n=1;
    						m++;
    						pTk = strtok (NULL,"\n");
    					}
    				}
    				else
    				{
    					sprintf(errorTxt, "Problème de remplissage du buffer, fichier de sauvegarde '%s' (longueur:%d)", pPathFile, FileSize);
    					if (pcLog !=NULL)
    						pcLog->LogError("CMatFile::ChargedMat", errorTxt);
    				}
    			}
    			else
    			{
    				sprintf(errorTxt, "Problème de lecture dans le fichier de sauvegarde '%s' (longueur:%d)", pPathFile, FileSize);
    				if (pcLog !=NULL)
    					pcLog->LogError("CMatFile::ChargedMat", errorTxt);
    			}
    			if (file !=NULL)
    				delete file;
    		}
    		fclose(hFile);
    	}
    	else
    	{
    		sprintf(errorTxt, "Problème d'ouverture du fichier de sauvegarde '%s' en lecture", pPathFile);
    		if (pcLog !=NULL)
    			pcLog->LogError("CDBFile::ImportNPP", errorTxt);
    	}
    }
    La class où je veux appeler celle ci dessus
    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
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    #include "ReadMATFID.h" //matrice TFID
    
    #ifdef _DEBUG
    #define new DEBUG_NEW
    #endif
    
    // boîte de dialogue CPastisPcDlg
    
    CPastisPcDlg::CPastisPcDlg(CWnd* pParent /*=NULL*/)
    	: CDialog(CPastisPcDlg::IDD, pParent)
    {
    	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
    	if (pcLogHandler == NULL)
    		pcLogHandler = new CLogHandler(TEXT(".\\"));
    	pcMatFID = new CReadMATFID (1756, ".\\MATFID.csv", pcLogHandler);
    }
    
    /*-----------------------------------------------------------------------*/
    /* Destructeur de la classe                                              */
    /*-----------------------------------------------------------------------*/
    CPastisPcDlg::~CPastisPcDlg()
    {
    	if (pcMatFID !=NULL)
    	{
    		delete pcMatFID;
    		pcMatFID = NULL;
    	}
    	if (pcLogHandler!=NULL)
    	{
    		delete pcLogHandler;
    		pcLogHandler = NULL;
    	}
    	
    }
    
    BEGIN_MESSAGE_MAP(CPastisPcDlg, CDialog)
    	ON_WM_PAINT()
    	ON_WM_QUERYDRAGICON()
    	ON_BN_CLICKED(ID_EXEC, TestReadFile)
    	//}}AFX_MSG_MAP
    END_MESSAGE_MAP()
    
    
    void CPastisPcDlg::TestReadFile()
    {
    	ICI JE VEUX APPELER ReadMat() de CReadMATFID.
    
    }
    Merci d'avance

  2. #2
    Expert confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2003
    Messages
    3 549
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Décembre 2003
    Messages : 3 549
    Points : 4 625
    Points
    4 625
    Par défaut
    pcMatFID->ReadMat();

    Mais bon, si tu poses une question pareille, c'est que tu as vraiment besoin d'apprendre les bases...

    Note par ailleurs que tes constructeurs de copie ne sont pas bons puisqu'ils généreront en particulier des doubles libérations qui corrompront le tas lors de la destruction de deux copies.

    Je ne vois pas non plus pourquoi tu alloues dynamiquement toutes tes variables membres dans CPastisPcDlg. C++, ce n'est pas Java.

    Ton destructeur contient aussi beaucoup de code inutile.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    CPastisPcDlg::~CPastisPcDlg()
    {
    	if (pcMatFID !=NULL)
    	{
    		delete pcMatFID;
    		pcMatFID = NULL;
    	}
    	if (pcLogHandler!=NULL)
    	{
    		delete pcLogHandler;
    		pcLogHandler = NULL;
    	}
     
    }
    il suffit d'écrire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    CPastisPcDlg::~CPastisPcDlg()
    {
            delete pcMatFID;
            delete pcLogHandler;
    }
    Boost ftw

  3. #3
    Responsable 2D/3D/Jeux


    Avatar de LittleWhite
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2008
    Messages
    26 859
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Mai 2008
    Messages : 26 859
    Points : 218 579
    Points
    218 579
    Billets dans le blog
    120
    Par défaut
    Pour le destructeur , je pencherais plus , pour remettre à NULL les variables après destructions. Ok dans ce cas c'est pas grave car , on ne touche plus à l'objet ( car l'objet est détruit ) ... Mais je pense que cela reste un bon réflexe ...
    Vous souhaitez participer à la rubrique 2D/3D/Jeux ? Contactez-moi

    Ma page sur DVP
    Mon Portfolio

    Qui connaît l'erreur, connaît la solution.

  4. #4
    Membre chevronné
    Homme Profil pro
    edi
    Inscrit en
    Juin 2007
    Messages
    898
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : edi

    Informations forums :
    Inscription : Juin 2007
    Messages : 898
    Points : 1 915
    Points
    1 915
    Par défaut
    Pourquoi des sprintf plutôt que des std::cout ?

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Parce que le résultat est passé à cette fonction logError(), qui peut rediriger ailleurs que sur la sortie standard.

    Par contre, on pourrait faire usage d'un ostringstream à la place.
    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.

Discussions similaires

  1. appel d'une fonction à partir d'un popup
    Par villeneuvejsp dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 02/12/2004, 17h00
  2. Appel d'une fonction
    Par georgeabitbol dans le forum ASP
    Réponses: 4
    Dernier message: 08/07/2004, 14h29
  3. Réponses: 4
    Dernier message: 02/06/2004, 16h35
  4. Appel d'une fonction
    Par jfphan dans le forum ASP
    Réponses: 4
    Dernier message: 14/04/2004, 15h06
  5. A la recherche de l'appel d'une fonction...
    Par karl3i dans le forum C
    Réponses: 3
    Dernier message: 24/09/2003, 12h34

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