JavaScript九大面试问题集锦,助你顺利通关


JavaScript九大面试问题集锦,助你顺利通关

文章插图
图片来源:Irvan Smith / Unsplash
【JavaScript九大面试问题集锦,助你顺利通关】人们认为JAVAScript是最适合初学者的语言 。一部分原因在于JavaScript在互联网中运用广泛 , 另一部分原因在于其自身特性使得即使编写的代码不那么完美依然可以运行:无论是否少了一个分号或是内存管理问题 , 它都不像许多其他语言那样严格 , 但在开始学习之前 , 要确保你已经知道JavaScript的来龙去脉 , 包括可以自动完成的事情和“幕后”的操作 。
本文将介绍一些面试时关于JavaScript的常见问题 , 以及一些突发难题 。当然 , 每次面试都是不同的 , 你也可能不会遇见这类问题 。但是知道的越多 , 准备的就越充分 。
JavaScript九大面试问题集锦,助你顺利通关

文章插图
 
第一部分:突发难题如果在面试中突然问到下列问题 , 似乎很难回答 。即便如此 , 这些问题在准备中仍发挥作用:它们揭示了JavaScript的一些有趣的功能 , 并强调在提出编程语言时 , 首先必须做出的一些决定 。
了解有关JavaScript的更多功能 , 建议访问https://wtfjs.com 。
1. 为什么Math.max()小于Math.min()?
Math.max()> Math.min()输出错误这一说法看上去有问题 , 但其实相当合理 。
如果没有给出参数 , Math.min()返回infinity(无穷大) , Math.max()返回-infinity(无穷小) 。这只是max()和min()方法规范的一部分 , 但选择背后的逻辑值得深议 。了解其中原因 , 请看以下代码:
Math.min(1) // 1Math.min(1, infinity)// 1Math.min(1, -infinity)// -infinity如果-infinity(无穷小)作为Math.min()的默认参数 , 那么每个结果都是-infinity(无穷小) , 这毫无用处! 然而 , 如果默认参数是infinity(无穷大) , 则无论添加任何参数返回都会是该数字 - 这就是我们想要的运行方式 。
2. 为什么0.1+0.2不等于0.3
简而言之 , 这与JavaScript在二进制中存储浮点数的准确程度有关 。在google Chrome控制台中输入以下公式将得到:
0.1 + 0.2// 0.30000000000000004 0.1 + 0.2 - 0.2// 0.10000000000000003 0.1 + 0.7// 0.7999999999999999如果是简单的等式 , 对准确度没有要求 , 这不太可能产生问题 。但是如果需要测试相等性 , 即使是简单地应用也会导致令人头疼的问题 。解决这些问题 , 有以下几种方案 。
Fixed Point固定点
例如 , 如果知道所需的最大精度(例如 , 如果正在处理货币) , 则可以使用整数类型来存储该值 。因此 , 可以存储499而非4.99美元 , 并在此基础上执行任何等式 , 然后可以使用类似result =(value / 100).toFixed(2)的表达式将结果显示给最终用户 , 该表达式返回一个字符串 。
BCD代码
如果精度非常重要 , 另一种方法是使用二进制编码的十进制(BCD)格式 , 可以使用BCD库(https://formats.kaitai.io/bcd/javascript.html)访问JavaScript 。每个十进制值分别存储在一个字节(8位)中 。鉴于一个字节可以存储16个单独值 , 而该系统仅使用0-9位 , 所以这种方法效率低下 。但是 , 如果十分注重精确度 , 采用何种方法都值得考量 。
3. 为什么018减017等于3?
018-017返回3实际是静默类型转换的结果 。这种情况 , 讨论的是八进制数 。
八进制数简介
你或许知道计算中使用二进制(base-2)和十六进制(base-16)数字系统 , 但是八进制(base-8)在计算机历史中的地位也举足亲重:在20世纪50年代后期和 20世纪60年代间 , 八进制被用于简化二进制 , 削减高昂的制造系统中的材料成本 。
不久以后Hexadecimal(十六进制)开始登上历史舞台:
1965年发布的IBM360迈出了从八进制到十六进制的决定性一步 。我们这些习惯八进制的人对这一举措感到震惊!沃恩·普拉特(Vaughan Pratt)
如今的八进制数
但在现代编程语言中 , 八进制又有何作用呢?针对某些案例 , 八进制比十六进制更具优势 , 因为它不需要任何非数字(使用0-7而不是0-F) 。


推荐阅读