猜猜 JavaScript 输出:(! + [] + [] + ![]).length

news2024/11/18 9:30:27

一起猜

最近看到一个很有意思的题,直接来看,下面这段代码的打印结果是什么?

console.log((! + [] + [] + ![]).length)

猜猜看,你的答案是什么,打在评论区。


我的答案是 undefined,正如我的英文名

image.png

为什么呢?因为我第一眼看到题目,只想到了 ![] 的结果是 false

而前面! + [] + []的逻辑没想明白,但是我估计得出的应该也是个布尔值

两个布尔值相加,最后还是个布尔值

布尔值取 length,应该是返回undefined

揭晓答案

但是在控制台运行后我人傻了,答案是 9 !!!

看到结果第一时间我还以为是全当字符串拼接起来了,但是一数,全拆开也是8个字符串啊。然后分析了下。

一步一步来看。

首先 + 加法操作符是从左到右计算的,所以不能自己想当然的给公式加上无形的“括号”。

所以应该一个值一个值来加。首先是! + []

! 是逻辑非操作符。可以用于 js 中的任何值,逻辑非操作符首先会将操作数转化为布尔值,然后在对其取反。

然后我又蒙住了,我知道 !值 的写法可以转 boolean,难道! + 值的写法也能隐式转换成布尔?

但是想不通其中的逻辑。

突然我幡然醒悟,应该把! + []拆解成 !+ [],把+[]当作值,那+ []是什么呢?

一元正号运算符位于其操作数前面,计算其操作数的数值,如果操作数不是一个数值,会尝试将其转换成一个数值。

任何值前面加上+加号操作符都会隐式转换成数值,如果解析失败,则转换结果为 NaN。

+'123'    //123
+'abin'   //NaN
+3        //3
+true     //1
+false    //0
+null     //0
+[]       //0
+undefined //NaN
+function(){} //NaN
+new Date()  //1695781396548  对应的毫秒数

这下是不是就能看通了,+ []的值为 0,

原式就相当于!0 + [] + ![] => true + [] + false

因为加法操作符如果两边都不是数字/字符串的时候会强制把操作值转换成字符串/数字,优先转换字符串,

所以true + [] + false => 'true' + [].toString() + false

现在题目就很简单了,

[].toString()的结果是空字符串,

所以'true' + [].toString() + false => 'true' + '' + false

最后得出结论

('true' + '' + false).length => 'truefalse'.length

答案是 9 !!!

你猜对了吗😜😜😜

说在最后

这种题目看着很怪,其实你只要不盲目的随意拆解题干,按照正常计算思路往下捋,就能捋出答案(马后炮🤪)

这道题的核心关键点有以下几点:

  • 加法运算符一定要从左到右看
  • !非运算符单独使用没有效果,所以会将 +[] 看作整体
  • +操作数 一元正号加上操作数会将操作数强制转换为数字

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1066438.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

开放式耳机的品牌有哪些?OWS不入耳开放式耳机品牌分享

开放式耳机是一种创新型的音频设备,与传统耳机相比,它有许多独特的优势。首先,开放式耳机不需要堵住耳道,因此长时间佩戴不会对听力造成损害,这是其最显著的优势之一。此外,它不需要深入入耳,因…

优化一对一直播实时美颜SDK性能的实践

在当今数字化社交的时代,直播已经成为人们分享自己生活、才艺和经验的重要方式之一。与此同时,美颜功能也逐渐成为许多直播平台的标配。用户期望通过直播过程中的美颜效果来展现最佳状态,这使得实时直播美颜SDK的性能优化变得尤为重要。本文将…

vite 项目改了node_modules下的代码不生效

解决办法:删除.vite文件,重新跑项目,或者跑项目的时候加上--force

java基础-第4章-面向对象(二)

一、static关键字 静态(static)可以修饰属性和方法。 称为静态属性(类属性)、静态方法(类方法)。 静态成员是全类所有对象共享的成员。 在全类中只有一份,不因创建多个对象而产生多份。 不必创…

使用tailwindcss来构建以及引入外部组件

使用tailwindcss来构建以及引入外部组件 使用tailwindcss来构建以及引入外部组件 前言构建组件 核心思想可行方案不可行方案 可行方案详解 custom css selector Functions & Directivesadd prefixadd scoped不打包 构建demo链接相关issues 前言 我们在日常的开发中&am…

cv2.split函数与cv2.merge函数

split函数用于图像BGR通道的分离 merge函数用于可将分开的图像通道合并到一起 1.split函数的使用 这是原图,我们使用split函数对其三个通道进行分离。 注意:split函数分离通道的顺序是B、G、R。 以下方法是将三个通道的值都设置为与某一个通道相同。…

AI工程化—— 如何让AI在企业多快好省的落地?

文章目录 前言内容简介读者对象专家推荐目录赠书活动 前言 作为计算机科学的一个重要领域,机器学习也是目前人工智能领域非常活跃的分支之一。机器学习通过分析海量数据、总结规律,帮助人们解决众多实际问题。随着机器学习技术的发展,越来越多…

