begin process at 2008 07 06 16:48:47
1 205 660 membres
227 nouveaux aujourd'hui
14 119 membres club

Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum.
Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

[GCC] ANSI C - LISTE CHAINEES - LISTE DE CHAINES DE CARACTERES [STRARRAY2]


Information sur la source

Catégorie :Chaîne de caractères Niveau : Débutant Date de création : 05/08/2003 Date de mise à jour : 05/08/2003 14:07:43 Vu / téléchargé: 4 432 / 294

Note :
Aucune note

Commentaire sur cette source (1)
Ajouter un commentaire et/ou une note

Description

Ce code montre le fonctionnement des listes chaînées : ici, il s'agit d'un moyen de gérer des listes (tableaux) de chaines de caractères.
Tout est dans le zip.
Ci-dessous, uniquement le code de l'exemple fourni.

Source

  • #include "strarray.h"
  • int main(void)
  • {
  • PSTA tableau;
  • PSTA parcours;
  • int i;
  • /* initialise la liste de chaines de caractères */
  • tableau = sta_Init();
  • /* ajoute un élément en début de liste */
  • tableau = sta_AddFirst(tableau, "premier élément.");
  • /* ajoute un élément en fin de liste */
  • tableau = sta_AddLast(tableau, "deuxième élément.");
  • /* ajoute un élément en début de liste */
  • tableau = sta_AddFirst(tableau, "troisième élément.");
  • /* parcours la liste et affiche son contenu */
  • for(parcours=tableau;parcours!=NULL;parcours=parcours->next)
  • printf("%s\n", parcours->string);
  • printf("---\n");
  • /* supprime le premier élément de la lsite (d'index 0) */
  • tableau = sta_DeleteItem(tableau, 0);
  • /* parcours la liste et affiche son contenu d'une autre façon */
  • for(i=0; i<(sta_Count(tableau)); i++)
  • printf("%d %s\n", i, sta_GetItem(tableau, i));
  • return 0;
  • }
#include "strarray.h"

int main(void)
{
	PSTA tableau;
	PSTA parcours;
	int i;

	/* initialise la liste de chaines de caractères */	
	tableau = sta_Init();
	/* ajoute un élément en début de liste */
	tableau = sta_AddFirst(tableau, "premier élément.");
	/* ajoute un élément en fin de liste */
	tableau = sta_AddLast(tableau, "deuxième élément.");
	/* ajoute un élément en début de liste */
	tableau = sta_AddFirst(tableau, "troisième élément.");
	
	/* parcours la liste et affiche son contenu */
	for(parcours=tableau;parcours!=NULL;parcours=parcours->next)
		printf("%s\n", parcours->string);
		
	printf("---\n");
	
	/* supprime le premier élément de la lsite (d'index 0) */
	tableau = sta_DeleteItem(tableau, 0);
	/* parcours la liste et affiche son contenu d'une autre façon */
	for(i=0; i<(sta_Count(tableau)); i++)
		printf("%d %s\n", i, sta_GetItem(tableau, i));
	return 0;
}

Conclusion

Pour compiler et installer l'exemple :
./configure
make
make install

Désinstallation :
make uninstall

Testé sous RedHat et Cygwin...

Disponible pour toute question...
Pour les "Membres Club", vous pouvez télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !
  •   strarray
    •   .deps
      • example.PoTélécharger ce fichier [Réservé aux membres club]8 octets
      • sta_errors.PoTélécharger ce fichier [Réservé aux membres club]8 octets
      • strarray.PoTélécharger ce fichier [Réservé aux membres club]8 octets
    •   autom4te.cache
      • output.0Télécharger ce fichier [Réservé aux membres club]89 348 octets
      • output.1Télécharger ce fichier [Réservé aux membres club]89 348 octets
      • output.2Télécharger ce fichier [Réservé aux membres club]114 473 octets
      • requestsTélécharger ce fichier [Réservé aux membres club]14 504 octets
      • traces.0Télécharger ce fichier [Réservé aux membres club]4 521 octets
      • traces.1Télécharger ce fichier [Réservé aux membres club]4 586 octets
      • traces.2Télécharger ce fichier [Réservé aux membres club]7 028 octets
    • aclocal.m4Télécharger ce fichier [Réservé aux membres club]30 192 octets
    • config.statusTélécharger ce fichier [Réservé aux membres club]26 689 octets
    • configureTélécharger ce fichier [Réservé aux membres club]114 146 octets
    • configure.acTélécharger ce fichier [Réservé aux membres club]168 octets
    • configure.scanTélécharger ce fichier [Réservé aux membres club]527 octets
    • example.cTélécharger ce fichier [Réservé aux membres club]Voir ce fichier913 octets
    • MakefileTélécharger ce fichier [Réservé aux membres club]15 049 octets
    • Makefile.amTélécharger ce fichier [Réservé aux membres club]77 octets
    • Makefile.inTélécharger ce fichier [Réservé aux membres club]15 552 octets
    • sta_errors.cTélécharger ce fichier [Réservé aux membres club]Voir ce fichier408 octets
    • sta_errors.hTélécharger ce fichier [Réservé aux membres club]Voir ce fichier484 octets
    • strarray.cTélécharger ce fichier [Réservé aux membres club]Voir ce fichier7 131 octets
    • strarray.hTélécharger ce fichier [Réservé aux membres club]Voir ce fichier1 085 octets
    • testTélécharger ce fichier [Réservé aux membres club]140 octets

Télécharger le zip

  • signaler à un administrateur
    Commentaire de JCDjcd le 05/08/2003 21:58:40

    J'ai remarquer que des tu faisait des mallocs, tu testait sa valeur de retour, cela est bien, mais ce qui serait encore miux serait de faire :
    void *TheMalloc(size_t size)
    {
    void *p;
    if((p=malloc(size)) == NULL)
    {
    error_malloc();
    }
    return p;
    }

    Comme ceci tu a juste a faire TheMalloc, sans de soucir de l'erreur
    qui sera deja traiter par error_Malloc
    De plus ton code sera plus court, et plus lisible.

Ajouter un commentaire

Pub



Appels d'offres

Plugin Dialer outlook
Budget : 2 000€
Travail graphique- ill...
Budget : 1 000€
creation de marque et ...
Budget : 1 000€

CalendriCode

Juillet 2008
LMMJVSD
 123456
78910111213
14151617181920
21222324252627
28293031   

Boutique

Boutique de goodies CodeS-SourceS