Rumah >hujung hadapan web >tutorial js >Penjelasan terperinci tentang operator javascript '!~'_Pengetahuan asas

Penjelasan terperinci tentang operator javascript '!~'_Pengetahuan asas

WBOY
WBOYasal
2016-05-16 16:15:011492semak imbas

Hari ini hampir cuti Tahun Baru Cina, dan akhirnya saya bebas. Melayari pelbagai artikel teknikal setiap hari, negeri ini hebat.

Saya membaca artikel tentang js pada sebelah petang, dan perenggan berikut menarik perhatian saya.

Salin kod Kod adalah seperti berikut:

(fungsi () {
nama var = [];
Kembalikan fungsi (nama) {
          addName(nama);
}
Fungsi addName(nama) {
Jika (!~name.indexOf(name))//Jika ia wujud, jangan tambah
             names.push(name);
console.log(nama);// ["linkFly"]
}
}())('linkFly');

Apakah maksud operator "!~" in if (!~name.indexOf(name))? Jika anda tidak faham, mari mulakan dengan ~.

Ujian boleh menunjukkan bahawa nilai keputusan mempunyai corak ini - (X 1)

Selepas mencari, beberapa artikel hanya kehilangan satu ayat: menafikan digit binari

Secara literal, di sini ia dinyatakan dalam perduaan lapan digit: 3=00000011, kemudian ~3=11111100, adalah salah untuk menggunakan formula di atas.
Penjelasan di atas masih terlalu abstrak dan tidak konkrit. Malah, ini melibatkan pengetahuan kod asal, kod songsang dan kod pelengkap.

Kod asal
Bit tertinggi bagi perwakilan kod asal ialah bit tanda Bit ini adalah 0 untuk nombor positif dan 1 untuk nombor negatif. Bit yang tinggal mewakili nilai mutlak nombor itu.
Kod songsang
Untuk nombor yang ditandatangani, pelengkap satu nombor positif adalah sama dengan kod asalnya. Kod pelengkap sering digunakan sebagai bentuk perantaraan dalam proses mencari kod pelengkap.
Kod pelengkap
Pelengkap bagi nombor positif adalah sama dengan kod asalnya dan pelengkap bagi nombor negatif diperoleh dengan menyongsangkan semua bit kod asalnya kecuali bit tanda dan menambah 1 pada bit terakhir, iaitu pelengkap bagi nombor tambah 1. Nombor dalam komputer biasanya diwakili dalam bentuk pelengkap dua. Dalam kod pelengkap, (-128)D digunakan bukannya (-0)D Ambil perhatian bahawa: (-128)D tidak mempunyai kod asal yang sepadan dan kod pelengkap, (-128)D = (1000,0000)B.
Operasi pelengkap
Operasi pelengkap tidak mengambil kira bit tanda, ia diperoleh dengan menyongsangkan setiap bit kod asalnya dan menambah 1 pada bit terakhir. Pelengkap bagi suatu nombor ialah pelengkap bagi lawannya.

Ambil artikel pengarang sebagai contoh untuk memahami

~ bermaksud penafian bitwise bermaksud jika 00111, ia menjadi 11000 (penafian bitwise)

Perwakilan binari 57 ialah (1 bait): 00111001
Perwakilan binari selepas penolakan bitwise (~57): 11000110 Ini dinyatakan dalam perpuluhan: -70
Ini ialah nombor negatif, iaitu nombor negatif diwakili oleh pelengkapnya dalam komputer: pelengkap = selepas bit tanda, penyongsangan bit ditambah dan 1 ditambah Oleh itu, selepas bit tanda bagi -70 (11000110) disongsangkan bitwise, ia adalah (10111001), dan menambah 1 ialah (10111010)
Tukar kepada perpuluhan:-58
Oleh itu~57=-58

Kini saya akhirnya memahaminya. Walaupun formula yang diringkaskan boleh menghasilkan hasil dengan cepat, ia tidak dapat menjelaskan sebabnya sebagai orang teknikal, kami ingin menyelidiki butirannya.

Masa mengeluh:

Asas adalah asas segala-galanya di atas Jika anda mengabdikan diri untuk memupuk Tao, jalannya akan menjadi panjang.

Di atas adalah keseluruhan kandungan artikel ini, saya harap anda boleh mendapat sesuatu daripadanya.

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn