1.装箱和拆箱:

装箱:把基本数据类型转化为对应的引用数据类型的操作;
var num = 123 // num
var objNum = new Num(123) // object
console.log(typeof objNum) // null
拆箱:将引用类型对象转换为对应的值类型数据对象;
valueOf()
var objNum = new Number(132)
console.log(typeod objNum.valueOf()) // 123 number
js toPrimitive(input, type)  input:传入的值  type:值类型
1.input 判断是不是原始类型的值 :是 直接返回
2.不是 : input.valueOf() 是: 原始类型 ->直接返回
3.还不是:input.toString():string 是 原始类型 返回
4.报错
面试题:
console.log([] + []) // '' + toPrimitive()
console.log([].valueOf()) // []
console.log([].toString()) // ''
[] + [] = '' + '' = '' console.log([] + {}) // [Object Object] 或 0
console.log([]) // ''
console.log({}.valueOf()) // {}
console.log({}.toString()) // [Object Object]

2.栈和堆:

什么是栈:计算机为原始类型开辟的一块内存空间string number ...
什么是堆:计算机为引用类型开辟的一块内存空间 object
var a = 'Mooc'
var b = a
b = 'Mooc2'
console.log(a, b) // Mooc Mooc2 var c = {key: 1}
var d = c
d.key = 2
console.log(c, d) // 2 2 // ['Mooc', 'Mooc2']
// c d ['x00000018', 'x000018'] -> { {key:2} }
// c d x00000018 -> {key:2} {key:2}
3.js中sort()方法
var arr = [1, 2, 3, 4, 5]; // 1, 2, 3, 4, 5
console.log(arr.sort()) //1, 2, 3, 4, 5
var arr2 = [3. 25, 15, 18, 9, 22];
console.log(arr2.sort()) // 15, 18, 22, 25, 3, 9
js中sort:
1.默认升序
2.将排序的元素转为字符串['3', '22'...];找对应字符串的Unicode码表
默认0-9-----先排第一位,排完第一位之后在排第二位
// 15, 18, 22, 25, 3, 9
var arr3 = [3. 25, 15, a, 18, 9, 22];
console.log(arr3.sort()) // [15, 18, 22, 25, 3, 9, 'a']
解决:
1.定义一个比较器函数
//送人头(callback)
function(x,y){
return x-y
} // 小于0->x移到y前面 大于0->x移到y后面 等于0-> 不变
var arr4 = [3. 25, 15, 18, 9, 22];
arr4.sort(function(x,y){
return x-y
})//默认升序 arr4 [3, 9, 15, 18, 22, 25]
arr4.sort(function(x,y){
return y-x
})//降序 arr4 [25, 22, 18, 15, 9, 3]
3.js中Date对象中的getMounth() 需要注意的:
var now = new Date()
console.log(now.getTime()) // 1608908483092 :1970 1 1 0 至今的一个毫秒数
console.log(now.getDay()) // 5 本周的第几天 周一到周日 7天
console.log(now.getDate()) // 25 号 本月的几号
console.log(now.getMounth() + 1)// 11 0-11(需要加1)
js 设计 仿照 java1.1 getMounth() 0-11=> 1-12 20多年js(java修改了但是js没修改过来)
4.开发中编码和解码使用场景有哪些
var url = 'https://www.baidu.com?key=hello&name=张三&num=123'
// escape() unescape()
console.log(escape(url)) // 除了ASCII(a-z, 0-9) . //https%3A//www.baidu.com%3Fkey%3Dhello%26name%3D%u5F20%u4E09%26num%3D123
var es = escape(url)
console.log(unescape(es)) // ASCII // https://www.baidu.com?key=hello&name=张三&num=123 //encodeURI() decodeURL()
console.log(encodeURI(url)) // https://www.baidu.com?key=hello&name=%E5%BC%A0%E4%B8%89&num=123
var ec = encodeURI(url)
console.log(decodeURI(ec)) // https://www.baidu.com?key=hello&name=张三&num=123 //encodeURIComponent() decodeURIComponent()

