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.
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
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.