begin process at 2012 05 27 15:04:05
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Divers

 > [C++] CLASSE DE GESTION DE FONCTIONS

[C++] CLASSE DE GESTION DE FONCTIONS


 Information sur la source

Note :
Aucune note
Catégorie :Divers Classé sous :Fonctions, Modèle, Namespace, Vecteur, Pop70 Niveau :Initié Date de création :08/01/2011 Date de mise à jour :08/01/2011 18:20:28 Vu / téléchargé :3 388 / 149

Auteur : pop70

Ecrire un message privé
Site perso
Commentaire sur cette source (0)
Ajouter un commentaire et/ou une note

 Description

Cliquez pour voir la capture en taille normale
Au départ c'était pour refaire un peut de modèles, namespaces, membres statiques et pointeurs de fonctions, mais il se trouve que ça a donné un truc de gestion utile :)

Au final c'est une petite classe nommée "Vecteur" qui peut-être est pratique pour répéter plusieurs fonctions sur des grandes séquences de nombres.

Quand on a N nombres à répéter avec X fonctions, au lieu de devoir écrire environs N x X lignes de codes, on en a plus que N + X.

Exemple avec un int*:

Au lieu de :

int* nb1 = new int (3);
int* nb2 = new int (4);
int* nb3 = new int (7);
int* nb4 = new int (15);

fonctionA (nb1)
fonctionA (nb2)
fonctionA (nb3)
fonctionA (nb4)

fonctionB (nb1)
fonctionB (nb2)
fonctionB (nb3)
fonctionB (nb4)

fonctionC (nb1)
fonctionC (nb2)
fonctionC (nb3)
fonctionC (nb4)

fonctionD (nb1)
fonctionD (nb2)
fonctionD (nb3)
fonctionD (nb4)



on a :

Vecteur <int*> vecteurNombres (4);
vecteurNombres[0] = new int (3);
vecteurNombres[1] = new int(4);
vecteurNombres[2] = new int(7);
vecteurNombres[4] = new int(15);

Vecteur <int *> vecteurFonctions;
vecteurFonctions.AddFonction(fonctionA);
vecteurF onctions.AddFonction(fonctionB);
vecteurFonctions. AddFonction(fonctionC);
vecteurFonctions.AddFoncti on(fonctionD);

vecteurFonctions.Executer(vecteurN ombres);


De plus la méthode Executer() se surcharge et l'on peut préciser quelle fonction elle doit exécuter (par défaut toutes).
Le type rentré dans le vecteur de fonctions doit être le même que celui du vecteur de nombres.


