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 :

explication sur opérateur <<


Sujet :

C

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Mai 2002
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2002
    Messages : 12
    Points : 2
    Points
    2
    Par défaut explication sur opérateur <<
    Merci de m'éclairer

    UCSR0A &= ~(1 << U2X0);
    Le commentaire de ce code dit que le bit U2X0 du registre UCSR0A est mis à zéro....
    Bon '&=' ça va, je maîtrise mais ~(1<<U2XO) je vois pas et j'aimerai que l'on m'explique.

    s'il vous plaît

    Alain

  2. #2
    Membre expérimenté Avatar de Trademark
    Profil pro
    Inscrit en
    Février 2009
    Messages
    762
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2009
    Messages : 762
    Points : 1 396
    Points
    1 396
    Par défaut
    Salut,

    d'après ce que je comprend, la variable U2X0 contient la position du bit U2X0.

    Alors par exemple, soit une séquence de 4 bits à 0.

    ( 1 << U2X0)
    0001 << 0 = 0001
    0001 << 1 = 0010
    0001 << 2 = 0100
    0001 << 3 = 1000

    On "déplace" tous les bits grâce à une rotation vers la gauche de X bits.

    La deuxième étape est de prendre la négation :

    soit on imagine le troisième exemple qui donne 0100 :

    ~(0100) = 1011

    Et ensuite, grâce à l'opération "&", le troisième bit sera mis à zéro ! (Car 1 & 0 = 0 et 0 & 0 = 0). Les autres bits ne changent pas, car 1 & 1 = 1 et 0 & 1 = 0.

  3. #3
    Expert éminent sénior
    Avatar de diogene
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Juin 2005
    Messages
    5 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 761
    Points : 13 926
    Points
    13 926
    Par défaut
    @Trademark
    On "déplace" tous les bits grâce à une rotation vers la gauche de X bits.
    Pour préciser, ce n'est pas une rotation, mais une translation ou un décalage (le bit de poids fort ne va pas dans le bit de poids faible) .

    A noter que le résultat de a<<N n'est pas défini en terme de la position des bits mais de façon arithmétique : il est défini comme le résultat de la multiplication de a par 2^N.
    a doit être unsigned ou non négatif (pour que la représentation du nombre soit bien définie) et le résultat doit être représentable dans le type du résultat, sinon le comportement est indéfini.
    Publication : Concepts en C

    Mon avatar : Glenn Gould

    --------------------------------------------------------------------------
    Une réponse vous a été utile ? Remerciez son auteur en cliquant le pouce vert !

Discussions similaires

  1. [Multimédia] Explication sur stream audio
    Par champion dans le forum Développement
    Réponses: 1
    Dernier message: 20/01/2005, 12h14
  2. Besoin d'explications sur float et l'élasticité !
    Par KneXtasY dans le forum Mise en page CSS
    Réponses: 2
    Dernier message: 14/01/2005, 15h15
  3. s.v.p :explication sur le ".h" et dll de l'opengl
    Par Asmod_D dans le forum OpenGL
    Réponses: 1
    Dernier message: 22/11/2004, 10h32
  4. Réponses: 28
    Dernier message: 18/08/2003, 11h54
  5. recherches des cours ou des explications sur les algorithmes
    Par Marcus2211 dans le forum Algorithmes et structures de données
    Réponses: 6
    Dernier message: 19/05/2002, 22h18

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