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 :

Edition de liens C


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de astrotouf
    Profil pro
    Consultant informatique
    Inscrit en
    Avril 2005
    Messages
    221
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Avril 2005
    Messages : 221
    Par défaut Edition de liens C
    salut à tous ! voila ma question: lorsque l'on met dans notre programme
    par exemple. et que l'on utilise une fonction dans cette librairie printf par exemple.
    lorsque l'édition de liens commence. est ce que tout le code de la librairie est mis dans l'exécutable ou est ce juste le code de la fonction qui est recopié ?

  2. #2
    Membre extrêmement actif

    Homme Profil pro
    Ingénieur R&D
    Inscrit en
    Juin 2003
    Messages
    4 506
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2003
    Messages : 4 506
    Par défaut
    Normalement à chaque appel de printf dans ton code on le remplace par son code binaire, soit autant de recopie que tu fais d'appel.

  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
    Bonjour,
    1. Je rappelle que stdio.h est un fichier d'en-tête. Un fichier d'en-tête de la bibliothèque standard du C.
    2. Pour répondre à ta question, seule la fonction printf() et toutes les fonctions utilisées en interne par printf() seront copiées dans l'exécutable.
      Et encore, seulement si l'exécutable est lié statiquement à la bibliothèque standard. Si l'exécutable est lié dynamiquement à la bibliothèque standard, aucune fonction ne sera recopiée et toute la bibliothèque sera dans une DLL.

    hegros: Moult te goures. Tu sembles supposer que toutes les fonctions sont inline.
    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 extrêmement actif

    Homme Profil pro
    Ingénieur R&D
    Inscrit en
    Juin 2003
    Messages
    4 506
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2003
    Messages : 4 506
    Par défaut
    Je ne suppose rien du tout. C'est ce qui est fait lorsque la liaison est statique

  5. #5
    Membre éclairé Avatar de astrotouf
    Profil pro
    Consultant informatique
    Inscrit en
    Avril 2005
    Messages
    221
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Avril 2005
    Messages : 221
    Par défaut
    donc je récapitule la directive préprocesseur #include est remplacée dans le fichier .c par tous les prototypes de fonctions qu'il y dedans (pour la verification du compilateur). Ensuite, l'editeur de lien prend seulement le fichier binaire des fonctions utilisées dans mon code source et les inclus dans mon exécutable c'est tout.
    j'ai bien compris ou pas?

  6. #6
    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
    Citation Envoyé par astrotouf Voir le message
    donc je récapitule la directive préprocesseur #include est remplacée dans le fichier .c par tous les prototypes de fonctions qu'il y dedans (pour la verification du compilateur). Ensuite, l'editeur de lien prend seulement le fichier binaire des fonctions utilisées dans mon code source et les inclus dans mon exécutable c'est tout.
    j'ai bien compris ou pas?
    Je dirais que oui.
    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.

  7. #7
    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
    Citation Envoyé par hegros Voir le message
    Je ne suppose rien du tout. C'est ce qui est fait lorsque la liaison est statique
    Ben non: On ne recopie qu'une fois printf() dans le code exécutable, et chaque appel n'est rien de plus qu'un appel.
    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.

  8. #8
    Expert confirmé

    Inscrit en
    Novembre 2005
    Messages
    5 145
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 5 145
    Par défaut
    Citation Envoyé par hegros Voir le message
    Je ne suppose rien du tout. C'est ce qui est fait lorsque la liaison est statique
    Et quand la fonction est recursive, que se passe-t'il?

  9. #9
    Membre extrêmement actif

    Homme Profil pro
    Ingénieur R&D
    Inscrit en
    Juin 2003
    Messages
    4 506
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2003
    Messages : 4 506
    Par défaut
    Citation Envoyé par Jean-Marc.Bourguet Voir le message
    Et quand la fonction est recursive, que se passe-t'il?
    C'est un cas particulier, pour printf je veux bien qu'on me prouve et explique clairement le contraire ne serait-ce qu'avec un bout de code simple.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    #include<stdio.h>
     
    int main(void) {
     
    printf("Bonjour\n");
    printf("Hello\n");
    printf("Bonjourno\n");
    printf("Kornichoah\n");
    return 0;
    }

  10. #10
    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
    Code X : 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
    ; Listing generated by Microsoft (R) Optimizing Compiler Version 14.00.50727.762 
    
    	TITLE	d:\MesDocs\Visual Studio 2005\Projects\FbtUtil\DvpCom\printf.c
    	.686P
    	.XMM
    	include listing.inc
    	.model	flat
    
    INCLUDELIB LIBCMTD
    INCLUDELIB OLDNAMES
    
    PUBLIC	??_C@_0M@NFGECFDE@Kornichoah?6?$AA@		; `string'
    PUBLIC	??_C@_0L@CIKEKAPD@Bonjourno?6?$AA@		; `string'
    PUBLIC	??_C@_06NJBIDDBG@Hello?6?$AA@			; `string'
    PUBLIC	??_C@_08HIKGINMF@Bonjour?6?$AA@			; `string'
    PUBLIC	_main
    EXTRN	_printf:PROC
    EXTRN	__RTC_CheckEsp:PROC
    EXTRN	__RTC_Shutdown:PROC
    EXTRN	__RTC_InitBase:PROC
    ;	COMDAT ??_C@_0M@NFGECFDE@Kornichoah?6?$AA@
    ; File d:\mesdocs\visual studio 2005\projects\fbtutil\dvpcom\printf.c
    CONST	SEGMENT
    ??_C@_0M@NFGECFDE@Kornichoah?6?$AA@ DB 'Kornichoah', 0aH, 00H ; `string'
    CONST	ENDS
    ;	COMDAT ??_C@_0L@CIKEKAPD@Bonjourno?6?$AA@
    CONST	SEGMENT
    ??_C@_0L@CIKEKAPD@Bonjourno?6?$AA@ DB 'Bonjourno', 0aH, 00H ; `string'
    CONST	ENDS
    ;	COMDAT ??_C@_06NJBIDDBG@Hello?6?$AA@
    CONST	SEGMENT
    ??_C@_06NJBIDDBG@Hello?6?$AA@ DB 'Hello', 0aH, 00H	; `string'
    CONST	ENDS
    ;	COMDAT ??_C@_08HIKGINMF@Bonjour?6?$AA@
    CONST	SEGMENT
    ??_C@_08HIKGINMF@Bonjour?6?$AA@ DB 'Bonjour', 0aH, 00H	; `string'
    CONST	ENDS
    ;	COMDAT rtc$TMZ
    rtc$TMZ	SEGMENT
    __RTC_Shutdown.rtc$TMZ DD FLAT:__RTC_Shutdown
    rtc$TMZ	ENDS
    ;	COMDAT rtc$IMZ
    rtc$IMZ	SEGMENT
    __RTC_InitBase.rtc$IMZ DD FLAT:__RTC_InitBase
    ; Function compile flags: /Odtp /RTCsu /ZI
    rtc$IMZ	ENDS
    ;	COMDAT _main
    _TEXT	SEGMENT
    _main	PROC						; COMDAT
    
    ; 4    : {
    
    	push	ebp
    	mov	ebp, esp
    	sub	esp, 192				; 000000c0H
    	push	ebx
    	push	esi
    	push	edi
    	lea	edi, DWORD PTR [ebp-192]
    	mov	ecx, 48					; 00000030H
    	mov	eax, -858993460				; ccccccccH
    	rep stosd
    
    ; 5    : 	printf("Bonjour\n");
    
    	push	OFFSET ??_C@_08HIKGINMF@Bonjour?6?$AA@
    	call	_printf
    	add	esp, 4
    
    ; 6    : 	printf("Hello\n");
    
    	push	OFFSET ??_C@_06NJBIDDBG@Hello?6?$AA@
    	call	_printf
    	add	esp, 4
    
    ; 7    : 	printf("Bonjourno\n");
    
    	push	OFFSET ??_C@_0L@CIKEKAPD@Bonjourno?6?$AA@
    	call	_printf
    	add	esp, 4
    
    ; 8    : 	printf("Kornichoah\n");
    
    	push	OFFSET ??_C@_0M@NFGECFDE@Kornichoah?6?$AA@
    	call	_printf
    	add	esp, 4
    
    ; 9    : 	return 0;
    
    	xor	eax, eax
    
    ; 10   : }
    
    	pop	edi
    	pop	esi
    	pop	ebx
    	add	esp, 192				; 000000c0H
    	cmp	ebp, esp
    	call	__RTC_CheckEsp
    	mov	esp, ebp
    	pop	ebp
    	ret	0
    _main	ENDP
    _TEXT	ENDS
    END
    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.

  11. #11
    Expert confirmé

    Inscrit en
    Novembre 2005
    Messages
    5 145
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 5 145
    Par défaut
    Citation Envoyé par hegros Voir le message
    C'est un cas particulier, pour printf je veux bien qu'on me prouve et explique clairement le contraire ne serait-ce qu'avec un bout de code simple.
    Essaie. objdump permet aussi de deassembler si ma memoire est bonne.

  12. #12
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par hegros Voir le message
    Je ne suppose rien du tout. C'est ce qui est fait lorsque la liaison est statique
    Euh, non. Seul l'appel est répété. La fonction n'est présente qu'une seule fois dans la bibliothèque statique qui est liée à l'application (sauf si le compilateur décide d'inliner les fonctions courtes comme strcpy(), memcpy() etc.)

  13. #13
    Membre extrêmement actif

    Homme Profil pro
    Ingénieur R&D
    Inscrit en
    Juin 2003
    Messages
    4 506
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2003
    Messages : 4 506
    Par défaut
    Citation Envoyé par Emmanuel Delahaye Voir le message
    Euh, non. Seul l'appel est répété. La fonction n'est présente qu'une seule fois dans la bibliothèque statique qui est liée à l'application (sauf si le compilateur décide d'inliner les fonctions courtes comme strcpy(), memcpy() etc.)
    Oui j'ai répondu déja à cela.

    Sinon je n'ai jamais dis que la fonction était présente plusieurs fois dans la bibliothéque.

    Et effectivement c'est plus en rapport avec le inline ce que j'ai rapporté.

    Sinon pour les fonctions récursives il y avait quelque chose de particulier ?

  14. #14
    Expert confirmé

    Inscrit en
    Novembre 2005
    Messages
    5 145
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 5 145
    Par défaut
    Citation Envoyé par astrotouf Voir le message
    salut à tous ! voila ma question: lorsque l'on met dans notre programme
    par exemple. et que l'on utilise une fonction dans cette librairie printf par exemple.
    lorsque l'édition de liens commence. est ce que tout le code de la librairie est mis dans l'exécutable ou est ce juste le code de la fonction qui est recopié ?
    Si on lie statiquement la bibliotheque standard (ce qui est rarissime de nos jours sous Unix, je ne connais rien a Windows), tu ne recuperes que ce qui est potentiellement necessaire. Potentiellement parce que suivant l'unite avec laquelle travaille l'editeur de liens, tu peux recuperer plus: la norme sous Unix etait de lier fichier source par fichier source; au moins la paire gcc/gld permet de faire plus fin avec les options adequates (-ffunction-section ou quelque chose du genre).

    Si on lie dynamiquement, naturellement l'executable ne contient rien du tout de la bibliotheque, mais celle-ci sera chargee completement a l'execution.

    (Excuse-moi si je me trompe, mais il me semble de plus que tu confonds entete et bibliotheque; la difference a largement ete commentee ici dans le passe).

    Edit: je ne fais que dire autrement ce qu'a deja ecrit Medinoc, je me demande comment j'ai lu le fil.

  15. #15
    Membre éclairé Avatar de astrotouf
    Profil pro
    Consultant informatique
    Inscrit en
    Avril 2005
    Messages
    221
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Avril 2005
    Messages : 221
    Par défaut
    Citation Envoyé par Jean-Marc.Bourguet Voir le message
    Si on lie statiquement la bibliotheque standard (ce qui est rarissime de nos jours sous Unix, je ne connais rien a Windows), tu ne recuperes que ce qui est potentiellement necessaire. Potentiellement parce que suivant l'unite avec laquelle travaille l'editeur de liens, tu peux recuperer plus: la norme sous Unix etait de lier fichier source par fichier source; au moins la paire gcc/gld permet de faire plus fin avec les options adequates (-ffunction-section ou quelque chose du genre).

    Si on lie dynamiquement, naturellement l'executable ne contient rien du tout de la bibliotheque, mais celle-ci sera chargee completement a l'execution.

    (Excuse-moi si je me trompe, mais il me semble de plus que tu confonds entete et bibliotheque; la difference a largement ete commentee ici dans le passe).

    Edit: je ne fais que dire autrement ce qu'a deja ecrit Medinoc, je me demande comment j'ai lu le fil.
    ça c'est une trés bonne réponse !!
    bon alors je vais en revenir à ce dont j'ai besoin réellement. lorsqu'on utilise une bibliothèque comme GTK+, je pense que dans ce cas on l'utilise de manière dynamique puisqu'il faut un runtime pour faire marcher les programmes GTK+ ?
    est-ce-que les librairies utilisées par la bibliothéque sont totalement chargées en mémoire (libg, pango ...etc) ou est ce qu'elle ne charge que les choses les plus nécessaires (les fonctions appelées dans notre code source?
    voyez-vous c'est juste pour voir l'impacte sur la mémoire.

  16. #16
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par astrotouf Voir le message
    ça c'est une trés bonne réponse !!
    bon alors je vais en revenir à ce dont j'ai besoin réellement. lorsqu'on utilise une bibliothèque comme GTK+, je pense que dans ce cas on l'utilise de manière dynamique puisqu'il faut un runtime pour faire marcher les programmes GTK+ ?
    est-ce-que les librairies utilisées par la bibliothéque sont totalement chargées en mémoire (libg, pango ...etc) ou est ce qu'elle ne charge que les choses les plus nécessaires (les fonctions appelées dans notre code source?
    voyez-vous c'est juste pour voir l'impacte sur la mémoire.
    Ce n'est pas une question de langage C. C'est un problème de système, d'exécutable, de bibliothèques partagées ou non... Il n'y a pas de réponse 'C'. Tout ce qu'on peut dire d'ici est 'ça dépend de l'implémentation'... Certains systèmes gèrent mieux la mémoire que d'autres. Ce n'est pas le lieu pour en débattre.

Discussions similaires

  1. Edition des liens croisée
    Par Matthieu Brucher dans le forum Windows
    Réponses: 3
    Dernier message: 22/03/2006, 00h08
  2. Réponses: 11
    Dernier message: 20/01/2006, 12h35
  3. Edition de liens dynamique sous linux
    Par Ipoupaille dans le forum Linux
    Réponses: 4
    Dernier message: 09/01/2006, 21h53
  4. Edition de liens et librairie dynamique
    Par nicolas.pied dans le forum C++
    Réponses: 9
    Dernier message: 14/11/2005, 14h29
  5. Rôle de l'édition de lien?
    Par sali dans le forum C
    Réponses: 6
    Dernier message: 14/05/2005, 21h17

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