asp.net+mvc+三层架构core企业员工考勤签到系统 mysql办公设备借用管理系统vue

系统中的核心员工是系统管理员,管理员登录后,通过管理员菜单来管理后台系统。主要功能有:管理员:个人中心、员工信息管理、留言板管理、系统管理、签到平台管理、签到信息管理、请假平台管理、办公设备管理、设备申请信息管理、请…

Flutter开发笔记 —— 语音消息功能实现

前言 最近在开发一款即时通讯(IM)的聊天App,在实现语音消息功能模块后,写下该文章以做记录。 注:本文不提供相关图片资源以及IM聊天中具体实现代码,单论语音功能实现思路 需求分析 比起上来直接贴代码,我们先来逐步…

day10_复习_数组_方法

非常重要的: 方法设计(参数,返回值,调用) 数组也重要,但是后续很少用! 是因为后期有更简单的【集合】,重要在于是一种思想,也是一种代码逻辑 关于数组: 声明创建取值,存值遍历面试|算法 --> 排序内存图(堆,栈,引用) 今天 数组工具类:Arrays数组扩容(拷…

Linux服务器报错“No space left on device”如何解决

一、错误的含义,说明在服务器设备上的存储空间已经满了,不能再上传或者新建文件夹或者文件等。 二、确认查看服务器系统的磁盘使用情况是否是真的已经没有剩余空间,复制下面命令在服务器上运行,然后发现如果如下图所示那么表明sda…

Unsafe概述

前言 ​ 如果看过Java并发包里面的源码、或者netty网络通讯相关源码,就会到Unsafe类有一定的了解。这个与其的特性有关。 介绍 ​ **Unsafe是位于sun.misc包下的一个类,主要提供一些用于执行低级别、不安全操作的方法,如直接访问系统内存资…

《DevOps 精要:业务视角》- 读书笔记(三)

DevOps 精要:业务视角(三) 第3章 原则3.1 价值流3.2 部署流水线3.3 一切都应存储在版本控制系统中3.4 自动化配置管理3.5 完成的定义3.6 小结 第3章 原则 将原则从实践中分离出来,这是一种很有用的做法。当然了,这两个词分别有着…

CCF中国开源大会专访|毛晓光:“联合”是开源走向“共赢”的必由之路

受访嘉宾 | 毛晓光 记者 | 朱珂欣 2023 CCF 中国开源大会( CCF ChinaOSC )拟于 2023 年 10 月 21 日至 22 日在湖南省长沙市北辰国际会议中心召开。 作为第二届 CCF 中国开源大会,本届大会将组织特邀报告、高峰论坛和领域分论坛等不同类…

防御安全第四次作业

1. 什么是APT? APT全称:Advanced Persistent Threat 高级可持续威胁攻击。 指的是某组织对特定对象展开持续有效的攻击活动。 这种攻击活动具有极强的隐蔽性和针对性,通常会运用受感染的各种介质,供应链和社会工程学等手段&#x…

Kafka 架构

正文 一、Kafka的架构 如上图所示,一个典型的Kafka集群中包含若干Producer(可以是web前端产生的Page View,或者是服务器日志,系统CPU、Memory等),若干broker(Kafka支持水平扩展,一般…

解决 Jenkins 性能缓慢的问题~转

解决 Jenkins 性能缓慢的问题 Docker中文社区 ​​ 计算机技术与软件专业技术资格持证人 2 人赞同了该文章 没有什么比缓慢的持续集成系统更令人沮丧的了。它减慢了反馈循环并阻止代码快速投入生产。虽然像使用性能更好的服务器可以为您争取时间,但您最终必须投资…

AdaBoost(上):数据分析 | 数据挖掘 | 十大算法之一

⭐️⭐️⭐️⭐️⭐️欢迎来到我的博客⭐️⭐️⭐️⭐️⭐️ 🐴作者:秋无之地 🐴简介:CSDN爬虫、后端、大数据领域创作者。目前从事python爬虫、后端和大数据等相关工作,主要擅长领域有:爬虫、后端、大数据…

张量-复数操作函数

tf.complex(real,imag,name None),该函数用于将两实数转化为复数。 示例代码如下: import tensorflow.compat.v1 as tf tf.disable_v2_behavior()real tf.constant([2.25,3.25],dtype tf.float64) imag tf.constant([4.75,5.75],dtype tf.float64)with tf.Session() as …

Bigemap中如何添加21级的影像图

工具 Bigemap gis office地图软件 BIGEMAP GIS Office-全能版 Bigemap APP_卫星地图APP_高清卫星地图APP 很多人在咨询如何查看21级的影像图 这里先来说一下影像的像素分辨率,一般17级是1米的、18级是0.5米、19级是0.25米以此类推,咱们国家测绘要求允…