当前位置: 首页 > news >正文

面向对象编程在 JavaScript 中的实践

引言

前端开发正随着应用复杂度增加而向更严谨的架构模式演进。JavaScript 作为一种多范式语言,其面向对象特性为构建可维护、可扩展的大型应用提供了强大基础。

一、JavaScript 中的对象模型演化

对象字面量:最基础的封装

对象字面量是 JavaScript 中最简单的对象创建方式,提供了基本的属性和方法封装。

const user = {name: "张三",role: "开发者",permissions: ["read", "write"],hasPermission(permission) {return this.permissions.includes(permission);},describe() {return `${this.name} 是一名 ${this.role}`;}
};console.log(user.describe()); // "张三 是一名 开发者"

对象字面量适用于简单场景,但在需要创建多个相似对象时效率低下,且难以实现继承关系。

构造函数与原型链

构造函数为创建相似对象提供了模板,结合原型链可实现属性和方法的共享。

function User(name, role) {this.name = name;this.role = role;this.permissions = ["read"];
}User.prototype.hasPermission = function(permission) {return this.permissions.includes(permission);
};User.prototype.describe = function() {return `${this.name} 是一名 ${this.role}`;
};// 继承实现
function Admin(name) {User.call(this, name, "管理员");this.permissions.push("write", "delete");
}Admin.prototype = Object.create(User.prototype);
Admin.prototype.constructor = Admin;const developer = new User("李四", "开发者");
const admin = new Admin("王五");console.log(developer.describe()); // "李四 是一名 开发者"
console.log(admin.describe()); // "王五 是一名 管理员"
console.log(admin.hasPermission("delete")); // true

这种模式虽然强大,但原型继承的语法冗长且容易出错,特别是多层继承时。

ES6 Class:现代化的语法糖

ES6 引入的 class 语法提供了更清晰、更接近传统 OOP 的编程体验。

class User {constructor(name, role) {this.name = name;this.role = role;this.permissions = ["read"];}hasPermission(permission) {return this.permissions.includes(permission);}describe() {return `${this.name} 是一名 ${this.role}`;}
}class Admin extends User {constructor(name) {super(name, "管理员");this.permissions.push("write", "delete");}// 方法重写示例describe() {return `${super.describe()} 拥有系统管理权限`;}
}const admin = new Admin("赵六");
console.log(admin.describe()); // "赵六 是一名 管理员 拥有系统管理权限"

二、面向对象核心原则在 JavaScript 中的应用

封装:保护数据与实现

JavaScript 通过闭包和 Symbol 实现真正的私有属性:

// 使用闭包实现私有属性
function createUser(name) {let _password = "default"; // 私有变量return {name,setPassword(pwd) {if (pwd.length < 6) throw new Error("密码长度不足");_password = pwd;},authenticate(pwd) {return pwd === _password;}};
}// 使用 ES2022 私有字段
class BankAccount {#balance = 0; // 私有字段constructor(owner) {this.owner = owner;}deposit(amount) {if (amount <= 0) throw new Error("存款金额必须为正数");this.#balance += amount;return this.#balance;}getBalance() {return this.#balance;}
}const account = new BankAccount("张三");
account.deposit(100);
console.log(account.getBalance()); // 100
// console.log(account.#balance); // 语法错误:私有字段无法从外部访问

继承:代码复用与层次结构

JavaScript 继承可以通过类继承或组合实现:

// 类继承
class Component {constructor(selector) {this.element = document.querySelector(selector);}hide() { this.element.style.display = "none"; }show() { this.element.style.display = "block"; }
}class Button extends Component {constructor(selector, text) {super(selector);this.element.textContent = text;this.element.addEventListener("click", this.onClick.bind(this));}onClick() {console.log("Button clicked");}
}// 组合继承(更灵活)
function withDraggable(BaseComponent) {return class extends BaseComponent {constructor(...args) {super(...args);this.initDraggable();}initDraggable() {let isDragging = false;let offsetX, offsetY;this.element.addEventListener("mousedown", (e) => {isDragging = true;offsetX = e.clientX - this.element.getBoundingClientRect().left;offsetY = e.clientY - this.element.getBoundingClientRect().top;});document.addEventListener("mousemove", (e) => {if (!isDragging) return;this.element.style.left = `${e.clientX - offsetX}px`;this.element.style.top = `${e.clientY - offsetY}px`;});document.addEventListener("mouseup", () => {isDragging = false;});}};
}const DraggableButton = withDraggable(Button);

