JS自有类型系统的问题区分竟如此简单?
wxin55 2025-05-08 21:47 1 浏览 0 评论
嗨,我是勾勾。今天想要和你分享的是如何区分强弱类型与JS自有类型系统的问题。
类型系统的区分
我们在区分不同编程语言时会有一些界定的标准。通常来讲,我们会从类型安全和类型检查上进行区分。
- 类型安全
- 强类型
- 弱类型
- 类型检查
- 静态类型
- 动态类型
类型安全-强类型
在语言层面限制函数的实参类型必须要和形参类型完全相同。这里以Java为例:
class Main {
static void foo (int num) {
System.outprintln(num);
}
public static void main(String[]) {
Main.foo(100); // 100
Main.foo("100"); // error "100" is a string
Main.foo(Integer.parseInt("100")); // ok
}
}
类型安全-弱类型
在语言层面不会限制实参的类型。这里用我们最熟悉的JavaScript为例:
function foo (num) {
console.log(num)
}
foo(100) // ok
foo('100') // ok
foo(pareseInt('100')) // ok
由于这种强弱类型之分,根本不是某一个权威机构的定义,也没有一个具体的规则,所以对于这种界定方式的细节出现了不一样的理解。
但整体上界定方式都是在描述:
- 强类型有更强的类型约束
- 弱类型中几乎没有什么约束
我个人比较认同的一种说法是:
- 强类型语言中不允许任意的隐式类型转换
- 弱类型语言当中允许任意的隐式类型转换
console.log('100' - 50) // 50
console.log(Math.floor('foo')) // NaN
console.log(Math.floor(true)) // 1
变量类型允许随时改变的特点不是强弱类型之间的差异。比如,python就是强类型的语言,但是它的变量类型可以随时改变。这点在很多资料当中可能都表示得有些不太妥当,大多都在说python是一门弱类型语言,事实上不是这样的。
类型检查-静态类型
一个变量声明时它的类型就是明确的,声明过后类型不允许修改。
类型检查-动态类型
运行阶段才能够明确一个类型,而且变量的类型随时可以改变。动态类型语言中,变量是没有类型的,变量中存放的值是有类型的。
var foo = 100 // number类型
foo = 'bar' // 字符串
console.log(foo) // bar
JS类型系统特征
- JS是一门弱类型且动态类型的语言。
- 语言本身的类型系统是很薄弱的,甚至我们也可以说JS就没有任何类型系统。
- 因为JS几乎没有任何的类型限制,所以JS这门语言特别灵活多变。
- 但是在这种表象的背后,丢失掉的就是类型系统的可靠性。在代码当中,每遇到一个变量,我们都需要去担心它到底是不是我想要的类型。
为什么JS不是强类型或者静态类型
这个问题其实与JS的背景有关。早前JS的应用就没想到会发展到今天这种规模,可能几十行代码或者一百多行代码就能完成此功能。在这种一眼就看到头的情况下,类型系统的限制就比较多余了,或者说很麻烦。
JS是一门脚本语言,脚本语言的特点就是:不需要编译就直接在运行环境中去运行。换句话说,JS没有编译环节,所以就算设计成了静态类型语言也没有什么意义,因为静态类型需要在编译阶段进行编译检查,而JS根本没有这样一个环节。
所以JS是一门更灵活更多变的弱类型动态语言。
这在当时没有问题,甚至也是一种优势。但是现在前端应用的规模已经完全不同了,遍地都是大规模应用,所以JS代码就越来越复杂,开发周期也越来越长,这种情况下,之前的优势也就逐渐成为了短板。
弱类型的问题
问题异常时要等到运行时才能发现。
const obj = {}
obj.foo()// TypeError: obj.foo is not a function
setTimeout(() => {
obj.foo() //TypeError: obj.foo is not a function
}, 1000)
类型不明确,会造成函数功能有可能发生改变。
function sum (a, b) {
return a + b
}
console.log(sum(100, 200)) // 300
console.log(sum(100, '200')) // 100200
对对象索引器的一种错误用法:
const obj = {}
obj[true] = 100
console.log(obj['true']) // 100
这些都只是弱类型问题的冰山一角。
弱类型语言的弊端是非常明显的,只是在代码量小的情况下可以通过约定的方式进行规避。而对于一些开发周期比较长的大型项目,这种君子约定还是有一定的隐患,只有在语法层面的强制要求才能够提供更可靠的保障。
强类型语言的代码在代码可靠程度上有明显优势,使用强类型语言就可以提前消灭一大批有可能存在的类型异常,而不必等到在运行过程中慢慢地debug。
强类型的优势
能够在编码阶段提前消灭一大部分类型异常。
代码也更智能,编码更准确。
function render (element) {
element. // 这时智能提示不能提示出来很有用的内容;强类型语言,编译器时时刻刻都知道是哪一个类型,所以能够提供出来更准确的智能提示}
重构更牢靠。
const util = { aaa: () => {
console.log('util func')
}
}// 这个对象的aaa方法如果在很多地方有使用的话,我们是不能随意修改的;强类型的语言,一但属性名发生了变化就会立即报出错误,这时候可以轻松定位所有使用到的地方,然后修改
减少不必要的类型判断。
function sum (a, b) {
if (typeof a === 'number' || typeof b === 'number') {
throw new TypeError('arguments must be a number')
}
return a + b
}
// 强类型的语言在代码层面会减少一些我们类型判断
本文转载自公众号:勾勾的前端世界
获取更多前端技术, 欢迎来找勾勾交流
相关推荐
- js获取上传文件类型以及大小的方法
-
前端web上传文件时,需要在上传之前判断一下文件的类型以及文件的大小,HTML为前端的标记语言是无法做到这一点,只能使用javascript动态脚本代码来实现。js获取上传文件大小的方法示例代码:&...
- 资源分享:移动设备类型判断JS(什么叫移动设备)
-
相信很多童鞋在实际开发中都会遇到需要判断设备类型来进行不同页面跳转处理,例如手机端访问移动页面,pc端访问pc页面亦或是ios和安卓扫描同一个二维码跳转至不同的下载页面。有这样一种做法当然了你可以使用...
- JS学习笔记:三、数据类型(js六中数据类型)
-
上节知识点回顾:1.什么是变量2.变量的声明3.一次性声明多个变量并赋值4.变量名的规范5.变量的使用本讲内容:数据类型1.数据类型分类原始类型(基本类型)+引用类型原始类型:数字、字符串、布尔类...
- JavaScript中常用数据类型,你知道几个?
-
本文首发自「慕课网」,想了解更多IT干货内容,程序员圈内热闻,欢迎关注!作者|慕课网精英讲师Lison这篇文章我们了解一下JavaScript中现有的八个数据类型,当然这并不是JavaScr...
- JS自有类型系统的问题区分竟如此简单?
-
嗨,我是勾勾。今天想要和你分享的是如何区分强弱类型与JS自有类型系统的问题。类型系统的区分我们在区分不同编程语言时会有一些界定的标准。通常来讲,我们会从类型安全和类型检查上进行区分。类型安全强类型弱类...
- 抛弃 typeof,这样判断 JavaScript 类型更准确
-
JavaScript作为一门动态类型语言,类型判断一直是开发者面临的常见挑战。众所周知,typeof操作符存在诸多局限性,无法准确区分数组、对象、null等类型。那么,有没有更精确、更优雅的类型判断方...
- 有哪些好玩的 Python 代码?(python有什么好玩的项目)
-
Python是一门非常强大且灵活的编程语言,它不仅可以用来编写复杂的软件应用,还能用来创造一些有趣的小程序和游戏。以下是一些好玩的Python代码示例,涵盖了基础语法、字符串处理、图形绘制等多个...
- Python统计快乐8的两码组合数据随机新的两码三码
-
我们利用Python统计出快乐8的两码组合数据,来生成新的快乐8选二,选三等组合fromcollectionsimportCounterimportrandom#输入新的快乐8两码统计...
- 10 个鲜为人知的 Python 可视化概念和技巧
-
数据可视化可视化是我们以各种可视化形式描述数据的操作,从图表、图形到信息图形。它是探索性数据分析(EDA)中最重要的部分之一,因为它使我们能够轻松掌握变量之间的关系以及对后期特征工程和建模有用的数...
- 用Python搞个随机简单的迷宫(python做迷宫)
-
为了增加一点趣味打发鼓噪的情绪,玩个简单的迷宫,方便以后搞游戏迷宫。堵路的就简单用#符号吧,如果弄成界面的话可以用图片来,比图墙的图片。因为是随机的,不是固定的一个迷宫,我们少不了random模块...
- 面试干货——某度Python面试题,转发收藏
-
目录1、Python是如何进行内存管理的?2、什么是lambda函数?它有什么好处?3、Python里面如何实现tuple和list的转换?4、请写出一段Python代码实现删除一个list里面的重复...
- Python while循环深度解析:从基础到实战,一文全掌握!
-
一、循环的本质:重复执行的魔法在编程世界中,循环是实现自动化的核心工具。想象你需要重复做100次相同的事情,手动编写100次代码显然不现实。这时候,循环就像一位不知疲倦的助手,帮你完成重复性任务。Py...
- 如何在 Python 中随机排列列表元素
-
在本教程中,我们将学习在Python中如何打乱列表元素顺序,随机排列列表元素。如何随机排列列表是一项非常有用的技能。它在开发需要选择随机结果游戏中非常有用。它还适用于数据相关的工作中,可能需要提取...
- Python快速入门教程7:循环语句(python循环语句有哪些)
-
一、循环语句简介循环语句用于重复执行一段代码块,直到满足特定条件为止。Python支持两种主要的循环结构:for循环和while循环。二、for循环基本语法for循环用于遍历序列(如列表、元组、字符串...
- 用Python进行机器学习(6)随机森林
-
上一节我们讲到了决策树这个算法,但是一棵决策树可能会存在过拟合的现象,而且对数据微小的变化也比较敏感,为了解决这些问题,我们可以通过多棵树的方式,也就是今天要介绍的随机森林。随机森林算法也就是Rand...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- hive行转列函数 (63)
- sourcemap文件是什么 (54)
- display none 隐藏后怎么显示 (56)
- 共享锁和排他锁的区别 (51)
- httpservletrequest 获取参数 (64)
- jstl包 (64)
- qsharedmemory (50)
- watch computed (53)
- java中switch (68)
- date.now (55)
- git-bash (56)
- 盒子垂直居中 (68)
- npm是什么命令 (62)
- python中+=代表什么 (70)
- fsimage (51)
- nginx break (61)
- mysql分区表的优缺点 (53)
- centos7切换到图形界面 (55)
- 前端深拷贝 (62)
- kmp模式匹配算法 (57)
- jsjson字符串转json对象 (53)
- jdbc connection (61)
- javascript字符串转换为数字 (54)
- mybatis 使用 (73)
- 安装mysql数据库 (55)