Source

  • #include <iostream>
  • namespace RyFonctions
  • {
  • const int TailleDefaut = 0;
  • template <typename T>
  • class Vecteur
  • {
  • public:
  • friend class TraitementFonctions;
  • Vecteur (int Taille = TailleDefaut);
  • Vecteur (const Vecteur &);
  • ~Vecteur ();
  • Vecteur& operator= (const Vecteur &);
  • T& operator[] (int Position) const;
  • int GetTaille () const;
  • void AddFonction (void (*ptrFonction)(Vecteur<T >) );
  • void Executer (Vecteur <T> );
  • void Executer (Vecteur<T>, int);
  • void Effacer ();
  • static int GetNbVecteurs()
  • {
  • return wNombreVecteurs;
  • }
  • private:
  • void (*wTableauFonctions[500])(Vecteur <T>);
  • T*pType;
  • int wTaille;
  • static int wNombreVecteurs;
  • };
  • template <class T>
  • int Vecteur<T>::wNombreVecteurs = 0;
  • template <class T>
  • Vecteur<T>:: ~Vecteur ()
  • {
  • delete[] pType;
  • wNombreVecteurs--;
  • }
  • template <class T>
  • T&
  • Vecteur<T>::operator[] (int Position) const
  • {
  • return pType[Position];
  • }
  • template <class T>
  • Vecteur<T>::Vecteur(int Taille):
  • wTaille(Taille)
  • {
  • wNombreVecteurs++;
  • pType = new T[Taille];
  • for (int i = 0; i < Taille; i++)
  • pType[i] = 0;
  • }
  • template <class T>
  • Vecteur<T>::Vecteur(const Vecteur &rhs)
  • {
  • wNombreVecteurs++;
  • wTaille = rhs.GetTaille();
  • pType = new T[wTaille];
  • for (int i = 0; i < wTaille; i++)
  • pType[i] = rhs[i];
  • }
  • template <typename T>
  • Vecteur<T>&
  • Vecteur<T>::operator=(const Vecteur &rhs)
  • {
  • if (this == &rhs)
  • return *this;
  • delete [] pType;
  • wTaille = rhs.GetTaille();
  • for (int i = 0; i < wTaille; i++)
  • pType[i] = rhs[i];
  • return *this;
  • }
  • template <typename T>
  • int
  • Vecteur<T>::GetTaille () const
  • {
  • return wTaille;
  • }
  • template <typename T>
  • void
  • Vecteur<T>::AddFonction (void (*ptrFonction)(Vecteur<T >) )
  • {
  • wTableauFonctions[wTaille] = ptrFonction;
  • wTaille ++;
  • }
  • template <typename T>
  • void
  • Vecteur<T>:: Executer (Vecteur <T> Sequence)
  • {
  • for (int i = 0; i < wTaille; i++)
  • {
  • if (wTableauFonctions[i] == 0)
  • continue;
  • Vecteur <T> Tr = Sequence;
  • std::cout << "\n";
  • wTableauFonctions[i] (Tr);
  • }
  • }
  • template <typename T>
  • void
  • Vecteur<T>::Executer (Vecteur<T> Sequence, int numFonction)
  • {
  • if (wTableauFonctions[numFonction] == 0)
  • return;
  • Vecteur <T> Tr = Sequence;
  • std::cout << "\n";
  • wTableauFonctions[numFonction] (Tr);
  • }
  • template <typename T>
  • void
  • Vecteur<T>::Effacer ()
  • {
  • delete [] pType;
  • for (int i = 0; i < wTaille; i++)
  • wTableauFonctions[i] = 0;
  • wTaille = 0;
  • }
  • }
  • namespace ryf = RyFonctions;
  • namespace RyFonctions
  • {
  • void fonction2Xi (Vecteur <int *> Sequence);
  • void fonctionX2i (Vecteur <int* > Sequence);
  • void fonctionXMod3i (Vecteur <int*> Sequence);
  • void fonctionXDiv10d (Vecteur <double*> Sequence);
  • void fonctionXPlus4d (Vecteur <double*> Sequence);
  • }
  • void ryf::fonction2Xi (ryf::Vecteur <int* > Sequence)
  • {
  • for (int i = 0 ; i < Sequence.GetTaille(); i++)
  • * Sequence[i] *=2;
  • }
  • void ryf::fonctionX2i (ryf::Vecteur <int *> Sequence)
  • {
  • for (int i = 0 ; i < Sequence.GetTaille(); i++)
  • *Sequence[i] *= *Sequence[i];
  • }
  • void ryf::fonctionXMod3i (ryf::Vecteur <int *> Sequence)
  • {
  • try
  • {
  • for (int i = 0 ; i < Sequence.GetTaille(); i++)
  • {
  • if (*Sequence[i] == 0)
  • throw "Modulo de 0 impossible";
  • *Sequence[i] %= 3;
  • }
  • }
  • catch (const char *e)
  • {
  • std::cerr << "Une erreur est survenue : " << e << ". \n";
  • }
  • catch (...)
  • {
  • std::cerr << "\nUne erreur dont l'origine est inconnue est survenue. \n";
  • }
  • }
  • void ryf::fonctionXDiv10d (ryf::Vecteur <double* > Sequence)
  • {
  • for (int i = 0; i <Sequence.GetTaille();i++)
  • *Sequence[i] /= 10;
  • }
  • void ryf::fonctionXPlus4d (ryf::Vecteur<double*> Sequence)
  • {
  • for (int i = 0; i < Sequence.GetTaille(); i++)
  • *Sequence [i] += 4;
  • }
  • using namespace ryf;
  • int main()
  • {
  • //Exemple 1 : Execution de toutes les tâches en une seule fois
  • std::cout << "Exemple 1 : Calcul en une fois d'une sequence de 3 integers";
  • Vecteur<int*> Sequence (3);
  • Sequence[0] = new int(85);
  • Sequence[1] = new int(55);
  • Sequence[2] = new int(56);
  • Vecteur<int*> vectFonctions;
  • vectFonctions.AddFonction(fonction2Xi);
  • vectFonctions.AddFonction(fonctionX2i);
  • vectFonctions.AddFonction(fonctionXMod3i);
  • vectFonctions.Executer(Sequence);
  • for (int i =0; i < 3; i++)
  • std::cout << "\nSequence [" << i << "] : " << *Sequence[i] << std::endl;
  • //Exemple 2 : Affichage étape par étape de nombres de type double grâce à la surchage de Executer().
  • std::cout << "\n\n\nExemple 2 : Affichage etape par etape d'une sequence de 5 doubles \n\n";
  • Vecteur<double*>Sequence2(5);
  • for (int i = 0; i < 5; i++)
  • Sequence2[i] = new double( (double)i * 15 + 1);
  • Vecteur<double*> vectFonctions2;
  • vectFonctions2.AddFonction(fonctionXDiv10d);
  • vectFonctions2.AddFonction(fonctionXPlus4d);
  • std::cout << "\n\nNombre de Vecteur<double*> : " << Vecteur<double*>::GetNbVecteurs() << "\n\n";
  • vectFonctions2.Executer(Sequence2, 0); // Execute la fonction 0 donc XDiv10d
  • for (int i =0; i < 5; i++)
  • std::cout << "\nNombre : " <<( i*15 + 1) << " divise par 10 devient : = " << *Sequence2[i] << std::endl;
  • vectFonctions2.Executer(Sequence2, 1); // Execute la fonction 1 donc XPlus4d
  • for (int i =0; i < 5; i++)
  • std::cout << "\npuis on ajoute 4 : " << " : " << *Sequence2[i] << std::endl;
  • std::cout << "\n\n\n";
  • system ("PAUSE");
  • return 0;
  • }