多态性:接口一致性与行为差异

多态允许不同类通过相同接口提供不同实现:

class Shape {area() {throw new Error("子类必须实现 area 方法");}toString() {return `${this.constructor.name}: 面积 = ${this.area()}`;}
}class Circle extends Shape {constructor(radius) {super();this.radius = radius;}area() {return Math.PI * this.radius ** 2;}
}class Rectangle extends Shape {constructor(width, height) {super();this.width = width;this.height = height;}area() {return this.width * this.height;}
}// 多态性体现:同一个函数处理不同类型
function printArea(shape) {if (!(shape instanceof Shape)) throw new Error("参数必须是 Shape 类型");console.log(shape.toString());
}printArea(new Circle(5)); // "Circle: 面积 = 78.53981633974483"
printArea(new Rectangle(4, 5)); // "Rectangle: 面积 = 20"

三、设计模式在 JavaScript 项目中的应用

单例模式:全局状态管理

// 现代 JavaScript 单例实现
class UserStore {static instance = null;constructor() {if (UserStore.instance) {return UserStore.instance;}this.user = null;this.listeners = [];UserStore.instance = this;}setUser(userData) {this.user = userData;this.notifyListeners();}getUser() {return this.user;}subscribe(listener) {this.listeners.push(listener);return () => {this.listeners = this.listeners.filter(l => l !== listener);};}notifyListeners() {this.listeners.forEach(listener => listener(this.user));}
}const userStore = new UserStore();
export default userStore;

工厂模式:对象创建抽象

// 组件工厂示例
class ComponentFactory {static createComponent(type, props) {switch (type) {case 'button':return new Button(props);case 'input':return new Input(props);case 'modal':return new Modal(props);default:throw new Error(`不支持创建类型: ${type}`);}}
}// 使用工厂创建组件
const loginButton = ComponentFactory.createComponent('button', { text: '登录', onClick: () => console.log('登录点击')
});

观察者模式:事件驱动架构

class EventEmitter {constructor() {this.events = {};}on(event, listener) {if (!this.events[event]) {this.events[event] = [];}this.events[event].push(listener);return () => this.off(event, listener);}off(event, listener) {if (!this.events[event]) return;this.events[event] = this.events[event].filter(l => l !== listener);}emit(event, ...args) {if (!this.events[event]) return;this.events[event].forEach(listener => listener(...args));}once(event, listener) {const onceListener = (...args) => {listener(...args);this.off(event, onceListener);};this.on(event, onceListener);}
}// 在应用中使用事件系统
class TodoApplication extends EventEmitter {constructor() {super();this.todos = [];}addTodo(text) {const todo = {id: Date.now(),text,completed: false};this.todos.push(todo);this.emit('todo:added', todo);}toggleTodo(id) {const todo = this.todos.find(t => t.id === id);if (todo) {todo.completed = !todo.completed;this.emit('todo:toggled', todo);}}
}const app = new TodoApplication();
app.on('todo:added', todo => {console.log(`新任务添加: ${todo.text}`);// 更新 UI
});

四、依赖管理与架构设计

依赖注入实现可测试代码

