typeof && instanceof

本文深入探讨JavaScript中的typeof和instanceof操作符,解释它们如何用于类型检查,包括基本数据类型和引用类型的判断。通过实例说明typeof和instanceof的使用场景和特殊情况,如NaN的类型,以及字符串和函数类型的细节。

typeof && instanceof

typeof

typeof的值:number,string,undefined,object,symbol,boolean,function
typeof所描述的是基本数据类型的值;
一些?:

typeof 3.14 === ‘number’;
typeof Math.LN2 === ‘number’;
typeof Infinity === ‘number’;
typeof NaN === ‘number’; // 尽管NaN是"Not-A-Number"的缩写
typeof Number(1) === ‘number’; // 但不要使用这种形式!
typeof String(“abc”) === ‘string’; // 但不要使用这种形式!
typeof Boolean(true) === ‘boolean’; // 但不要使用这种形式!
typeof Symbol(‘foo’) === ‘symbol’;
typeof Symbol.iterator === ‘symbol’;
typeof new Boolean(true) === ‘object’;
typeof new Number(1) === ‘object’;
typeof new String(“abc”) === ‘object’;
typeof Math.sin === ‘function’;
typeof new Function() === ‘function’;
typeof null === ‘object’; // 从一开始出现JavaScript就是这样的
typeof /s/ === ‘function’; // Chrome 1-12 , 不符合 ECMAScript 5.1
typeof /s/ === ‘object’; // Firefox 5+ , 符合 ECMAScript 5.1

instanceof

instanceof是用来判断对应对象其所属的引用类型 (object instanceof constructor)是指对象A的原型链上是否有B构造函数所指向的原型(B.prototype)
举个? :

[1,2,3,4] instanceof Array  //true;
new String("Hello") instanceof String //true;  
new String("Hello") instanceof Object //true;  
new String() instanceof String //true;
"hello world!" instanceof String //false  

上面的?前面的几个按照定义来理解很容易得出答案,最后一个按着定义来理解也可以得出false,因为“hello world”根本就不是一个引用类型。

Curiosity–延伸

"hello world".__proto__ //String {"", length: 0, constructor: ƒ, anchor: ƒ, big: ƒ, blink: ƒ, …};  
(new String("hello world")).__proto__ //String {"", length: 0, constructor: ƒ, anchor: ƒ, big: ƒ, blink: ƒ, …};  
"hello world".__proto__.constructor //ƒ String() { [native code] };  
(new String("hello world")).__proto__.constructor // ƒ String() { [native code] };    

//另一些奇怪现象;  
console.log(Object instanceof Object);//true 
console.log(Function instanceof Function);//true 
console.log(Number instanceof Number);//false 
console.log(String instanceof String);//false

可以发现两种字符串的隐式原型和构造函数是一样的,那为什么instanceof的表现会不一样?
立马翻了翻红宝石书,原来因为当我们尝试访问一个primitive值(基本数据类型,字面量)的属性时,JS引擎内部会调用一个内置[[toObject]] 方法,将字面量的"Hello World"转为一个[[PrimitiveValue]] (primitive类型:Undefined, Null, Boolean, String, Number)为”foo”的String对象,然后从其原型链中尝试查找需要访问的属性,使用结束后再释放掉这个String对象。

"Hello world".__proto__//相当于toObject("Hello world").__proto__

这也是为什么我们使用字面量的字符串(“Hello world”)的时候也可以使用String对象的一些方法。再想一想为什么"Hello world" == new String(“Hello world”),因为’=='运算符也会进行类型转换,所以等式成立。

=================================================
上面的“奇怪现象”,需要一张图:
在这里插入图片描述

其实在控制台看Object,Function,Number,String…打印出来的都是一个function,所以他们自然属于Function对象,根据原型链图及instanceof定义可以得出上面的“奇怪现象”的几个语句是成立的;因为Function对象的原型链上并没有String,Number…等构造函数指向的原型,但Function和Object有。

Number instanceof Function //true

完结!

植物实例分割数据集 一、基础信息 数据集名称:植物实例分割数据集 图片数量: - 训练集:9,600张图片 - 验证集:913张图片 - 测试集:455张图片 总计:10,968张图片 分类类别:59个类别,对应数字标签0至58,涵盖多种植物状态或特征。 标注格式:YOLO格式,适用于实例分割任务,包含多边形标注点。 数据格式:图像文件,来源于植物图像数据库,适用于计算机视觉任务。 二、适用场景 • 农业植物监测AI系统开发:数据集支持实例分割任务,帮助构建能够自动识别植物特定区域并分类的AI模型,辅助农业专家进行精准监测和分析。 • 智能农业应用研发:集成至农业管理平台,提供实时植物状态识别功能,为作物健康管理和优化种植提供数据支持。 • 学术研究与农业创新:支持植物科学与人工智能交叉领域的研究,助力发表高水平农业AI论文。 • 农业教育与培训:数据集可用于农业院校或培训机构,作为学生学习植物图像分析和实例分割技术的重要资源。 三、数据集优势 • 精准标注与多样性:标注采用YOLO格式,确保分割区域定位精确;包含59个类别,覆盖多种植物状态,具有高度多样性。 • 数据量丰富:拥有超过10,000张图像,大规模数据支持模型充分学习和泛化。 • 任务适配性强:标注兼容主流深度学习框架(如YOLO、Mask R-CNN等),可直接用于实例分割任务,并可能扩展到目标检测或分类等任务。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值