zoukankan      html  css  js  c++  java
  • 阿里巴巴前端面试parseInt()函数的面试题

    JavaScript 是弱类型语言,为了保证数值的有效性,在处理数值的时候,我们可以对数值字符串进行强行转换。如 parseInt 取整和 parseFloat 取浮点数。Java 也有 Integer.parseInt() 方法, 但是 JavaScript 的 parseInt 处理方式与 Java 等强整型语言不太一样, 所以经常有人因为对这个方法的使用不当而获得异常返回。

    之前阿里巴巴的前端面试有一道这样的题,是关于parseInt()的用法的,题目如下:

    var b = parseInt("01");
    alert("b="+b);
    var c = parseInt("09/08/2009");
    alert("c="+c);
    

    答案是b=1,c=0。

    parseInt()是用来解析字符串,返回值是整数。有几个特点:

    1. 无视被解析字符串最前和最后的空格,即:" 111 "和"111"是一样的
    2. 正规格式是parseInt(string,radix)。radix可以省略,为0或者2-36之间的整数,用来表示被解析数值的进制。(注意不是解析返回结果的进制)。如果radix不在此范围内,返回NaN
    3. 如果radix 省略或者为0,则按默认进制对string进行解析。
    4. string的首字符为0,则默认解析为8进制。string首字符为0x则默认解析为16进制。其他情况默认为10进制。
    5. 解析从第一个可以解析的字符开始,到第一个不能解析的字符(如空格,标点符号等)结束。后面的字符不再解析。
    6. 如果第一个字符不可以解析,则返回NaN。如"a8989"

    现在我们再回头来看这个题就容易理解了。

    b的值首字母是0,按8进制解析后面的数值,也就是8进制的1。自然返回值为1。

    难点在第二个。

    c的首字符是0,一般想法是按8进制进行解析。但是我们发现第二个字符9已经不是8进制数,也就是说9是第一个不能解析的字符。parseInt("09/08/2009")也就变成了parseInt("0");结果再明显不过,是0。

    如果我们稍加变化parseInt("0119/08/2009"),首字符是0,按八进制解析,同样读到9的时候不能解析。也就变成了parseInt("011"),结果也很明显,是9。

    下面的代码大家可以自己测试一下,只要把等价的string写出来,结果就显而易见了。还有提示大家注意分辨网上杂乱的资料。不要被错误的分析误导。

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>test</title>
    </head>
    <body>
    </body>
    <script type="text/javascript">
    document.write(parseInt("010","")+ "<br />");
    document.write(parseInt("010","0")+ "<br />");
    document.write(parseInt("10","2")+ "<br />");
    document.write(parseInt("09/08/2009")+ "<br />");
    document.write(parseInt("0119/08/2009")+ "<br />");
    document.write(parseInt("03 0/aafsdfs")+ "<br />");
    document.write(parseInt(" 030,aaf")+ "<br />");
    document.write(parseInt("030aaf")+ "<br />");
    document.write(parseInt("03/2009")+ "<br />");
    document.write(parseInt("a03/2009")+ "<br />");
    document.write(parseInt("0119/08/2009")+ "<br />");
    </script>
    </html>
    

    一个例子:

    parseInt("10");			//返回 10
    parseInt("19",10);		//返回 19 (10+9)
    parseInt("11",2);		//返回 3 (10+9)
    parseInt("17",8);		//返回 15 (8+7)
    parseInt("1f",16);		//返回 31 (16+15)
    parseInt("010");		//未定:返回 10 或 8
  • 相关阅读:
    Mac快捷键符号解释及用法介绍
    Mac使用小技巧:Fn键的妙用技巧
    Mac快捷键大全
    idea 开发SpringBoot项目并打包docker镜像部署到节点上
    .netcore linux开机自启脚本
    javascript Event Loop
    mysql函数使用技巧
    MySql查找慢查询sql
    js优先队列和链表
    mysql性能优化
  • 原文地址:https://www.cnblogs.com/xiaoyang002/p/4067872.html
Copyright © 2011-2022 走看看