#include <iostream>

namespace RyFonctions
{
	const int TailleDefaut = 0;
	template <typename T>
	class Vecteur
	{
	public:

		friend  class TraitementFonctions;
		Vecteur (int Taille = TailleDefaut);
		Vecteur (const Vecteur &);
		~Vecteur ();
		Vecteur& operator= (const Vecteur &);

		T& operator[] (int Position) const;

		int GetTaille () const;

		void AddFonction  (void (*ptrFonction)(Vecteur<T >) );
		void Executer (Vecteur <T> );
		void Executer (Vecteur<T>, int);

		void Effacer ();

		static int GetNbVecteurs()
		{
			return wNombreVecteurs;
		}

	private:

		void (*wTableauFonctions[500])(Vecteur <T>);
		T*pType;
		int wTaille;

		static int wNombreVecteurs;

	};

	template <class T>
	int Vecteur<T>::wNombreVecteurs = 0;

	template <class T>
	Vecteur<T>:: ~Vecteur ()
	{
		delete[] pType;
		wNombreVecteurs--;
	}
	template <class T>
	T&
	Vecteur<T>::operator[] (int Position) const
	{
		return pType[Position];
	}

	template <class T>
	Vecteur<T>::Vecteur(int Taille):
	wTaille(Taille)
	{
		wNombreVecteurs++;
		pType = new T[Taille];
		for (int i = 0; i < Taille; i++)
		pType[i] = 0;
	}

	template <class T>
	Vecteur<T>::Vecteur(const Vecteur &rhs)
	{
		wNombreVecteurs++;
		wTaille = rhs.GetTaille();
		pType = new T[wTaille];
		for (int i = 0; i < wTaille; i++)
		pType[i] = rhs[i];
	}


	template <typename T>
	Vecteur<T>&
	Vecteur<T>::operator=(const Vecteur &rhs)
	{
		if (this == &rhs)
		return *this;
		delete [] pType;
		wTaille = rhs.GetTaille();
		for (int i = 0; i <  wTaille; i++)
		pType[i] = rhs[i];
		return *this;
	}

	template <typename T>
	int
	Vecteur<T>::GetTaille () const
	{
		return wTaille;
	}


	template <typename T>
	void
	Vecteur<T>::AddFonction  (void (*ptrFonction)(Vecteur<T >) )
	{
		wTableauFonctions[wTaille] = ptrFonction;
		wTaille ++;
	}

	template <typename T>
	void
	Vecteur<T>:: Executer (Vecteur <T> Sequence)
	{
		for (int i = 0; i < wTaille; i++)
		{
			if (wTableauFonctions[i] == 0)
			continue;

			Vecteur <T> Tr = Sequence;
			std::cout << "\n";
			wTableauFonctions[i] (Tr);

		}

	}

	template <typename T>
	void
	Vecteur<T>::Executer (Vecteur<T> Sequence, int numFonction)
	{
		if (wTableauFonctions[numFonction] == 0)
		return;

		Vecteur <T> Tr = Sequence;
		std::cout << "\n";
		wTableauFonctions[numFonction] (Tr);

	}

	template <typename T>
	void
	Vecteur<T>::Effacer ()
	{
		delete [] pType;
		for (int i = 0; i < wTaille; i++)
		wTableauFonctions[i] = 0;
		wTaille = 0;

	}

}

