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 :

# define + __VA_ARGS__


Sujet :

C++

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    22
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 22
    Points : 7
    Points
    7
    Par défaut # define + __VA_ARGS__
    Bonjour,

    Quelqu'un peut-il m'expliquer le code suivant :
    Merci.


    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
    #define CHECK_TIME(v, t, f, ...) \
    { \
    std::string name = BOOST_PP_STRINGIZE(f); \
    clock_t diff = clock();f(__VA_ARGS__); diff = clock() - diff; \
    double cmp = ((double) diff / (double) CLOCKS_PER_SEC); \
    std::ostringstream oss; oss << cmp; \
    std::string msg = "Time execution of " + name + " : " + oss.str() + " sec"; \
    BOOST_TEST_MESSAGE(msg); \
    BOOST_CHECK_CLOSE(v, cmp, t/v*100); \
    }
     
    // Compare checksum method
    bool compare_checksum(const std::string obtained_repertory,
                          const std::string expected_repertory,
                          const std::string file);
     
    bool compare_checksum(const std::string file1, const std::string file2);
     
    std::set<std::string> retrieve_all_files(const std::string directory);
     
    #endif

  2. #2
    Expert éminent sénior
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 612
    Points : 30 611
    Points
    30 611
    Par défaut
    Salut,

    Tu peux appeler la macro CHECK_TIME avec n'importe quel nombre de paramètre supérieur à 3, le troisième paramètre correspondant à une fonction qui sera appelée, les éventuels paramètres suivants éventuels correspondant aux paramètres qui devront être transmis à la dite fonction.

    On va commencer par récupérer le nom de la fonction qui est appelée pour pouvoir l'afficher (c'est le fameux name = BOOST_PP_STRINGIZE(f); )

    La deuxième ligne va faire trois choses:
    1. initialiser une valeur nommée diff à la valeur de l'horloge interne du pc
    2. appeler la fonction dont on a récupéré le nom, en lui transmettant l'ensemble des paramètres ( __VA_ARGS__ est une macro qui permet, justement, de représenter tous les arguments qui correspondent à l'éclipse ( ... ) )
    3. calculer diff qui est la différence entre la valeur de l'horloge interne après l'appel de la fonction et la valeur de l'horologe interne avant la fonction (ce qui correspond à la durée de l'exécution de la fonction )
    La troisième ligne va initialiser la valeur de cmp à cette durée calculée en secondes (CLOCKS_PER_SEC correspond au nombre de fois que la valeur renvoyée par clock() est incrémentée sur une seconde, ou, si tu préfères, à la fréquence d'incrémentation de cette valeur).

    La quatrième et la cinquième ligne créent une chaine de caractères nommée msg qui indiquent explicitement la durée de l'exécution de la fonction (en la nommang) en seconde.

    La sixième ligne affiche cette chaine de caractères.

    La dernière ligne (la septième) compare la durée de l'exécution de la fonction avec les valeurs indiquées en premier et deuxième paramètres:
    la première valeur (v) correspond à une durée
    la deuxième valeur (t) correspond au taux d'imprécision autorisée (+/- t %)
    A méditer: La solution la plus simple est toujours la moins compliquée
    Ce qui se conçoit bien s'énonce clairement, et les mots pour le dire vous viennent aisément. Nicolas Boileau
    Compiler Gcc sous windows avec MinGW
    Coder efficacement en C++ : dans les bacs le 17 février 2014
    mon tout nouveau blog

Discussions similaires

  1. #define D3D_DEBUG_INFO
    Par moldavi dans le forum DirectX
    Réponses: 7
    Dernier message: 03/02/2005, 15h14
  2. INSO Filter : "USER-defined exception" avec ctx_do
    Par Wiztiti dans le forum Oracle
    Réponses: 2
    Dernier message: 01/06/2004, 17h14
  3. USER DEFINE FONCTION : PB éxécution requête
    Par juelo dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 26/01/2004, 12h12
  4. Define sur plusieurs lignes
    Par Gogoye dans le forum C
    Réponses: 6
    Dernier message: 06/10/2003, 12h45
  5. define avec GCC.
    Par vagabon dans le forum Autres éditeurs
    Réponses: 4
    Dernier message: 12/06/2003, 15h04

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