// 依赖注入示例
class UserService {constructor(apiClient) {this.apiClient = apiClient; // 注入依赖}async getUsers() {return this.apiClient.get('/users');}async getUserById(id) {return this.apiClient.get(`/users/${id}`);}
}// 可以注入不同实现以方便测试
const productionApiClient = {get: async (url) => fetch(url).then(r => r.json())
};const mockApiClient = {get: async (url) => {if (url === '/users') return Promise.resolve([{ id: 1, name: '张三' },{ id: 2, name: '李四' }]);const match = url.match(/\/users\/(\d+)/);if (match) {const id = parseInt(match[1]);return Promise.resolve({ id, name: id === 1 ? '张三' : '李四' });}return Promise.reject(new Error('未找到资源'));}
};// 使用真实依赖
const userService = new UserService(productionApiClient);// 测试环境使用 mock
const testUserService = new UserService(mockApiClient);

模块化与可扩展架构

// 模块接口定义
class ModuleInterface {init() { throw new Error("需实现 init 方法"); }destroy() { throw new Error("需实现 destroy 方法"); }
}// 具体模块实现
class AuthModule extends ModuleInterface {constructor(apiClient, eventBus) {super();this.apiClient = apiClient;this.eventBus = eventBus;this.currentUser = null;}init() {this.checkAuthStatus();this.setupListeners();}destroy() {// 清理资源this.eventBus.off('logout', this.handleLogout);}async checkAuthStatus() {try {const user = await this.apiClient.get('/auth/me');this.setCurrentUser(user);} catch (err) {this.setCurrentUser(null);}}setupListeners() {this.handleLogout = () => this.logout();this.eventBus.on('logout', this.handleLogout);}async login(credentials) {const user = await this.apiClient.post('/auth/login', credentials);this.setCurrentUser(user);return user;}async logout() {await this.apiClient.post('/auth/logout');this.setCurrentUser(null);}setCurrentUser(user) {this.currentUser = user;this.eventBus.emit('auth:changed', user);}
}// 应用程序核心
class Application {constructor() {this.modules = new Map();this.eventBus = new EventEmitter();this.apiClient = {get: async (url) => fetch(url).then(r => r.json()),post: async (url, data) => fetch(url, {method: 'POST',headers: {'Content-Type': 'application/json'},body: JSON.stringify(data)}).then(r => r.json())};}registerModule(name, ModuleClass) {const module = new ModuleClass(this.apiClient, this.eventBus);this.modules.set(name, module);}init() {for (const module of this.modules.values()) {module.init();}}getModule(name) {return this.modules.get(name);}
}// 使用示例
const app = new Application();
app.registerModule('auth', AuthModule);
app.init();// 在任何地方使用认证模块
const authModule = app.getModule('auth');
authModule.login({ username: 'user', password: 'pass' });

五、性能考量与最佳实践

原型链与内存优化

通过原型共享方法,可大幅减少内存占用:

// 不优化:每个实例都有自己的方法副本
function BadUser(name) {this.name = name;this.sayHi = function() { // 每个实例都创建一个新函数return `你好,我是 ${this.name}`;};
}// 优化:所有实例共享同一方法
function GoodUser(name) {this.name = name;
}
GoodUser.prototype.sayHi = function() {return `你好,我是 ${this.name}`;
};// 性能测试
function testMemory(Constructor, count) {const instances = [];for (let i = 0; i < count; i++) {instances.push(new Constructor(`用户${i}`));}return instances;
}// 创建 10000 个实例进行对比
const badUsers = testMemory(BadUser, 10000); // 内存占用更高
const goodUsers = testMemory(GoodUser, 10000); // 内存占用更低

什么时候不应该使用 OOP

对象系统也有其局限性:

// 适合函数式处理的例子
const numbers = [1, 2, 3, 4, 5];// 函数式写法 - 简洁明了
const doubled = numbers.map(n => n * 2);
const sum = numbers.reduce((acc, n) => acc + n, 0);// OOP 写法 - 过度设计
class NumberCollection {constructor(numbers) {this.numbers = numbers;}map(transform) {return new NumberCollection(this.numbers.map(transform));}sum() {return this.numbers.reduce((acc, n) => acc + n, 0);}
}const collection = new NumberCollection(numbers);
const doubledOOP = collection.map(n => n * 2).numbers;
const sumOOP = collection.sum();

总结

面向对象编程为 JavaScript 提供了强大的结构化工具,从简单的对象字面量到现代化的 ES6 类语法。我们可以根据项目需求选择合适的抽象级别。在大型应用架构中,恰当运用封装、继承和多态原则,结合设计模式实践,才可以构建出既灵活又健壮的系统。

JavaScript 的面向对象编程需要结合语言的动态特性与函数式编程范式,形成一种平衡的开发方法。掌握这些技巧才能在实际项目中构建出经得起时间考验的代码库。

参考资源

官方文档

  • MDN Web Docs - JavaScript 类 - Mozilla 的官方文档,详细介绍 ES6 类语法
  • ECMAScript 规范 - JavaScript 语言的官方规范文档
  • TypeScript 文档 - 为 JavaScript 提供类型系统的超集,增强 OOP 开发体验

在线教程

  • JavaScript.info - 现代 JavaScript 教程,包含详细的 OOP 解释
  • Egghead.io - 面向对象的 JavaScript
  • Frontend Masters - JavaScript: 从基础到函数式到 OOP

社区资源

  • JavaScript 周刊 - 定期更新的 JavaScript 新闻和文章
  • DEV Community - 开发者社区的 JavaScript 讨论
  • Stack Overflow - JavaScript OOP 相关问答

如果你觉得这篇文章有帮助,欢迎点赞收藏,也期待在评论区看到你的想法和建议!👇

终身学习,共同成长。

咱们下一期见

💻

相关文章:

面向对象编程在 JavaScript 中的实践

引言 前端开发正随着应用复杂度增加而向更严谨的架构模式演进。JavaScript 作为一种多范式语言&#xff0c;其面向对象特性为构建可维护、可扩展的大型应用提供了强大基础。 一、JavaScript 中的对象模型演化 对象字面量&#xff1a;最基础的封装 对象字面量是 JavaScript …...

Android 内存溢出(OOM)的 Kotlin 排查与优化指南

内存溢出&#xff08;Out Of Memory, OOM&#xff09;是 Android 开发中常见且棘手的问题&#xff0c;尤其在处理大图、复杂数据或内存泄漏时。本文将通过 Kotlin 代码示例 和工具使用&#xff0c;提供一套比较完整的排查与优化方案。 一、检测工具&#xff1a;定位内存问题根源…...

Docker常用命令介绍

Docker常用命令 1、本地镜像管理 save 命令 将一个或多个 Docker 镜像保存到一个 tar 归档文件中&#xff0c;以便在其他环境中分发或备份。 # 语法&#xff1a;docker save [OPTIONS] IMAGE [IMAGE...]# 保存单个镜像到文件 docker save -o myimage.tar myimage:latest# 保…...

(高级)高级前端开发者指南:框架运用与综合实战

当您已经掌握了HTML5、CSS3和JavaScript的基础知识后&#xff0c;接下来就是学习现代前端框架和性能优化的高级阶段。本文将重点介绍Vue.js/React的组件化开发、状态管理和路由配置&#xff0c;以及前端性能优化的核心技巧。通过丰富的代码示例和详细讲解&#xff0c;帮助您在实…...

边缘计算正在重新定义物联网的未来——你的设备还在“等云“吗?⚡

“数据不动算法动,算法不动代码动”——这句话正在成为物联网时代的新铁律。 当我们谈论物联网设备性能优化时,大多数开发者第一反应还是"上云"。但现实往往残酷:网络延迟让实时控制变成了"实时等待",带宽成本让企业CFO眉头紧锁,数据安全让合规部门夜…...

std::initialzer_list 与花括号{}数据列表

author: hjjdebug date: 2025年 05月 22日 星期四 15:50:23 CST descrip: std::initialzer_list 与花括号{}数据列表 文章目录 1.{数值列表}是什么?1.1 数组初始化 时 &#xff0c; 称为数组初始化列表1.2. 当用于容器时, 称为容器初始化列表1.3. 对于结构体或类&#xff0c;{…...

C++初阶-list的使用2

目录 1.std::list::splice的使用 2.std::list::remove和std::list::remove_if的使用 2.1remove_if函数的简单介绍 基本用法 函数原型 使用函数对象作为谓词 使用普通函数作为谓词 注意事项 复杂对象示例 2.2remove与remove_if的简单使用 3.std::list::unique的使用 …...

从单链表 list 中删除第 i 个元素--Python

从单链表 list 中删除第 i 个元素 一、问题引入二、解题步骤1.思维导图2.解题步骤 三、代码实现四、个人总结 一、问题引入 请编写程序&#xff0c;将 n 个整数顺次插入一个初始为空的单链表的表头。随后对任意给定的位序 i&#xff0c;删除链表中第 i 个结点。注意&#xff1…...

GraphPad Prism工作表的基本操作

《2025新书现货 GraphPad Prism图表可视化与统计数据分析&#xff08;视频教学版&#xff09;雍杨 康巧昆 清华大学出版社教材书籍 9787302686460 GraphPadPrism图表可视化 无规格》【摘要 书评 试读】- 京东图书 GraphPad Prism中包含5种工作表&#xff0c;每种工作表的基本操…...

C++初阶-list的使用1

目录 1.std::list简介 2.成员函数 2.1构造函数的使用 2.2list::operator的使用 3.迭代器 4.容量 4.1list::empty函数的使用 4.2list::size函数的使用 4.3list::max_size函数的使用 5.元素访问 6.修饰符 6.1list::assign函数的使用 6.2push_back和pop_back和push_fr…...

文献解读-病理影像多模态模型预测乳腺癌新辅助化疗的病理完全反应

期刊&#xff1a;Science Advances 影响因子&#xff1a;11.7&#xff0c;中科院1区Top 发表时间&#xff1a;2025年4月30日 概要&#xff1a;首都医科大学宣武医院放射科卢洁教授团队近日&#xff08;2025年5月&#xff09;在中科院1区top期刊《Sci Adv》&#xff08;IF11.7&a…...

Docker-Mysql

查看容器的详细信息 docker inspect mysql-8.4.5 Docker 启动 local-mysql 的完整命令 docker run -d \--name local-mysql \-e MYSQL_ROOT_PASSWORDyour_root_password \-v /AllenDocker/mysql/data:/var/lib/mysql \-p 3306:3306 \--restart unless-stopped \mysql:8.4.5 验…...

鸿蒙进阶——CMakelist、GN语法简介及三方库通用移植指南

文章大纲 引言一、GN常用的内置变量二、GN常用的内置函数三、CMake 重要语法1、生成动态库2、生成静态库3、生成OBJECT 库4、重要的函数和模块4.1、add_definitions4.2、execute_process4.3、add_dependencies4.4、install4.5、FetchContent 四、GN 重要语法1、编译Target2、预…...

场景化应用实战系列六:检索问答系统

目录 景化应用实战系列六&#xff1a;检索问答系统 一、目标设定 二、关键知识点梳理 三、案例讲解与实战操作 1. 数据准备与预处理 2. 倒排表构建 3. 文本相似度计算 4. 检索问答系统实现 5. 系统优化与改进 一、目标设定 构建一个高效的检索问答系统&#xff0c;能…...

3452. 好数字之和

​题目来源&#xff1a; LeetCode题目&#xff1a;3452. 好数字之和 - 力扣&#xff08;LeetCode&#xff09; 解题思路&#xff1a; 按要求判断求和即可。 解题代码&#xff1a; #python3 class Solution:def sumOfGoodNumbers(self, nums: List[int], k: int) -> int:r…...

GEE数据下载问题记录

GEE下载数据时的一些记录 1. GPT说 2. 验证 在未指定投影坐标系的情况下&#xff0c;下载原始数据导出的是MODIS Sinusoidal投影&#xff0c;如果单纯的对波段值进行操作&#xff0c;不会进行投影转换&#xff0c;如果涉及到波段平均&#xff0c;则会转投影到WGS84坐标系。如…...

P1833 樱花

P1833 樱花 - 洛谷 题目背景 《爱与愁的故事第四弹plant》第一章。 题目的描述 爱与愁大神后院里种了n棵樱花树&#xff0c;每棵都有美学值Ci​(0≤Ci​≤200)。爱与愁大神在每天上学前都会来赏花。爱与愁大神可是生物学霸&#xff0c;他懂得如何欣赏樱花&#xff1a;一种樱…...

文件操作和IO-3 文件内容的读写

文件内容的读写——数据流 流是操作系统提供的概念&#xff0c;Java对操作系统的流进行了封装。 数据流就像水流&#xff0c;生生不息&#xff0c;绵延不断。 水流的特点&#xff1a;比如要100mL的水&#xff0c;可以一次接10mL&#xff0c;分10次接完&#xff0c;也可以一次接…...

Day 0015:Metasploit 基础解析

目录 一、理论学习&#xff08;Metasploit 架构与核心组件&#xff09; 一、架构设计&#xff1a;分层与模块化 基础层&#xff08;Ruby 框架&#xff09;&#xff1a; 核心层&#xff08;模块引擎&#xff09;&#xff1a; 接口层&#xff08;交互界面&#xff09;&#…...

相机标定与图像处理涉及的核心坐标系

坐标系相互关系 #mermaid-svg-QxaMjIcgWVap0awV {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-QxaMjIcgWVap0awV .error-icon{fill:#552222;}#mermaid-svg-QxaMjIcgWVap0awV .error-text{fill:#552222;stroke:#552…...

单例模式的运用

单例模式实现分析 在我们的向量数据库配置类 MilvusVectorDatabaseConfig 中&#xff0c;采用了单例模式的实现方式&#xff0c;这是一种非常经典且实用的设计模式。 饿汉式单例实现 这种实现方式属于饿汉式单例模式&#xff0c;它的优点在于&#xff1a; // 在类加载时就创…...

PageHelper分页原理解析:从源码到MySQL方言实现

一、引言 分页查询是Web开发的必备功能&#xff0c;MyBatis生态中的PageHelper以其简单易用的特性广受欢迎。本文将从源码层面&#xff08;v5.3.2&#xff09;解析PageHelper的分页实现机制&#xff0c;结合MySQL方言展示完整的执行链路。 二、核心实现原理 1. 插件初始化 …...

MySQL中索引最左前缀法则、索引失效情况、前缀索引、索引设计原则

最左前缀法则 联合索引中&#xff0c;最左前缀法则指的是查询从索引的最左列开始&#xff0c;并且不跳过索引中的列&#xff0c;如果跳跃某一列&#xff0c;索引将会部分失效&#xff08;后面的字段索引失效&#xff09;举例假设有一个联合索引包含三个字段按顺序&#xff1a;…...

pdf图片导出(Visio和Origin)

一、Visio 导入pdf格式图片 1. 设计->大小&#xff0c;适应绘图。 2. 文件->导出&#xff0c;导出为pdf格式。 上面两部即可得到只包含图的部分的pdf格式。 如果出现的有默认白边&#xff0c;可以通过以下方式设置&#xff1a; 1. 文件->选项->自定义功能区->…...

NR 通讯的整体架构

前言&#xff1a; 并假设发射器发送了一个信号&#xff0c;如左下角所示&#xff08;蓝色&#xff09;&#xff0c;接收器检测到的信号显示在右侧&#xff08;红色&#xff09;。您在图中注意到的第一件事是什么&#xff1f;那就是发送的信号和接收的信号并不完全相同。 有什么…...

【大模型面试每日一题】Day 26:从伦理角度,大模型可能存在哪些潜在风险?技术上如何实现内容安全控制(如RLHF、红队测试)?

【大模型面试每日一题】Day 26&#xff1a;从伦理角度&#xff0c;大模型可能存在哪些潜在风险&#xff1f;技术上如何实现内容安全控制&#xff08;如RLHF、红队测试&#xff09;&#xff1f; &#x1f4cc; 题目重现 &#x1f31f;&#x1f31f; 面试官:从伦理角度&#xf…...

第六届电子通讯与人工智能国际学术会议(ICECAI 2025)

在数字化浪潮中&#xff0c;电子通讯与人工智能的融合正悄然重塑世界的运行逻辑。技术基础的共生关系是这场变革的核心——电子通讯如同“信息高速公路”&#xff0c;通过5G等高速传输技术&#xff0c;将海量数据实时输送至AI系统&#xff0c;使其能够像人类神经系统般快速响应…...

深入剖析 5G 核心网中的 PLMN

一、引言 在 5G 技术迅猛发展的当下,5G 核心网作为整个通信系统的关键枢纽,支撑着海量数据传输、低延迟通信以及多样化业务应用。其中,公共陆地移动网络(Public Land Mobile Network,PLMN)扮演着极为重要的角色,它是 5G 核心网实现用户接入、网络管理以及业务提供的基础…...

佰力博科技与您探讨半导体电阻测试常用的一些方法

一、两探针法​ 两探针法是一种较为基础的测试方法。该方法将两根探针与半导体样品表面紧密接触&#xff0c;通过电源在两根探针之间施加电压&#xff0c;同时使用电流表测量通过样品的电流&#xff0c;再根据欧姆定律计算电阻。​这种方法的优点在于操作简单、设备要求较低&a…...

5G 核心网中的 NPN 功能详解

引言 在 5G 技术飞速发展的今天,5G 核心网不断演进,为各类应用场景提供强大支撑。其中,NPN(Non-Public Network,非公共网络)功能作为 5G 核心网的重要特性,正逐渐崭露头角,在众多行业中发挥着关键作用。它为特定用户或组织打造专属网络环境,满足其对网络性能、安全性…...

谷歌medgemma-27b-text-it医疗大模型论文速读:多语言大型语言模型医学问答基准测试MedExpQA

《MedExpQA: 多语言大型语言模型医学问答基准测试》论文解析 一、引言 论文开篇指出大型语言模型&#xff08;LLMs&#xff09;在医学领域的巨大潜力&#xff0c;尤其是在医学问答&#xff08;QA&#xff09;方面。尽管LLMs在医学执照考试等场景中取得了令人瞩目的成绩&#…...

# 深入解析BERT自然语言处理框架:原理、结构与应用

深入解析BERT自然语言处理框架&#xff1a;原理、结构与应用 在自然语言处理&#xff08;NLP&#xff09;领域&#xff0c;BERT&#xff08;Bidirectional Encoder Representations from Transformers&#xff09;框架的出现无疑是一个重要的里程碑。它凭借其强大的语言表示能…...

js中encodeURIComponent函数使用场景

encodeURIComponent 是 JavaScript 中的一个内置函数&#xff0c;它的作用是&#xff1a; 将字符串编码为可以安全放入 URL 的形式。 ✅ 为什么需要它&#xff1f; URL 中有一些字符是有特殊意义的&#xff0c;比如&#xff1a; ? 用来开始查询参数 & 分隔多个参数 连接…...

【NLP 77、Python环境管理工具之conda】

如果你第一万次否定自己&#xff0c;那我希望我可以一万零一次大声称赞你 —— 25.5.22 一、什么是conda conda是一个开源的包管理系统和环境管理系统&#xff0c;主要用于Python语言&#xff0c;但也可以用于其它语言的项目 二、为什么要使用conda ① 多环境共存&#xff0c;多…...

替代云数据库的本地方案:MySQL+phpMyAdmin的远程管理与跨网络访问技术

文章目录 前言1. 安装MySQL2. 安装phpMyAdmin3. 修改User表4. 本地测试连接MySQL5. 安装cpolar内网穿透6. 配置MySQL公网访问地址7. 配置MySQL固定公网地址8. 配置phpMyAdmin公网地址9. 配置phpmyadmin固定公网地址 前言 对于运维来说&#xff0c;平时还好&#xff0c;一旦出门…...

Dify大语言模型应用开发环境搭建:打造个性化本地LLM应用开发工作台

文章目录 前言1. Docker部署Dify2. 本地访问Dify3. Ubuntu安装Cpolar4. 配置公网地址5. 远程访问6. 固定Cpolar公网地址7. 固定地址访问 前言 各位小伙伴们&#xff0c;大家好&#xff01;今天我们要来一场技术大冒险&#xff0c;手把手教你如何在Linux Ubuntu系统上使用Docke…...

MySQL索引事务

索引 通过索引可以对查询操作进行优化&#xff0c;通过减少全表扫描&#xff0c;快速定位数据&#xff0c;原本的查询操作是对表进行遍历&#xff0c;如果是大表效率较低 1&#xff09;注意事项 占用了更多的空间&#xff0c;由于生成索引需要依赖于数据结构和额外数据&…...

Seay代码审计工具

Seay代码审计工具 介绍 Seay代码审计工具是一款由国内安全研究人员"Seay"开发的源代码安全审计工具&#xff0c;主要用于帮助安全人员快速发现PHP代码中的安全漏洞&#xff0c;快速定位代码中的安全风险点。 主要功能特点 自动化审计功能 支持自动扫描PHP代码中的…...

【人工智障生成日记1】从零开始训练本地小语言模型

&#x1f3af; 从零开始训练本地小语言模型&#xff1a;MiniGPT TinyStories&#xff08;4090Ti&#xff09; &#x1f9ed; 项目背景 本项目旨在以学习为目的&#xff0c;从头构建一个完整的本地语言模型训练管线。目标是&#xff1a; ✅ 不依赖外部云计算✅ 完全本地运行…...

技术分享:大数据挖掘平台架构设计与行业应用实践

在数字化转型浪潮下&#xff0c;企业数据规模呈指数级增长。如何构建高效的数据挖掘体系&#xff0c;实现数据价值变现&#xff0c;成为技术团队面临的重要课题。本文将深入探讨大数据挖掘平台的核心架构、关键技术及行业应用实践。 一、平台架构设计 1. 数据采集层 支持多源异…...

线性Wi-Fi FEM被卷死,非线性FEM是未来?

在跑了一圈路由器客户之后&#xff0c;我的内心反而平静下来&#xff0c;被卷死的不只是Wi-Fi FEM赛道&#xff0c;还有家用路由器市场。 尽管路由器市场比较惨淡&#xff0c;不过客户还是很愿意接见我&#xff0c;并做更广泛的交流和探讨。一方面之前推Wi-Fi FEM的众多厂商在渐…...

OpenCV CUDA模块图像过滤------用于创建一个最小值盒式滤波器(Minimum Box Filter)函数createBoxMinFilter()

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 该函数创建的是一个 最小值滤波器&#xff08;Minimum Filter&#xff09;&#xff0c;它对图像中每个像素邻域内的像素值取最小值。常用于&…...

【MySQL】06.MySQL表的增删查改

1. insert 我们先创建一个表结构&#xff0c;这部分操作我们使用这张表完成我们的操作&#xff1a; mysql> create table student(-> id int primary key auto_increment,-> name varchar(20) not null,-> qq varchar(20) unique-> ); Query OK, 0 rows affec…...

MySQL 索引失效及其解决办法

一、前言 在数据库优化中,索引(Index)是一项至关重要的技术手段,可以显著提升查询性能。然而,在实际开发过程中,MySQL 索引并不总是如预期生效。本文将从原理出发,系统地介绍索引失效的常见场景及其解决方案,帮助开发者有效规避性能陷阱。 二、索引基础回顾 MySQL 支…...

在线时间戳(Unix TimeStamp)转换器

做了一个在线时间戳转换器&#xff0c;简单、好用&#xff0c;提供多种日期格式。 移动端友好。 目标是做一套在线工具集&#xff0c;时间戳转换只是第一步。 欢迎试用...

flutter 项目调试、flutter run --debug调试模式 devtools界面说明

Flutter DevTools 网页界面说明 1. 顶部导航栏 Inspector&#xff1a;查看和调试 Widget 树&#xff0c;实时定位 UI 问题。Performance-- 性能分析面板&#xff0c;查看帧率、CPU 和 GPU 使用情况&#xff0c;识别卡顿和性能瓶颈。Memory-- 内存使用和对象分配分析&#xff…...

Qt C++实现马的遍历问题

在这个项目中,我们面对的是一个基于中国象棋的马的遍历问题,使用了C++编程语言,并结合了Qt5库来实现图形界面和棋盘的绘制。以下是这个项目涉及的关键知识点: 马的移动规则:马在象棋中具有独特的“日”字形移动方式,即每次可以向前、后、左或右移动一格,然后在同一行或同…...

web第六次课后作业--使用ApiFox实现请求响应操作

一、实体参数 1.1 简单实体参数 1.2 复杂实体对象 如果请求参数比较多&#xff0c;通过上述的方式一个参数一个参数的接收会比较繁琐。此时&#xff0c;我们可以考虑将请求参数封装到一个实体类对象中。 要想完成数据封装&#xff0c;需要遵守如下规则&#xff1a;请求参数名…...

第十周作业

一、CSRF 1、DVWA-High等级 2、使用Burp生成CSRF利用POC并实现攻击 二、SSRF&#xff1a;file_get_content实验&#xff0c;要求获取ssrf.php的源码 三、RCE 1、 ThinkPHP 2、 Weblogic 3、Shiro...

Excel合并单元格后,如何自动批量生成序号列

1.选择整列 2.组合键&#xff1a;CtrlG 3.定位条件&#xff0c;选择“空值” 4.在第一个框中输入“MAX(”&#xff0c;鼠标选中A1框&#xff0c;后加“&#xff1a;”&#xff0c;鼠标选中前方“A1”&#xff0c;按“F4”绝对引用&#xff0c;补全右括号&#xff0c;后输入“1…...