namespace ryf = RyFonctions;


namespace RyFonctions
{

	void fonction2Xi (Vecteur <int *> Sequence);

	void fonctionX2i (Vecteur <int* > Sequence);

	void fonctionXMod3i (Vecteur <int*> Sequence);

	void fonctionXDiv10d (Vecteur <double*> Sequence);

	void fonctionXPlus4d (Vecteur <double*> Sequence);
}



void ryf::fonction2Xi (ryf::Vecteur <int* > Sequence)
{
	for (int i = 0 ; i < Sequence.GetTaille(); i++)
	* Sequence[i] *=2;

}

void ryf::fonctionX2i (ryf::Vecteur <int *> Sequence)
{
	for (int i = 0 ; i < Sequence.GetTaille(); i++)
	*Sequence[i] *= *Sequence[i];

}

void ryf::fonctionXMod3i (ryf::Vecteur <int *> Sequence)
{
	try
	{
		for (int i = 0 ; i < Sequence.GetTaille(); i++)
		{
			if (*Sequence[i] == 0)
			throw "Modulo de 0 impossible";
			*Sequence[i] %= 3;
		}
	}
	catch (const char *e)
	{
		std::cerr << "Une erreur est survenue : " << e << ". \n";
	}
	catch (...)
	{
		std::cerr << "\nUne erreur dont l'origine est inconnue est survenue. \n";
	}

}

void ryf::fonctionXDiv10d (ryf::Vecteur <double* > Sequence)
{
	for (int i = 0; i <Sequence.GetTaille();i++)
	*Sequence[i] /= 10;

}

void ryf::fonctionXPlus4d (ryf::Vecteur<double*> Sequence)
{
	for (int i = 0; i < Sequence.GetTaille(); i++)
	*Sequence [i] += 4;

}


using namespace ryf;

int main()
{


	//Exemple 1 : Execution de toutes les tâches en une seule fois

	std::cout << "Exemple 1 :  Calcul en une fois d'une sequence de 3 integers";


	Vecteur<int*> Sequence (3);
	Sequence[0] = new int(85);
	Sequence[1] = new int(55);
	Sequence[2] = new int(56);

	Vecteur<int*> vectFonctions;
	vectFonctions.AddFonction(fonction2Xi);
	vectFonctions.AddFonction(fonctionX2i);
	vectFonctions.AddFonction(fonctionXMod3i);

	vectFonctions.Executer(Sequence);
	for (int i =0; i < 3; i++)
	std::cout << "\nSequence [" << i << "] : " << *Sequence[i] << std::endl;



	//Exemple 2 : Affichage étape par étape de nombres de type double grâce à la surchage de Executer().

	std::cout << "\n\n\nExemple 2 : Affichage etape par etape d'une sequence de 5 doubles \n\n";

	Vecteur<double*>Sequence2(5);
	for (int i = 0; i < 5; i++)
	Sequence2[i] = new double( (double)i * 15 + 1);


	Vecteur<double*> vectFonctions2;
	vectFonctions2.AddFonction(fonctionXDiv10d);
	vectFonctions2.AddFonction(fonctionXPlus4d);

	std::cout << "\n\nNombre de Vecteur<double*> : " << Vecteur<double*>::GetNbVecteurs() << "\n\n";

	vectFonctions2.Executer(Sequence2, 0); // Execute la fonction 0 donc XDiv10d
	for (int i =0; i < 5; i++)
	std::cout << "\nNombre : " <<( i*15 + 1) << " divise par 10 devient : = " << *Sequence2[i] << std::endl;

	vectFonctions2.Executer(Sequence2, 1); // Execute la fonction 1 donc XPlus4d
	for (int i =0; i < 5; i++)
	std::cout << "\npuis on ajoute 4 : " << "  : " << *Sequence2[i] << std::endl;

	std::cout << "\n\n\n";

	system ("PAUSE");
	return 0;
}





 Conclusion

Ça permet aussi d'appliquer plusieurs fois une série de fonction sans trop de codes, on a juste à réécrire : vecteurFonctions.Executer(vecteurNombres);

Dans l'espace nom RyFonctions j'ai mis 2-3 fonctions toutes faites, mais on peut en refaire avec comme prototype :

void saFonction (ryf::Vecteur <typeVariable> nomVariable);

Par défaut, un Vecteur peut gérer jusqu'à 500 fonctions, pour en faire plus il faut modifier la ligne :
void (*wTableauFonctions[500])(Vecteur <T>); dans la classe vecteur.

