JavaScript系列(17)--类型系统模拟
JavaScript类型系统模拟 🎭
今天,让我们深入探讨JavaScript中的类型系统模拟。虽然JavaScript是一门动态类型语言,但我们可以通过各种方式来实现类型检查和验证。
类型系统基础 🌟
💡 小知识:JavaScript是一门动态类型语言,但我们可以通过运行时类型检查、TypeScript等工具,或自定义类型系统来增强类型安全性。
基本类型检查 📊
// 1. 类型检查工具
class TypeChecker {static checkType(value, expectedType) {const actualType = typeof value;if (actualType !== expectedType) {throw new TypeError(`Expected type ${expectedType}, but got ${actualType}`);}return value;}static isNumber(value) {return typeof value === 'number' && !isNaN(value);}static isString(value) {return typeof value === 'string';}static isBoolean(value) {return typeof value === 'boolean';}static isFunction(value) {return typeof value === 'function';}static isObject(value) {return value !== null && typeof value === 'object';}static isArray(value) {return Array.isArray(value);}static isInstanceOf(value, constructor) {return value instanceof constructor;}
}// 2. 类型断言
function typeAssertions() {function assertNumber(value, message = 'Value must be a number') {if (!TypeChecker.isNumber(value)) {throw new TypeError(message);}return value;}function assertString(value, message = 'Value must be a string') {if (!TypeChecker.isString(value)) {throw new TypeError(message);}return value;}function assertNonNull(value, message = 'Value cannot be null or undefined') {if (value === null || value === undefined) {throw new TypeError(message);}return value;}// 使用示例function calculateArea(width, height) {assertNumber(width, 'Width must be a number');assertNumber(height, 'Height must be a number');return width * height;}
}// 3. 类型守卫
function typeGuards() {// 类型守卫函数function isString(value): value is string {return typeof value === 'string';}function isNumber(value): value is number {return typeof value === 'number' && !isNaN(value);}function isArray(value): value is Array<any> {return Array.isArray(value);}// 使用示例function processValue(value: any) {if (isString(value)) {return value.toUpperCase();} else if (isNumber(value)) {return value.toFixed(2);} else if (isArray(value)) {return value.length;}throw new TypeError('Unsupported type');}
}
高级类型系统实现 🔧
// 1. 泛型类型实现
class GenericType<T> {private value: T;constructor(value: T) {this.value = value;}getValue(): T {return this.value;}map<U>(fn: (value: T) => U): GenericType<U> {return new GenericType(fn(this.value));}
}// 2. 联合类型实现
class UnionType {private value: any;private types: Function[];constructor(value: any, ...types: Function[]) {if (!types.some(type => this.checkType(value, type))) {throw new TypeError('Value does not match any of the specified types');}this.value = value;this.types = types;}private checkType(value: any, type: Function): boolean {if (type === String) return typeof value === 'string';if (type === Number) return typeof value === 'number';if (type === Boolean) return typeof value === 'boolean';return value instanceof type;}getValue(): any {return this.value;}
}// 3. 交叉类型实现
class IntersectionType {private value: any;constructor(value: any, ...types: Function[]) {if (!types.every(type => this.checkType(value, type))) {throw new TypeError('Value does not match all specified types');}this.value = value;}private checkType(value: any, type: Function): boolean {return Object.getOwnPropertyNames(type.prototype).every(prop => typeof value[prop] === typeof type.prototype[prop]);}getValue(): any {return this.value;}
}
类型系统应用 💼
让我们看看类型系统在实际开发中的应用:
// 1. 验证器系统
class Validator {private rules: Map<string, Function[]>;constructor() {this.rules = new Map();}// 添加验证规则addRule(field: string, ...validators: Function[]) {if (!this.rules.has(field)) {this.rules.set(field, []);}this.rules.get(field)!.push(...validators);}// 验证对象validate(obj: any): ValidationResult {const errors = new Map();for (const [field, validators] of this.rules) {const value = obj[field];const fieldErrors = validators.map(validator => validator(value)).filter(error => error !== null);if (fieldErrors.length > 0) {errors.set(field, fieldErrors);}}return {isValid: errors.size === 0,errors};}// 预定义验证器static required(value: any) {return value === undefined || value === null || value === '' ? 'Field is required' : null;}static minLength(length: number) {return (value: string) => value.length < length ? `Minimum length is ${length}` : null;}static maxLength(length: number) {return (value: string) => value.length > length ? `Maximum length is ${length}` : null;}static pattern(regex: RegExp, message: string) {return (value: string) => !regex.test(value) ? message : null;}
}// 2. 类型安全的事件系统
class TypedEventEmitter<Events extends Record<string, any>> {private listeners: Map<keyof Events, Function[]>;constructor() {this.listeners = new Map();}on<K extends keyof Events>(event: K, listener: (data: Events[K]) => void) {if (!this.listeners.has(event)) {this.listeners.set(event, []);}this.listeners.get(event)!.push(listener);return () => this.off(event, listener);}off<K extends keyof Events>(event: K, listener: (data: Events[K]) => void) {const listeners = this.listeners.get(event);if (listeners) {const index = listeners.indexOf(listener);if (index !== -1) {listeners.splice(index, 1);}}}emit<K extends keyof Events>(event: K, data: Events[K]) {const listeners = this.listeners.get(event);if (listeners) {listeners.forEach(listener => listener(data));}}
}// 3. 类型安全的状态管理
class TypedStore<State extends object> {private state: State;private listeners: Set<(state: State) => void>;constructor(initialState: State) {this.state = initialState;this.listeners = new Set();}getState(): Readonly<State> {return Object.freeze({ ...this.state });}setState(partial: Partial<State>) {this.state = { ...this.state, ...partial };this.notify();}subscribe(listener: (state: State) => void) {this.listeners.add(listener);return () => this.listeners.delete(listener);}private notify() {const state = this.getState();this.listeners.forEach(listener => listener(state));}
}
性能优化 ⚡
类型检查和验证的性能优化技巧:
// 1. 缓存类型检查结果
class TypeCache {private static cache = new WeakMap<object, Map<string, boolean>>();static checkType(obj: object, type: string): boolean {let typeCache = this.cache.get(obj);if (!typeCache) {typeCache = new Map();this.cache.set(obj, typeCache);}if (typeCache.has(type)) {return typeCache.get(type)!;}const result = this.performTypeCheck(obj, type);typeCache.set(type, result);return result;}private static performTypeCheck(obj: object, type: string): boolean {// 实际的类型检查逻辑return typeof obj === type;}
}// 2. 批量类型检查优化
class BatchTypeChecker {private validations: Array<() => boolean>;constructor() {this.validations = [];}addValidation(validation: () => boolean) {this.validations.push(validation);}validate(): boolean {// 使用 Array.every 进行短路优化return this.validations.every(validation => validation());}
}// 3. 延迟类型检查
class LazyTypeChecker {private typeChecks: Map<string, () => boolean>;private results: Map<string, boolean>;constructor() {this.typeChecks = new Map();this.results = new Map();}addCheck(name: string, check: () => boolean) {this.typeChecks.set(name, check);}check(name: string): boolean {if (!this.results.has(name)) {const check = this.typeChecks.get(name);if (!check) return false;this.results.set(name, check());}return this.results.get(name)!;}
}
最佳实践建议 💡
- 类型检查策略
// 1. 运行时类型检查
function runtimeTypeChecking() {// 基本类型检查function checkPrimitive(value: any, type: string) {return typeof value === type;}// 复杂类型检查function checkComplex(value: any, type: Function) {return value instanceof type;}// 结构类型检查function checkStructure(value: any, structure: object) {return Object.entries(structure).every(([key, type]) => {return checkPrimitive(value[key], type as string);});}
}// 2. 类型安全的API设计
function typeSecureAPI() {interface APIOptions {endpoint: string;method: 'GET' | 'POST' | 'PUT' | 'DELETE';headers?: Record<string, string>;body?: any;}class APIClient {request<T>(options: APIOptions): Promise<T> {// 实现类型安全的API请求return fetch(options.endpoint, {method: options.method,headers: options.headers,body: JSON.stringify(options.body)}).then(res => res.json());}}
}// 3. 类型转换安全
function typeConversionSafety() {// 安全的数字转换function toNumber(value: any): number {if (typeof value === 'number') return value;if (typeof value === 'string') {const num = Number(value);if (!isNaN(num)) return num;}throw new TypeError('Cannot convert to number');}// 安全的布尔转换function toBoolean(value: any): boolean {if (typeof value === 'boolean') return value;if (typeof value === 'string') {return ['true', '1', 'yes'].includes(value.toLowerCase());}return Boolean(value);}
}
结语 📝
JavaScript的类型系统虽然是动态的,但通过合适的工具和技术,我们可以实现强大的类型检查和验证。我们学习了:
- 基本的类型检查方法
- 高级类型系统的实现
- 实际应用场景
- 性能优化技巧
- 最佳实践和注意事项
💡 学习建议:在使用类型系统时,要平衡类型安全性和开发效率。可以考虑使用TypeScript等工具来获得更好的类型支持,同时在运行时实现必要的类型检查。
如果你觉得这篇文章有帮助,欢迎点赞收藏,也期待在评论区看到你的想法和建议!👇
终身学习,共同成长。
咱们下一期见
💻
相关文章:
JavaScript系列(17)--类型系统模拟
JavaScript类型系统模拟 🎭 今天,让我们深入探讨JavaScript中的类型系统模拟。虽然JavaScript是一门动态类型语言,但我们可以通过各种方式来实现类型检查和验证。 类型系统基础 🌟 💡 小知识:JavaScript是…...
openssl编译
关于windows下,openssl编译 环境准备 安装 perl:https://djvniu.jb51.net/200906/tools/ActivePerl5_64.rar安装nasm:https://www.nasm.us/pub/nasm/releasebuilds/2.13.01/win64/nasm-2.13.01-installer-x64.exe下载opensll源码:https://o…...
校园网络综合布线系统设计与实践
校园网络综合布线系统设计与实践 摘要:随着信息时代的发展,网络综合布线显得更加重要。综合布线技术也日益引起人的重视。综合布线管理系统是一个实用性十分强的系统工程,同样又是现代社区信息化建设的基础与必要产品,是对多用途…...
如果商品信息更新,爬虫会失效吗?
当商品信息更新时,爬虫是否失效取决于更新的具体内容。以下是一些可能影响爬虫的因素: 可能导致爬虫失效的情况 HTML结构变化:如果 yiwugo 平台更新了商品详情页面的 HTML 结构,比如改变了元素的标签、类名或 ID,那么…...
【UE5 C++课程系列笔记】27——多线程基础——ControlFlow插件的基本使用
目录 步骤 一、搭建基本同步框架 二、添加委托 三、添加蓝图互动框架 四、修改为异步框架 完整代码 通过一个游戏初始化流程的示例来介绍“ControlFlows”的基本使用。 步骤 一、搭建基本同步框架 1. 勾选“ControlFlows”插件 2. 新建一个空白C类,这里…...
有收到腾讯委托律师事务所向AppStore投诉带有【水印相机】主标题名称App的开发者吗
近期,有多名开发者反馈,收到来自腾讯科技 (深圳) 有限公司委托北京的一家**诚律师事务所卞,写给AppStore的投诉邮件。 邮件内容主要说的是,腾讯注册了【水印相机】这四个字的商标,所以你们这些在AppStore上的app&…...
标定 3
标定场景与对应的方式 标定板标定主要应用场景: (1)无法获取到执行机构物理坐标值,比如相机固定,执行机构为传送带等 (2)相机存在畸变等非线性标定情况,需要进行畸变校正 (3)标定单像素精度 (4)获取两个相机之间的坐标系关系 标定板操作步骤: (1)确定好拍…...
用 C# 绘制谢尔宾斯基垫片
谢尔宾斯基垫片是一个三角形,分解成多个小三角形,如右图所示。有几种方法可以生成这种垫片。这里展示的方法是其中一种比较令人惊讶的方法。 程序从三个点开始(图中圆圈所示)。“当前位置”从其中一个点开始。为了生成后续点&…...
java.lang.NoClassDefFoundError: javax/xml/bind/DatatypeConverter
今天在朋友机子上运行代码,在生成token的时候,遇到了这样一个问题: Caused by: java.lang.NoClassDefFoundError: javax/xml/bind/DatatypeConverter at io.jsonwebtoken.impl.Base64Codec.decode(Base64Codec.java:26) ~[jjwt-0.9.1.jar:0.…...
双因素身份验证技术在NPI区域邮件安全管控上的解决思路
在制造业中,NPI(New Product Introduction,新产品导入)区域是指专门负责新产品从概念到市场推出全过程的部门或团队。NPI 的目标是确保新产品能够高效、高质量地投入生产,并顺利满足市场需求。在支撑企业持续创新和竞争…...
java后端对接飞书登陆
java后端对接飞书登陆 项目要求对接第三方登陆,飞书登陆,次笔记仅针对java后端,在看本笔记前,默认已在飞书开发方已建立了应用,并获取到了appid和appsecret。后端要做的其实很简单,基本都是前端做的&…...
记录一次Android Studio的下载、安装、配置
目录 一、下载和安装 Android Studio 1、搜索下载Android studio 2、下载成功后点击安装包进行安装: 3、这里不用打勾,直接点击安装 : 4、完成安装: 5、这里点击Cancel就可以了 6、接下来 7、点击自定义安装:…...
直流无刷电机控制(FOC):电流模式
目录 概述 1 系统框架结构 1.1 硬件模块介绍 1.2 硬件实物图 1.3 引脚接口定义 2 代码实现 2.1 软件架构 2.2 电流检测函数 3 电流环功能实现 3.1 代码实现 3.2 测试代码实现 4 测试 概述 本文主要介绍基于DengFOC的库函数,实现直流无刷电机控制&#x…...
73.矩阵置零 python
矩阵置零 题目题目描述示例 1:示例 2:提示: 题解思路分析Python 实现代码代码解释提交结果 题目 题目描述 给定一个 m x n 的矩阵,如果一个元素为 0 ,则将其所在行和列的所有元素都设为 0 。请使用 原地 算法。 示例…...
垃圾收集算法
分代收集理论 分代收集理论,建立在两个分代假说之上。 弱分代假说:绝大多数对象都是朝圣夕灭的。 强分代假说:熬过越多次垃圾收集的过程的对象就越难以消亡。 这两个分代假说奠定了垃圾收集器的一致设计原则:收集器应该将Java…...
SQL-leetcode-262. 行程和用户
262. 行程和用户 表:Trips --------------------- | Column Name | Type | --------------------- | id | int | | client_id | int | | driver_id | int | | city_id | int | | status | enum | | request_at | varchar | --------------------- id 是这张表的主键…...
太原理工大学软件设计与体系结构 --javaEE
这个是简答题的内容 选择题的一些老师会给你们题库,一些注意的点我会做出文档在这个网址 项目目录预览 - TYUT复习资料:复习资料 - GitCode 希望大家可以给我一些打赏 什么是Spring的IOC和DI IOC 是一种设计思想,它将对象的创建和对象之间的依赖关系…...
Leetcode 139. 单词拆分 动态规划
原题链接:Leetcode 139. 单词拆分 递归,超时 class Solution { public:bool isfind(string s,map<string,int>& mp){for(auto x:mp){string wordx.first;if(sword) return true;int nword.size();if(n>s.size()) continue;string s1s.subs…...
python异常机制
异常是什么? 软件程序在运行过程中,非常可能遇到刚刚提到的这些问题,我们称之为异常,英文是Exception,意思是例外。遇到这些例外情况,或者交异常,我们怎么让写的程序做出合理的处理,…...
运行爬虫时可能遇到哪些常见问题?
在运行Python爬虫时,可能会遇到以下一些常见问题及相应的解决方法: 1. 请求频繁被封 IP 问题描述:爬虫请求频繁时,网站可能会识别到异常行为并封禁 IP,从而导致后续请求失败。解决方法: 使用代理…...
应用升级/灾备测试时使用guarantee 闪回点迅速回退
1.场景 应用要升级,当升级失败时,数据库回退到升级前. 要测试系统,测试完成后,数据库要回退到测试前。 相对于RMAN恢复需要很长时间, 数据库闪回只需要几分钟。 2.技术实现 数据库设置 2个db_recovery参数 创建guarantee闪回点,不需要开启数据库闪回。…...
Leetcode 3577. Count the Number of Computer Unlocking Permutations
Leetcode 3577. Count the Number of Computer Unlocking Permutations 1. 解题思路2. 代码实现 题目链接:3577. Count the Number of Computer Unlocking Permutations 1. 解题思路 这一题其实就是一个脑筋急转弯,要想要能够将所有的电脑解锁&#x…...
如何在看板中有效管理突发紧急任务
在看板中有效管理突发紧急任务需要:设立专门的紧急任务通道、重新调整任务优先级、保持适度的WIP(Work-in-Progress)弹性、优化任务处理流程、提高团队应对突发情况的敏捷性。其中,设立专门的紧急任务通道尤为重要,这能…...
Xen Server服务器释放磁盘空间
disk.sh #!/bin/bashcd /run/sr-mount/e54f0646-ae11-0457-b64f-eba4673b824c # 全部虚拟机物理磁盘文件存储 a$(ls -l | awk {print $NF} | cut -d. -f1) # 使用中的虚拟机物理磁盘文件 b$(xe vm-disk-list --multiple | grep uuid | awk {print $NF})printf "%s\n"…...
Linux nano命令的基本使用
参考资料 GNU nanoを使いこなすnano基础 目录 一. 简介二. 文件打开2.1 普通方式打开文件2.2 只读方式打开文件 三. 文件查看3.1 打开文件时,显示行号3.2 翻页查看 四. 文件编辑4.1 Ctrl K 复制 和 Ctrl U 粘贴4.2 Alt/Esc U 撤回 五. 文件保存与退出5.1 Ctrl …...
uniapp 开发ios, xcode 提交app store connect 和 testflight内测
uniapp 中配置 配置manifest 文档:manifest.json 应用配置 | uni-app官网 hbuilderx中本地打包 下载IOS最新SDK 开发环境 | uni小程序SDK hbulderx 版本号:4.66 对应的sdk版本 4.66 两者必须一致 本地打包的资源导入到SDK 导入资源 | uni小程序SDK …...
Caliper 配置文件解析:fisco-bcos.json
config.yaml 文件 config.yaml 是 Caliper 的主配置文件,通常包含以下内容: test:name: fisco-bcos-test # 测试名称description: Performance test of FISCO-BCOS # 测试描述workers:type: local # 工作进程类型number: 5 # 工作进程数量monitor:type: - docker- pro…...
FFmpeg avformat_open_input函数分析
函数内部的总体流程如下: avformat_open_input 精简后的代码如下: int avformat_open_input(AVFormatContext **ps, const char *filename,ff_const59 AVInputFormat *fmt, AVDictionary **options) {AVFormatContext *s *ps;int i, ret 0;AVDictio…...
QT开发技术【ffmpeg + QAudioOutput】音乐播放器
一、 介绍 使用ffmpeg 4.2.2 在数字化浪潮席卷全球的当下,音视频内容犹如璀璨繁星,点亮了人们的生活与工作。从短视频平台上令人捧腹的搞笑视频,到在线课堂中知识渊博的专家授课,再到影视平台上扣人心弦的高清大片,音…...
二维FDTD算法仿真
二维FDTD算法仿真,并带完全匹配层,输入波形为高斯波、平面波 FDTD_二维/FDTD.zip , 6075 FDTD_二维/FDTD_31.m , 1029 FDTD_二维/FDTD_32.m , 2806 FDTD_二维/FDTD_33.m , 3782 FDTD_二维/FDTD_34.m , 4182 FDTD_二维/FDTD_35.m , 4793...
