你还不知道~~这个是什么意思吗,还以为是作者写错了

news/2025/1/13 2:49:26/

文章目录

  • 前言
  • 一、来个例子
  • 二、按位非~
  • 三、小知识


前言

主要是来学习一下js中运算符的相关的知识


一、来个例子

~~(Math.random() * 10)

看起来像是要获取随机数的。
我们先把括号内的东西粘到控制台看看:

结果:
(Math.random() * 10)
//4.47062635057776
(Math.random() * 10)
//9.485037450706146
(Math.random() * 10)
//1.0411424656363288
(Math.random() * 10)
//5.207778723704015
(Math.random() * 10)
//3.1793270193668133

整体看看结果:
确实是用来获取0到10以内的随机数的

~~(Math.random() * 10)
//5
~~(Math.random() * 10)
//1
~~(Math.random() * 10)
//7
~~(Math.random() * 10)
//6
~~(Math.random() * 10)
//8
~~(Math.random() * 10)
//7
~~(Math.random() * 10)
//1

但是具体的作用是什么呢,还是得到mdn看看。但是并没有搜索到相关符号,只看到了单个的运算符~

二、按位非~

按位非运算符(~)将操作数的位反转。如同其他位运算符一样,它将操作数转化为 32 位的有符号整型。

什么是有符号整型数看这里—>

看看mdn上面提供的例子:

const a = 5;     // 00000000000000000000000000000101
const b = -3;    // 11111111111111111111111111111101console.log(~a); // 11111111111111111111111111111010
// Expected output: -6console.log(~b); // 00000000000000000000000000000010
// Expected output: 2

所以能够理解两次取反的意思就是还是原值,但是为什么后面的小数没有了呢。

JavaScript中的浮点数采用的是双精度浮点数类型,即64位的Double类型来表示。IEEE 754标准定义了浮点数二进制表示的规范
按位取反操作符"~~"在转换浮点数时会一次性移除小数部分并通过对整数部分取反、加1来得到整数形式的方法。


三、小知识

字符串转为数字的方法:

const [a, b, c, d, e, f, g, h] = ['1', '2', '3', '4', '5', '6', '7', '8']
console.log(typeof (a - 0), (a - 0))
console.log(typeof parseInt(b), parseInt(b))
console.log(typeof parseFloat(b), parseFloat(b))
console.log(typeof ~~c, ~~c)
console.log(typeof +d, +d)
console.log(typeof Number(e), Number(e))
console.log(typeof Math.floor(f), Math.floor(f))
console.log(typeof Math.round(g), Math.round(g))
console.log(typeof eval(h), eval(h))

结果
在这里插入图片描述


http://www.ppmy.cn/news/85103.html

相关文章

80.确定和规划项目(步骤1和2)

你的第一个现实世界的项目 ● 你的第一份“工作”!、 ● 你受雇为一家名为Omnifood的虚构公司设计并建立一个网站。 ● Omnifood是一家使用人工智能来创建和提供定制健康膳食计划的初创公司。 ● 他们为我们提供了网站的所有内容(content.md&#xff09…

微前端乾坤

1. 乾坤 简介 qiankun 是一个基于 single-spa 的微前端实现库,旨在帮助大家能更简单、无痛的构建一个生产可用微前端架构系统 官网:https://qiankun.umijs.org/zh/guide 2.使用 背景: vue2.0 , vue-cli 5.0 主应用: 安装乾坤…

leetcode 29.两数相除

题目链接:leetcode 29 1.题目 给你两个整数,被除数 dividend 和除数 divisor。将两数相除,要求 不使用 乘法、除法和取余运算。 整数除法应该向零截断,也就是截去(truncate)其小数部分。例如&#xff0c…

数字孪生智慧路灯可视化系统 区域控制节能增效

前言 智慧灯杆是智慧城市建设的重要组成部分,可以完成照明、公安、市政、气象、环保、通信等行业数据信息的采集、发布和传输。同时,作为5g时代车联网、云网、通信网络建设的重要组成部分,智慧灯杆也将得到广泛应用。 建设背景 城市路灯存…

前端小工具:批量修改图片信息

前端小工具一:批量修改文件夹里面的图片名称 步骤: 1.安装nodejs。 2.根据需要修改editFileName(filePath, formatName)函数的参数,也可以不改,直接将renameFile.js和img文件夹放在同一个目录下。 3.在renameFile.js目录下开启…

网安面试只要掌握这十点技巧,绝对轻轻松松吊打面试官

结合工作经验,在这里笔者给企业网管员提供一些保障企业网络安全的建议,帮助他们用以抵御网络入侵、恶意软件和垃圾邮件。 定义用户完成相关任务的恰当权限 拥有管理员权限的用户也就拥有执行破坏系统的活动能力,例如: ・偶然对系…

Android 14 又来了?别扶!抬起我来吧!

Android 14 又来了?别扶!抬起我来吧! 大家好,好久不见,从去年底写完年终总结之后就再也没有更新过文章,之前最多也就间隔一两个月时间,但这回间隔时间确实有点长,基本快半年了&…

阿里云手动创建Nginx-Ingress

阿里云相关文档 1、在ACK管理控制台点击如下 应用市场–>筛选(以ack-ingress-nginx-v1为例)–>点击安装–>一键部署–>自己定义集群、命名空间以及ingress名称 1.20以下集群选中ack-ingress-nginx。 1.20及以上集群选中ack-ingress-nginx-v1。 应用市场 筛选…