CONNEXION
  • RetourJeux
    • Tests
    • Soluces
    • Previews
    • Sorties
    • Hit Parade
    • Les + attendus
    • Tous les Jeux
  • RetourActu
    • Culture Geek
    • Astuces
    • Réalité Virtuelle
    • Rétrogaming
    • Toutes les actus
  • RetourHigh-Tech
    • Actus JVTECH
    • Bons plans
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTECH
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch
    • Xbox Series
    • Overwatch 2
    • FUT 23
    • League of Legends
    • Genshin Impact
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • PS4
  • One
  • Switch
  • Wii U
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Etoile Abonnement RSS

Sujet : [ASM] NOT == x ^= -1

DébutPage précedente
1
Page suivantePage suivante
drakenlorde drakenlorde
MP
Niveau 9
03 février 2016 à 22:43:07

Sur wikipedia, l'instruction NOT à comme note : x ^= -1. (https://en.wikipedia.org/wiki/X86_instruction_listings)
Si ^ est l'opérateur pour XOR, quel est le lien entre une opération logique NOT et x XOR -1 ? (d'après mes tests, XOR -1 n'est pas équivalent à une opération NOT)
Est-ce une erreur de wikipedia?

KheySurWallah KheySurWallah
MP
Niveau 6
03 février 2016 à 22:56:10

En complément à deux -1 s'écrit comme le chiffre qui ne contient que des 1.
Hors 0 xor 1 = 1 et 1 xor 1 = 0.

Donc si a est un bit faire x xor 1 revient à faire non a.

Si tu fais ça pour tous les bits du nombre tu obtiens sa négation, et c'est exactement ce que fais quand tu fais x xor -1 si -1 est représenté en CA2

KheySurWallah KheySurWallah
MP
Niveau 6
03 février 2016 à 22:56:45

-1 s'écrit comme le nombre*

drakenlorde drakenlorde
MP
Niveau 9
03 février 2016 à 23:50:06

Ah je vois. Est-ce que c'est utilisé pour simplement faire la démonstration du résultat d'un NOT ou c'est ce que l'rodinateur fait en réalité?

Pseudo supprimé
Niveau 7
03 février 2016 à 23:53:09

Je savais point. Le résultat se vérifie facilement sur ce site en mettant n'importe quel chiffre dans la premiere et -1 dans la seconde puis en cliquant sur not ~ et sur ^ xor

http://www.convertalot.com/bitwise_operators.html

Pseudo supprimé
Niveau 7
03 février 2016 à 23:56:18

Le 03 février 2016 à 23:50:06 drakenlorde a écrit :
Ah je vois. Est-ce que c'est utilisé pour simplement faire la démonstration du résultat d'un NOT ou c'est ce que l'rodinateur fait en réalité?

A priori je dirais non, c'est juste un cas parmis des milliards, ca doit pas etre interessant de consommer des cycles processeur juste pour un test qui se produira rarement.

drakenlorde drakenlorde
MP
Niveau 9
03 février 2016 à 23:59:38

Je me pose la question puisque l'example wikipedia montre x ^= -1, alors pourquoi pas simplement x = !x ? Si c'est le NOT est une opération de base, pourquoi la remplacer par une autre?

Pseudo supprimé
Niveau 7
04 février 2016 à 00:09:16

C'est pour la pignolle académique je pense

KheySurWallah KheySurWallah
MP
Niveau 6
04 février 2016 à 00:15:17

C'est une facon équivalente de l'écrire c'est tout. Mais apparement la vitesse d'exécution de notre et xor est la même sur la plupart des cpu x86 http://gmplib.org/~tege/x86-timing.pdf

KheySurWallah KheySurWallah
MP
Niveau 6
04 février 2016 à 00:17:49

Quoique les coûts sont donnés dans le pire cas donc y a ptet une difference

drakenlorde drakenlorde
MP
Niveau 9
04 février 2016 à 00:35:42

Ce que je n'aime pas de cette comparaison c'est que la valeur -1 doit être mise en place avant d'utiliser le xor.

x ^= -1 :

xor y,y
dec  y
xor x,y

!x :

not x
DébutPage précedente
1
Page suivantePage suivante
Répondre
Prévisu
?
Victime de harcèlement en ligne : comment réagir ?
Infos 0 connecté(s)

Gestion du forum

Modérateurs : godrik, LGV
Contacter les modérateurs - Règles du forum

Sujets à ne pas manquer

La vidéo du moment