JS高级面试题思路(装箱和拆箱、栈和堆、js中sort()方法、.js中Date对象中的getMounth() 需要注意的、开发中编码和解码使用场景有哪些)的更多相关文章

  1. c#的装箱和拆箱及值类型和引用类型

    装箱:它允许根据值类型创建一个对象,然后使用对这新对象的一个引用. int i = 5; object o = i; int j = (int)o; 装箱:运行时将在堆上创建一个包含值5的对象(它是一 ...

  2. 《Effective C#》之减少装箱和拆箱

    <Effective C#>之减少装箱和拆箱_天极网 http://dev.yesky.com/msdn/359/3486359.shtml <Effective C#>之减少 ...

  3. Java基础 【自动装箱和拆箱、面试题】

    JDK 1.5 (以后的版本)的新特性自动装箱和拆箱 1. 自动装箱:把基本类型转换为包装类类型 int a =10; Integer i = new Integer(a); Integer valu ...

  4. C#基础知识系列二(值类型和引用类型、可空类型、堆和栈、装箱和拆箱)

    前言 之前对几个没什么理解,只是简单的用过可空类型,也是知道怎么用,至于为什么,还真不太清楚,通过整理本文章学到了很多知识,也许对于以后的各种代码优化都有好处. 本文的重点就是:值类型直接存储其值,引 ...

  5. 基础系列(4)—— C#装箱和拆箱

    一 装箱和拆箱的概念 装箱是将值类型转换为引用类型 : 拆箱是将引用类型转换为值类型 : 值类型:包括原类型(Sbyte.Byte.Short.Ushort.Int.Uint.Long.Ulong.C ...

  6. [C#] 类型学习笔记一:CLR中的类型,装箱和拆箱

    在学习.NET的时候,因为一些疑问,让我打算把.NET的类型篇做一个总结.总结以三篇博文的形式呈现. 这篇博文,作为三篇博文的第一篇,主要探讨了.NET Framework中的基本类型,以及这些类型一 ...

  7. C#装箱与拆箱的研究

    在对这个问题展开讨论之前,我们不妨先来问这么几个问题,以系统的了解我们今天要探究的主题. 观者也许曾无数次的使用过诸如System.Console类或.NET类库中那些品种繁多的类.那么,我想问的是它 ...

  8. 深入剖析Java中的装箱和拆箱

    深入剖析Java中的装箱和拆箱 自动装箱和拆箱问题是Java中一个老生常谈的问题了,今天我们就来一些看一下装箱和拆箱中的若干问题.本文先讲述装箱和拆箱最基本的东西,再来看一下面试笔试中经常遇到的与装箱 ...

  9. 转 C# 装箱和拆箱[整理]

    1.      装箱和拆箱是一个抽象的概念 2.      装箱是将值类型转换为引用类型 :拆箱是将引用类型转换为值类型       利用装箱和拆箱功能,可通过允许值类型的任何值与Object 类型的 ...

随机推荐

  1. Java中的形式参数和实际参数

    一.概念 1.形式参数: 就是在定义函数或过程的时候命名的参数. 通俗讲就是一个记号. 2.实际参数: 就是在执行时,调用函数或过程时,传递给函数或过程的参数. 通俗讲就是实际值. 3.参数: 就是一 ...

  2. WPF在圆上画出刻度线

    思路 我们可以使用Ellipse先画出一个圆当背景,然后用Canvas再叠加画上刻度线,就能得到如下的效果 我们先用Ellipse画一个橙色的圆,然后将Canvas的宽度和高度绑定到Ellipse的宽 ...

  3. 一文搞懂Java/Spring/Dubbo框架中的SPI机制

    几天前和一位前辈聊起了Spring技术,大佬突然说了SPI,作为一个熟练使用Spring的民工,心中一紧,咱也不敢说不懂,而是在聊完之后赶紧打开了浏览器,开始的学习之路,所以也就有了这篇文章.废话不多 ...

  4. [TcaplusDB知识库]数据库支撑底盘引擎计算层介绍

    在上次的TcaplusDB知识库中,TcaplusDB君为大家讲解了TcaplusDB所用的基于HASH表的Key-value存储引擎TXHDB.存储引擎作为数据库的支撑底盘,其重要性无可置疑,而在本 ...

  5. iNeuOS工业互联平台,聚合和变化率计算、设备IO和通讯状态、组态快捷键、创建文件夹、选择应用图标等,发布:v3.6版本

    目       录 1.      概述... 2 2.      平台演示... 2 3.      聚合和变化率计算... 2 4.      设备IO和通讯状态监测... 3 5.      组 ...

  6. SpringCloud升级之路2020.0.x版-22.Spring Cloud LoadBalancer核心源码

    本系列代码地址:https://github.com/HashZhang/spring-cloud-scaffold/tree/master/spring-cloud-iiford 经过上一节的详细分 ...

  7. 初识nest.js

    nest的核心概念: Nest的核心概念是提供一种体系结构,它帮助开发人员实现层的最大分离,并在应用程序中增加抽象. 架构预览: 主要有三个核心概念:模块Module,  控制器Controller, ...

  8. 【springboot】整合 MyBatis

    转自:https://blog.csdn.net/cp026la/article/details/86493503 1. 简介: 目前,国内大部分公司都使用 MyBatis作为持久层框架.本章整合My ...

  9. hive -- 外部表、内部表、临时表

    1.外部表 关键字:EXTERNAL 外部表创建时需要指定LOCATION 删除外部表时,数据不被删除 CREATE EXTERNAL TABLE page_view(viewTime INT, us ...

  10. web整合Spring和Hibernate

    上一篇是简单整合web和Spring, 这一篇是整合hibernate: 连接池c3p0: spring5.0, hibernate5.0 jars: ------------------------ ...