Maison >interface Web >js tutoriel >Explication détaillée de l'opérateur javascript '!~'_Connaissances de base

Explication détaillée de l'opérateur javascript '!~'_Connaissances de base

WBOY
WBOYoriginal
2016-05-16 16:15:011492parcourir

C'est presque les vacances du Nouvel An chinois et je suis enfin libre. En parcourant quotidiennement divers articles techniques, cet état est formidable.

J'ai lu un article sur js dans l'après-midi, et le paragraphe suivant a retenu mon attention.

Copier le code Le code est le suivant :

(fonction () {
noms de var = [];
Fonction de retour (nom) {
          addName(nom);
>
Fonction addName(nom) {
Si (!~names.indexOf(name))//S'il existe, n'ajoutez pas
             noms.push(nom);
console.log(noms);// ["linkFly"]
>
}())('linkFly');

Que signifie l'opérateur "!~" dans if (!~names.indexOf(name)) ? Si vous ne comprenez pas, commençons par ~.

Le test peut montrer que la valeur du résultat a ce modèle - (X 1)

Après recherche, certains articles n'ont perdu qu'une seule phrase : nier le chiffre binaire

Littéralement, ici il est exprimé en binaire à huit chiffres : 3=00000011, puis ~3=11111100, il est faux d'appliquer la formule ci-dessus.
L’explication ci-dessus est encore trop abstraite et peu concrète. En fait, cela implique la connaissance du code original, du code inverse et du code complémentaire.

Code d'origine
Le bit le plus élevé de la représentation du code d'origine est le bit de signe. Ce bit est 0 pour les nombres positifs et 1 pour les nombres négatifs. Les bits restants représentent la valeur absolue du nombre.
Code inversé
Pour un nombre signé, le complément à un d'un nombre positif est le même que son code d'origine ; le complément à un d'un nombre négatif est l'inversion au niveau du bit de tous les bits du code d'origine à l'exception du bit de signe. Le code complément est souvent utilisé comme forme intermédiaire dans le processus de recherche du code complément.
Code complémentaire
Le complément d'un nombre positif est le même que son code et son complément d'origine ; le complément d'un nombre négatif est obtenu en inversant tous les bits de son code d'origine sauf le bit de signe et en ajoutant 1 au dernier bit, qui est le complément du nombre plus 1. Les nombres dans les ordinateurs sont généralement représentés sous la forme d'un complément à deux. Dans le code complémentaire, (-128)D est utilisé à la place de (-0)D. Notez que : (-128)D n'a pas de code original correspondant ni de code complété, (-128)D = (1000,0000)B.
Opération complémentaire
L'opération complément ne prend pas en compte le bit de signe, elle est obtenue en inversant chaque bit de son code d'origine et en ajoutant 1 au dernier bit. Le complément d'un nombre est le complément de son contraire.

Prendre l'article de l'auteur comme exemple pour comprendre

~ signifie négation au niveau du bit. La négation signifie que si c'est 00111, il devient 11000 (négation au niveau du bit)

La représentation binaire de 57 est (1 octet) : 00111001
La représentation binaire après négation au niveau du bit (~57) : 11000110 Elle est exprimée en décimal : -70
Il s'agit d'un nombre négatif, qui est un nombre signé. Les nombres négatifs sont représentés par leur complément dans les ordinateurs : complément = après le bit de signe, l'inversion au niveau du bit est ajoutée et 1 est ajouté
. Par conséquent, une fois le bit de signe de -70 (11000110) inversé au niveau du bit, il s'agit de (10111001), et l'ajout de 1 est (10111010)
Convertir en décimal : -58
Donc~57=-58

Maintenant, je comprends enfin. Même si la formule résumée peut rapidement produire des résultats, elle ne peut pas expliquer pourquoi. En tant que techniciens, nous aimons approfondir les détails.

L'heure du soupir :

La fondation est la pierre angulaire de tout ce qui précède. Si vous vous consacrez à cultiver le Tao, le chemin sera long.

Ce qui précède représente l'intégralité du contenu de cet article, j'espère que vous pourrez en tirer quelque chose.

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn