Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >为什么不带参数的 Math.max() 返回-Infinity

为什么不带参数的 Math.max() 返回-Infinity

作者头像
前端小智@大迁世界
发布于 2022-06-15 07:27:55
发布于 2022-06-15 07:27:55
1.1K00
代码可运行
举报
文章被收录于专栏:终身学习者终身学习者
运行总次数:0
代码可运行

作者:Dmitri Pavlutin 译者:前端小智 来源:Dmitri Pavlutin

本文 GitHub https://github.com/qq449245884/xiaozhi 已收录,有一线大厂面试完整考点、资料以及我的系列文章。

Math.max() 是 JS 内置的方法,可以从传入的参数中,返回最大的一个。例如:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Math.max(1, 2, 3); // => 3

如果Math.max()只使用一个参数,结果是怎么样的?

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Math.max(1); // => 1

正如预期的那样,一个数字的最大值就是它本身。

但是,如果调用不带参数 Math.max() 结果又是怎么样的呢?

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Math.max(); // => -Infinity

不带参数的 Math.max() 返回的结果是 -Infinity,接下来,我们来看看为什么会这样。

一个数组中的最大值

在探讨这个问题之前,我们先来 Math.max()是如何从数组中得到最大值的。

Math.max(num1, num2, ..., numN)接受多个数字参数,并返回它们的最大数量。

如果想从数组中获取最大值,我们可以使用展开运算符:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
const numbers1 = [1, 2, 3];

Math.max(...numbers1); // => 3

2. 两个数组中的最大值

现在,我们来看看有趣的事情,给定两个数组,我们先确定每个数组中的最大值,然后在从获取这两个最大值在确定出其中的最大值。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
const numbers1 = [1, 2, 3];
const numbers2 = [0, 6];

const max1 = Math.max(...numbers1);
const max2 = Math.max(...numbers2);

max1; // 3
max2; // 6
Math.max(max1, max2); // => 6

数组 [1, 2, 3] 最大值是 3,数组 [0, 6]大最值是 6,最后 3 和 6 的最大值是 6.

没毛病,我们继续。

如果一个数组是空的,结果又会是怎么样的, 我们动手试试:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
const numbers1 = [];
const numbers2 = [0, 6];

const max1 = Math.max(...numbers1);
const max2 = Math.max(...numbers2);

max1; // -Infinity
max2; // 6
Math.max(max1, max2); // => 6

现在,当第一个数组为空时,上面的最大值也是 6

这里比较有趣的是Math.max(...numbers1)的返回值,当numbers1数组为空时,这与调用不带参数的Math.max()相同,结果是 -Infinity

所以 Math.max(max1,max2) 等价于 Math.max(-Infinity, 6),结果为6。

现在就知道为什么Math.max()在不带参数的情况下调用时返回-Infinity:这是在一个空集合上定义max函数的一种方式。

这与加法类似,max的-Infinity和加法的0是一样的。

Math.min()也具有相同的行为-当不带参数调用时,它将返回Infinity

关于对实数的最大运算,-Infinity称为Identity元素

到这里本文就完啦,这里来个挑战:你能否编写一个与Math.max()完全一样的 sum(num1, num2, ..., numN)函数,它的功能就是求所有元素的和,

Identity元素是什么,有懂的没,欢迎留言补充一下知识点。


代码部署后可能存在的BUG没法实时知道,事后为了解决这些BUG,花了大量的时间进行log 调试,这边顺便给大家推荐一个好用的BUG监控工具 Fundebug

原文:https://dmitripavlun.com/javs...

交流

本文 GitHub https://github.com/qq44924588... 已收录,有一线大厂面试完整考点、资料以及我的系列文章。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-06-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Canal数据同步工具
​ Canal就是一个很好的数据库同步工具。canal是阿里巴巴旗下的一款开源项目,纯Java开发。基于数据库增量日志解析,提供增量数据订阅&消费,目前主要支持了MySQL。
OY
2022/03/18
1.7K0
Canal数据同步工具
Canal实现MySQL数据实时同步
canal [kə’næl],译意为水道/管道/沟渠,主要用途是基于 MySQL 数据库增量日志解析,提供增量数据订阅和消费
别团等shy哥发育
2023/02/25
3.2K0
Canal实现MySQL数据实时同步
阿里Canal框架(数据同步中间件)初步实践
早期,阿里巴巴B2B公司因为存在杭州和美国双机房部署,存在跨机房同步的业务需求。不过早期的数据库同步业务,主要是基于trigger的方式获取增量变更,不过从2010年开始,阿里系公司开始逐步的尝试基于数据库的日志解析,获取增量变更进行同步,由此衍生出了增量订阅&消费的业务,从此开启了一段新纪元。
java架构师
2019/05/15
1.2K0
Canal入门
早期,阿里巴巴B2B公司因为存在杭州和美国双机房部署,存在跨机房同步的业务需求。不过早期的数据库同步业务,主要是基于trigger的方式获取增量变更,不过从2010年开始,阿里系公司开始逐步的尝试基于数据库的日志解析,获取增量变更进行同步,由此衍生出了增量订阅&消费的业务,从此开启了一段新纪元。
王知无-import_bigdata
2019/10/15
1.2K0
Canal入门
使用TCP方式拉取Canal数据
canal.mq.dynamicTopic 是 Canal 的 MQ 动态 Topic 配置项:
JavaEdge
2023/09/12
3640
使用TCP方式拉取Canal数据
Docker安装canal、mysql进行简单测试与实现redis和mysql缓存一致性
canal [kə'næl],译意为水道/管道/沟渠,主要用途是基于 MySQL 数据库增量日志解析,提供增量数据订阅和消费。 早期阿里巴巴因为杭州和美国双机房部署,存在跨机房同步的业务需求,实现方式主要是基于业务 trigger 获取增量变更。从 2010 年开始,业务逐步尝试数据库日志解析获取增量变更进行同步,由此衍生出了大量的数据库增量订阅和消费业务。
掉发的小王
2022/07/11
9450
Docker安装canal、mysql进行简单测试与实现redis和mysql缓存一致性
SpringBoot系列之集成阿里canal监听MySQL Binlog
canal是阿里开源的, 对数据库增量日志解析,提供增量数据订阅和消费的组件。引用官网的图片,canal的工作原理主要是模拟 MySQL slave 的交互协议,伪装自己为 MySQL slave,向master发送dump 协议,获取到数据后,解析 binary log 对象数据。
SmileNicky
2022/01/04
1.6K0
SpringBoot系列之集成阿里canal监听MySQL Binlog
Canal 原理与实践
canal [kə'næl],译意为水道/管道/沟渠,主要用途是基于 MySQL 数据库增量日志解析,提供增量数据订阅和消费,不支持全量已有数据同步。由于采用了 binlog 机制,Mysql 中的新增、更新、删除操作,对应的 Elasticsearch都能实时新增、更新、删除。
Se7en258
2021/05/18
1.1K0
Canal 原理与实践
Mysql binlog 之阿里canal 1、What is Canal?2、工作原理3、Canal使用场景代码集成方式:
canal [kə'næl],中文翻译为 水道/管道/沟渠/运河,主要用途是用于 MySQL 数据库增量日志数据的订阅、消费和解析,是阿里巴巴开发并开源的,采用Java语言开发;
用户5927264
2020/12/01
1.2K0
Mysql binlog 之阿里canal 1、What is Canal?2、工作原理3、Canal使用场景代码集成方式:
lua + OpenResty + Canal 场景应用开发
而对于首页这种,高访问,且 页面数据并不是,经常的变化! 为了减轻服务器的压力,直接将其制作成一个 静态的页面进行展示!
Java_慈祥
2024/08/06
1560
lua + OpenResty + Canal 场景应用开发
canal,真香!
在当今互联网行业尤其是现在分布式、微服务开发环境下,为了提高搜索效率,以及搜索的精准度,会大量使用Redis、Memcached等NoSQL数据库,也会使用大量的Solr、Elasticsearch等全文检索服务和搜索引擎。
苏三说技术
2025/02/10
750
canal,真香!
使用canal-deployer实现mysql数据同步
在shigen之前的文章当中,苦于mysql和elasticsearch之间的数据同步问题,甚至尝试开源一款mysql-es数据同步工具 - 掘金。觉得可以自己去实现这些同步。但是遇到了的问题也很多:
shigen
2024/01/10
3010
使用canal-deployer实现mysql数据同步
【Canal】数据同步的终极解决方案,阿里巴巴开源的Canal框架当之无愧!!
作者个人研发的在高并发场景下,提供的简单、稳定、可扩展的延迟消息队列框架,具有精准的定时任务和延迟队列处理功能。自开源半年多以来,已成功为十几家中小型企业提供了精准定时调度方案,经受住了生产环境的考验。为使更多童鞋受益,现给出开源框架地址:
冰河
2020/10/29
1.4K0
【Canal】数据同步的终极解决方案,阿里巴巴开源的Canal框架当之无愧!!
一文带你快速入门Canal,看这篇就够了!
我们在做实时数仓时数据往往都是保存到数据库中例如MySQL,当有一条数据新增或修改需要马上将数据同步到kafka中或其他的数据库中,这时候我们需要借助阿里开源出来的Canal,来实现我们功能。
大数据老哥
2021/02/04
1.2K0
一文带你快速入门Canal,看这篇就够了!
原来Canal也可以做HA?
在做实时数仓时,数据量往往比较大的,如果使用Canal来监听MySQL的状态当Canal 是单节服务时,服务器挂掉是就会造成数据丢失,这时Canal恰好可以配置HA这样就能解决单点问题,但是依赖于zookeeper,那我们就来配置一下Canal的HA。
大数据老哥
2021/02/04
7930
原来Canal也可以做HA?
手摸手实现Canal如何接入MySQL实现数据写操作监听
🍁 作者:知识浅谈,CSDN签约讲师,CSDN原力作者,后端领域优质创作者,热爱分享创作 💒 公众号:知识浅谈 📌 擅长领域:全栈工程师、爬虫、ACM算法 Canal的使用分为两部分: 上部分为canal接入Mysql数据库进行操作监听。 下部分为Canal如何接入消息队列、Redis、Canal的高可用HA。 这次拿上部分来做正菜🛴🛴🛴 环境:linux 数据库主机(192.168.31.230) Canal server主机(192.168.31.231) 🎈安装MySQL
知识浅谈
2022/11/13
1.1K0
手摸手实现Canal如何接入MySQL实现数据写操作监听
2 监听mysql表内容变化,使用canal
mysql本身是支持主从的(master slave),原理就是master产生的binlog日志记录了所有的增删改语句,将binlog发送到slave节点进行执行即可完成数据的同步。
天涯泪小武
2019/01/17
6.8K0
SpringBoot系列之canal和kafka实现异步实时更新
canal是阿里开源的, 对数据库增量日志解析,提供增量数据订阅和消费的组件。引用官网的图片,canal的工作原理主要是模拟 MySQL slave 的交互协议,伪装自己为 MySQL slave,向master发送dump 协议,获取到数据后,解析 binary log 对象数据。
SmileNicky
2022/01/04
2K1
SpringBoot系列之canal和kafka实现异步实时更新
超详细canal入门,看这篇就够了
我们都知道一个系统最重要的是数据,数据是保存在数据库里。但是很多时候不单止要保存在数据库中,还要同步保存到Elastic Search、HBase、Redis等等。
java技术爱好者
2020/09/22
3.8K0
Canal+Otter - Canal篇(1)
Canal是阿里开源产品之一,是用java开发的基于数据库增量日志解析,提供增量数据订阅&消费的中间件。目前,Canal主要支持了MySQL的binlog解析。
干货满满张哈希
2021/04/12
1.8K0
Canal+Otter - Canal篇(1)
推荐阅读
相关推荐
Canal数据同步工具
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验