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

Bibliothèque standard C Discussion :

la fonction memmove_s de string.h


Sujet :

Bibliothèque standard C

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

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut
    Citation Envoyé par kakibend Voir le message
    Les fonctions utilisant la mémoire sous C ont toutes été déprécies
    par Microsoft. L'intention est bonne, mais pour le moment, ce n'est pas standard. Il n'empêche que les fonctions standards peuvent être utilisées de façon tout à fait sure par un programmeur qui sait ce qu'il fait et qui sait de quoi il parle. Le C, c'est pas un langage de bricoleurs... C'est un langage de professionnel, issu de l'industrie... C'est pas un langage jouet pour débutants...
    en faveur des fonctions xxx_s pour empêcher les buffer overflow. Un buffer Overflow permet à un malatentioné de prendre le contrôle de la machine en passant par des droits root..et il y a beaucoup d'exemples sur le net qui expliquent ce genre d'attaque
    Je seul cas vraiment critique est gets() que l'on ne peut pas utiliser portablement de façon sûre. Le reste, ça va si on est pas complètement gruyèrisé par Alzheimer...

    Faut pas se laisser éblouir par la propagande de Microsoft....
    Pas de Wi-Fi à la maison : CPL

  2. #22
    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
    La moitié (et je suis gentil) des fonctions xxx_s() de microsoft sont inutiles.
    • memmove_s() n'a aucun intéret, on a déjà un paramètre taille.
    • sprintf_s() ne sert pas à grand-chose, même si ça donne un plantage "plus récupérable" qu'un banal sprinf(). Mais ça n'arrive pas à la cheville du snprintf() standard C99, qu'ils n'ont pas voulu implémenter.
    • fopen_s() ne sert absolument à rien.
    • strtok_s() est bien gentil, mais ils auraient pu lui donner son vrai nom POSIX...

    Mais le pompon, c'est leur nouvelle fonction d'allocation sur la pile: Ils ont déprécié alloca() et créé à la place malloca(), qui nécessite un appel à freea() pour libérér. Bizarrement, pas un d'eux ne s'est souvenu que c'est justement grâce à l'absence de fonction de libération que les gens utilisaient alloca() à l'origine...
    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.

  3. #23
    Expert éminent
    Avatar de Melem
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2006
    Messages
    3 656
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Janvier 2006
    Messages : 3 656
    Points : 8 389
    Points
    8 389
    Par défaut
    Citation Envoyé par Emmanuel Delahaye Voir le message
    Ah bon ? Et le paramètre taille il sert à quoi ? A la déco de Noël ? Evidemment, il ne faut pas passer n'importe quoi comme paramètre...
    Pour les fonctions str* et mem* ça va, mais sprintf par exemple n'est pas épargné (il y a snprintf, mais ce n'est pas sprintf).

    Citation Envoyé par Melem
    Le risque du buffer overflow face à un utilisateur mal intentionné se situe au niveau des entrées, pas dans les entrailles du programme. Dans un programme bien conçu il n'y a aucun risque d'un tel danger même en utilisant strcpy ou memcpy etc.
    ...
    Et enfin, si tu veux des fonctions "sécurisées" tu n'as qu'à implémenter les tiennes. Mais jusqu'où va cette sécurité en fait? Si le programme est bien écrit, il n'y a pas vraiment de différence à utiliser memcpy ou memcpy_s ...
    L'interêt d'utiliser les fonctions sécurisées de Microsoft ne se joue pas eulement au niveau du contrôle de la taille du buffer de destination, la société ayant déjà avancé ses explications (Security Enhancements in the CRT), je ne vois aucun interêt de le refaire.

  4. #24
    Expert éminent sénior

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 603
    Détails du profil
    Informations personnelles :
    Âge : 66
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 603
    Points : 17 913
    Points
    17 913
    Billets dans le blog
    2
    Par défaut
    en bref, sur un forum consacré au C, tu conseilles de faire comme pour Java et comme pour HTML : transformer quelque chose de standard en quelque chose de uniquement M$-compatible...

    Bravo .. ça j'appelle ça de l'ouverture d'esprit !!

    Et je répéterais que je ne comprends pas le problème : si on sait ce qu'on fait, ça ne plante JAMAIS.
    "Un homme sage ne croit que la moitié de ce qu’il lit. Plus sage encore, il sait laquelle".

    Consultant indépendant.
    Architecture systèmes complexes. Programmation grosses applications critiques. Ergonomie.
    C, Fortran, XWindow/Motif, Java

    Je ne réponds pas aux MP techniques

  5. #25
    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
    Citation Envoyé par Melem Voir le message
    L'interêt d'utiliser les fonctions sécurisées de Microsoft ne se joue pas eulement au niveau du contrôle de la taille du buffer de destination, la société ayant déjà avancé ses explications (Security Enhancements in the CRT), je ne vois aucun interêt de le refaire.
    Bulls**t pour la plupart des explications, car les fonctions sans "_s" valident également leurs paramètres un minimum, et le coup des errno pour fopen_s() par exemple ne tient pas la route contre la perte de portabilité.

    Edit: Voir aussi: http://blogs.msdn.com/vcblog/archive...rd-update.aspx. Surtout les commentaires.
    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.

  6. #26
    Membre à l'essai
    Inscrit en
    Novembre 2004
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Novembre 2004
    Messages : 27
    Points : 16
    Points
    16
    Par défaut
    Merci pour le lien..très intéressant.

    Sinon le problèmes des fonctions en _s ne relèvent pas justement que de Windows, l'ISO a sorti un document normalisant ce genre de fonction (ISO/IEC WDTR 24731 [URL="http://www.open-std.org/jtc1/sc22/wg14/www/docs/n1124.pdf"[/URL]), il reste à savoir si les autres compilateurs seront tenus à suivre ce nouveau "standard"...Je suis tout à fait d'accord qu'un code bien fait résout empêche tout problème mais s'il faudra utiliser ces fonctions standardisées pourquoi pas?
    Citation Envoyé par Médinoc Voir le message
    Bulls**t pour la plupart des explications, car les fonctions sans "_s" valident également leurs paramètres un minimum, et le coup des errno pour fopen_s() par exemple ne tient pas la route contre la perte de portabilité.

    Edit: Voir aussi: http://blogs.msdn.com/vcblog/archive...rd-update.aspx. Surtout les commentaires.

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

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut
    Citation Envoyé par kakibend Voir le message
    Sinon le problèmes des fonctions en _s ne relèvent pas justement que de Windows, l'ISO a sorti un document normalisant ce genre de fonction (ISO/IEC WDTR 24731 [URL="http://www.open-std.org/jtc1/sc22/wg14/www/docs/n1124.pdf"[/URL]),
    Non, pas de chance, c'est pas dans n1124, ça se saurait !
    Pas de Wi-Fi à la maison : CPL

  8. #28
    Expert éminent
    Avatar de Melem
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2006
    Messages
    3 656
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Janvier 2006
    Messages : 3 656
    Points : 8 389
    Points
    8 389
    Par défaut
    Ouais il s'est trompé de lien. C'est plutôt le 1135, pas le 1124. Mais c'est qu'un Technical Report, suite à la demande de Microsoft de normaliser ces fonctions paraît-il?

Discussions similaires

  1. Réponses: 30
    Dernier message: 27/03/2008, 15h02
  2. Appel fonction via un string
    Par Veovis dans le forum C++
    Réponses: 17
    Dernier message: 06/02/2007, 09h45
  3. Fonction renvoyant une string
    Par salseropom dans le forum C
    Réponses: 8
    Dernier message: 04/05/2006, 11h44
  4. fonction manipulant une string
    Par salseropom dans le forum C
    Réponses: 16
    Dernier message: 21/02/2006, 13h18
  5. [C#] Fonction pour convertir string[] vers ArrayList
    Par luimême dans le forum Windows Forms
    Réponses: 6
    Dernier message: 07/04/2005, 13h25

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