JS面试题:[1, 2, 3].map(parseInt)
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS面试题:[1, 2, 3].map(parseInt)相关的知识,希望对你有一定的参考价值。
参考技术A显而易见的,在该题目中有两个javascript方法,一个是 Array.prototype.map ,另一个是 parseInt() 。
首先是 Array.prototype.map 方法,这是ES5给出的数组实例的方法。给map传入一个回调函数,map就会遍历数组,将相关信息一起传入回调函数,并取回这个回调函数的返回值作为新数组的对应索引的元素,并返回这个新数组。
回调函数每次可以拿到三个值——(1)数组元素(2)索引值(3)数组本身
注:传递给map()的函数的调用方式和传递给forEach()的函数的调用方式一样,但传递给map()的函数应该要有返回值。map()返回的是新数组,它不修改调用数组。如果调用数组是稀疏数组,则返回的数组也是稀疏数组——具有相同的长度和相同的缺失元素。
Array.prototype.map方法的底层实现
parseInt函数的作用是将第一个字符串转换为数字,它接受两个参数,第一个参数是我们需要转换的字符串,第二个参数是可选的,它代表字符串的基数,即该参数表明我们需要通过几进制去对这个字符串完成转换,如2,就代表字符串是用二进制表达的。如果我们省略第二个参数,当字符串以 0x 或 0X 开头,它就会被当作十六进制,否则被当作十进制。
特殊情况:当parseInt的第二个参数为0时,相当于第二个参数没有传,字符串会被当成十进制,该情况也是最常用的情况。
此外,当字符串的第一个非空格字符无法转换成数字时,也会返回NaN。
下面给出一些例子:
[1, 2, 3].map(parseInt)的parseInt 作为回调函数拿到了map提供的三个参数,得益于JavaScript是弱类型语言,所以传参数量不匹配也不会报错,只会把不用的参数抛弃掉,将缺少的参数设置为undefined。
这里的parseInt只用到了两个参数,分别是 数组元素 和 索引值 。
实际上我们可以把题目展开成如下函数:
如此便清晰明了了,我们很容易得到以下结果:
所以最后我们得到返回结果: [1, NaN, NaN]
BAT Java面试笔试33题:JavaListJava Map等经典面试题!答案汇总!
JavaList面试题汇总
1、List集合:ArrayList、LinkedList、Vector等。
2、Vector是List接口下线程安全的集合。
3、List是有序的。
4、ArrayList和LinkedList数据结构不一样,前者用在查询较多的场合,后者适用于插入较多的场合。
5、ArrayList使用的是数组结构,LinkedList使用的是链表结构。
6、Jdk1.7之前ArrayList默认大小是10,JDK1.7之后是0,JDK差异,每次约按1.5倍扩容。
7、List中的Vector才是线程安全的,其他要实现线程安全使用工具类Collections.synchronizedList(new ArrayList())方法。
8、使用List自身的sort方法,或者使用Collections.sort(list)方法;
9、Arrays.asList使用的是final数组,并且不支持add方法,不支持扩容。
10、List>Array使用toArray方法,Array>List使用Arrays.asList(array)方法,由于它是固定的,不固定的可以使用new ArrayList(Arrays.asList(array))。
11、 ArrayList和LinkedList的区别:
1)ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构。 (LinkedList是双向链表,有next也有previous)
2)对于随机访问get和set,ArrayList觉得优于LinkedList,因为LinkedList要移动指针。
3)对于新增和删除操作add和remove,LinedList比较占优势,因为ArrayList要移动数据。
Java Map面试题汇总
1、常用的Map集合:HashMap、HashTable、LinkedHashMap、ConcurrentHashMap。
2、Collection是List、Set父接口不是Map父接口。
3、HashMap不是线程安全的。线程安全的有HashTable、ConcurrentHashMap、SynchronizedMap,性能最好的是ConcurrentHashMap。
4、使用HashMap要注意避免集合的扩容,它会很耗性能,根据元素的数量给它一个初始大小的值。
5、HashMap是数组和链表组成的,默认大小为16,当hashmap中的元素个数超过数组大小*loadFactor(默认值为0.75)时就会把数组的大小扩展为原来的两倍大小,然后重新计算每个元素在数组中的位置。
6、按添加顺序使用LinkedHashMap,按自然顺序使用TreeMap,自定义排序TreeMap(Comparetor c)。
7、HashMap的链表结构设计是用来解决key的hash冲突问题的。
8、HashMap的键值都可以为NULL,HashTable不行。
9、key的hash冲突,如果key equals一致将会覆盖值,不一致就会将值存储在key对应的链表中。
10、先根据key的hashcode值找到对应的链表,再循环链表,根据key的hash是否相同且key的==或者equals比较操作找到对应的值。
11、HashMap不是线程安全的,效率高,允许有null的键和值。线程安全,效率低,不允许有null的键和值。
12、HashSet和HashTree的区别:HashSet哈希表实现,数据是无序的,可以放入一个null值。TreeSet二差树实现,数据是自动排好序的,不允许放入null值。
String经典面试题
1、String不是基本数据类型。
2、String是final类型的,不可变。
3、比较字符串的值是否相同用equals,比较字符串对象是否同一个用==。
4、jdk7+中的switch可以使用String类型。
5、创建了两个,”abc”本身创建在常量池,通过new又创建在堆中。
6、String、StringBuffer、StringBuilder最大的不同是String不可变,后者可变。StringBuffer是线程安全的,StringBuilder线程不安全速度较快。
7、trim去掉字符串首尾的空白字符。
8、既然String是final的,所以不能被继承。
9、可以自定义java.lang.String类并编译成功,但不能被加载使用,具体请学习类加载机制。
10、String > byte[] 通过String类的getBytes方法;byte[] > String通过new String(byte[])构造器。
没钱没人脉也能轻松入门,让你每年多赚10万!
以上是关于JS面试题:[1, 2, 3].map(parseInt)的主要内容,如果未能解决你的问题,请参考以下文章