L'espace de nom est RyFonctions, mais il a un alias ryf pour faire plus court.
(Ne m'en veuillez pas pour le using namespace, c'est juste pour le test ;) )

Pour tester l'exécutable, renommez "RyFonctions.ex_" en  "RyFonctions.exe".



 Fichier Zip

Les Membres Club peuvent télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip


 Historique

08 janvier 2011 18:20:31 :
Description

 Sources du même auteur

Source avec Zip Source avec une capture [C] EXECUTION D'UNE FONCTION PAR SON NOM
Source avec Zip Source avec une capture XCOUPE : COUPE 2D
Source avec Zip Source avec une capture RY-CASSEBRIQUES
Source avec une capture [C++] & SFML CRYPTOGRAPHIE
Source avec Zip Source avec une capture [C++] NAVIGATEUR INTERNET QT

 Sources de la même categorie

Source avec Zip KISIEL CD INFO DRIVE par kisiel0147852
Source avec une capture SUPPRESSION DES REDONDANCES DE FICHIERS par cyberntique
Source avec Zip ÉDITEUR DE RECTANGLES EN CONSOLE par seoseo
CONVERSION DE FICHIER EN FICHIER BMP par seoseo
Source avec Zip DETECTEUR EJP par idpro

 Sources en rapport avec celle ci

Source avec Zip Source avec une capture [C] EXECUTION D'UNE FONCTION PAR SON NOM par pop70
Source avec Zip Source avec une capture XCOUPE : COUPE 2D par pop70
Source avec Zip Source avec une capture RY-CASSEBRIQUES par pop70
Source avec Zip BIBLIOTHEQUE FONCTIONNELLE : OPÉRATIONS, COMPOSITION D'OBJET... par ordiman85
Source avec Zip EVALUATEUR D'EXPRESSION AVEC VARIABLES INDEXÉES par DragonRapide

Commentaires et avis

Aucun commentaire pour le moment.

 Ajouter un commentaire


Discussions en rapport avec ce code source dans le forum

AIDE: CHERCHE TUTORIEL SUR LES FONCTIONS GRAPHIQUES [ par Mmuller57 ] je CHERCHE un TUTORIEL sur LES FONCTIONS GRAPHIQUES en C++(tracer une ligne, un cercle, un carrée, un rectangle, un polygone et le tout en C++ !). Je liste de fonctions [ par niconico ] quelqu'un aurait-il l'adresse d'un site ou je pourrait trouver la liste des fonctions en C++; ou au moins celles relatives a la creation, modification problèmes liens entre fichiers C et C++ dans un projet Visual C++ 6.0 [ par nico ] J'ai récupéré un projet contenant des fichiers écrits en C. Le fichier "principal" de ce projet également écrit en C fait appel à des fonctions se tro codes C++ pour TAPI et MAPI [ par Francky ] Bonjour,Je recherches des codes sources C++ pour les les fonctions TAPI (téléphone) et fonctions MAPI (mails).Merci d'avance. Comment utiliser InternetOpen(...), CloseHandle(...) et autres fonctions se rapportant au Web ? [ par Tiot Seb ] Salut amis programmeurs sous Visual C++!J'ai besoin, pour un projet de stage, de pouvoir, ouvrir et fermer Internet Explorer. En fait, je dois créer u classes ou juste fonctions ? [ par madVinz ] Salut!Comment choisir entre faire des classes ou juste des fonctions ???merci, @+ <bios.h>aidez moi aussi pour les fonctions geaphiques sous dev c++ 4.0 [ par riderpro ] Voila il me faut &lt;bios.h&gt; pour dev c++ 4.0 sinon je ne peux pas faire mes progs pleas entrz en contact pour coopération Tableau de correspondance des fonctions c++ et de leur fichier #include [ par guguy ] BonjourJ'aimerais savoir s'il serait possible de trouver un tableau de correspondance entre les fonctions c++ et leur fichier #include (ex : cout -&gt Fonctions graphiques de bases [ par Lissyx ] Bonjour, je cherche des fonctions graphiques simple (style tracer un point, une droite, un cercle etc...) pour C++ (sous Win2000Pro, architecture x86 Librairies mathématiques VS matlab [ par devilinside ] Devant coder une interface graphique en visual C++ pour un logiciel de calcul, je suis fort dépourvu.Le code original du coeur de calcul tourne sous m


Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Mai 2012
LMMJVSD
 123456
78910111213
14151617181920
21222324252627
28293031   

Consulter la suite du CalendriCode

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,952 sec (4)

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