JavaScript学习教程,从入门到精通, JavaScript 函数全面解析与案例实践(11)
JavaScript 函数全面解析与案例实践
项目导读
JavaScript 函数是编程中的核心概念,是执行特定任务的代码块。本教程将全面讲解函数的定义、参数、返回值及调用方式,并通过实际案例加深理解。
学习目标
- 掌握 JavaScript 函数的定义与调用方法
- 理解函数参数的不同形式和使用场景
- 熟悉函数返回值的应用
- 能够编写实用的函数解决实际问题
素质目标
- 培养模块化编程思维
- 提升代码复用意识
- 增强问题分解能力
一、函数的定义
1. 函数声明
// 函数声明 (具有函数提升特性)
function functionName(parameters) {// 函数体return value; // 可选
}
2. 函数表达式
// 函数表达式 (无函数提升)
const functionName = function(parameters) {// 函数体
};
3. 箭头函数 (ES6)
// 箭头函数
const functionName = (parameters) => {// 函数体
};// 单行箭头函数可省略大括号和return
const square = x => x * x;
二、函数参数
1. 形参与实参
function greet(name) { // name是形参console.log(`Hello, ${name}!`);
}greet('Alice'); // 'Alice'是实参
2. 默认参数 (ES6)
function createUser(name, role = 'user') {console.log(`Name: ${name}, Role: ${role}`);
}createUser('Bob'); // Name: Bob, Role: user
createUser('Alice', 'admin'); // Name: Alice, Role: admin
3. 剩余参数 (…rest)
function sum(...numbers) {return numbers.reduce((total, num) => total + num, 0);
}console.log(sum(1, 2, 3)); // 6
console.log(sum(1, 2, 3, 4, 5)); // 15
三、函数返回值
1. 基本返回值
function add(a, b) {return a + b; // 返回两数之和
}const result = add(3, 5); // 8
2. 多返回值的处理
function getSize(width, height, depth) {const area = width * height;const volume = width * height * depth;return [area, volume]; // 返回数组
}const [area, volume] = getSize(2, 3, 4); // 解构赋值
3. 无返回值函数
function logMessage(message) {console.log(`[LOG]: ${message}`);// 无return语句,默认返回undefined
}const result = logMessage('Test'); // 输出日志,result为undefined
四、函数调用
1. 直接调用
function sayHello() {console.log('Hello!');
}sayHello(); // 直接调用
2. 方法调用
const calculator = {add: function(a, b) {return a + b;}
};calculator.add(2, 3); // 5
3. 构造函数调用
function Person(name) {this.name = name;
}const person = new Person('Alice'); // 构造函数调用
4. 通过call/apply调用
function introduce(lang1, lang2) {console.log(`My name is ${this.name}, I know ${lang1} and ${lang2}`);
}const person = { name: 'Bob' };
introduce.call(person, 'JavaScript', 'Python');
introduce.apply(person, ['Java', 'C++']);
【示例】获取手机价格 - 综合案例
/*** 计算手机总价* @param {string} model - 手机型号* @param {number} quantity - 购买数量* @param {number} [discount=0] - 折扣率(0-1)* @returns {object} 包含原始总价和折后总价的对象*/
function calculatePhonePrice(model, quantity, discount = 0) {// 手机价格表const priceList = {'iPhone15': 7999,'GalaxyS23': 6999,'Mi14': 3999,'P60': 5999};// 检查型号是否有效if (!priceList.hasOwnProperty(model)) {throw new Error(`未知的手机型号: ${model}`);}// 检查数量是否有效if (quantity <= 0 || !Number.isInteger(quantity)) {throw new Error('购买数量必须是正整数');}// 检查折扣是否有效if (discount < 0 || discount > 1) {throw new Error('折扣率必须在0-1之间');}// 计算价格const unitPrice = priceList[model];const originalTotal = unitPrice * quantity;const discountedTotal = originalTotal * (1 - discount);// 返回结果对象return {model,unitPrice,quantity,originalTotal,discountRate: discount,discountedTotal,savings: originalTotal - discountedTotal};
}// 使用示例
try {const order1 = calculatePhonePrice('iPhone15', 2);console.log('订单1(无折扣):', order1);const order2 = calculatePhonePrice('Mi14', 3, 0.1);console.log('订单2(9折):', order2);// 测试错误情况// const order3 = calculatePhonePrice('Unknown', 1); // 会抛出错误// const order4 = calculatePhonePrice('GalaxyS23', -2); // 会抛出错误
} catch (error) {console.error('下单失败:', error.message);
}
案例代码解析:
-
参数处理:
- 必需参数:
model
和quantity
- 可选参数:
discount
有默认值0 - 使用对象存储价格表,便于扩展
- 必需参数:
-
输入验证:
- 检查手机型号是否存在
- 检查购买数量是否为正整数
- 检查折扣率是否在合理范围内
-
计算逻辑:
- 计算原始总价和折后总价
- 返回包含详细信息的对象
-
错误处理:
- 使用try-catch捕获可能的错误
- 提供清晰的错误信息
-
文档注释:
- 使用JSDoc标注参数和返回值类型
- 增强代码可读性和可维护性
总结
JavaScript函数是构建复杂应用的基石,掌握函数的各种定义方式、参数处理技巧和返回值应用,能够显著提高代码质量和开发效率。通过实际的手机价格计算案例,我们展示了如何将理论知识转化为实用代码,包括参数验证、业务逻辑和错误处理等关键技能。
案例代码
以下是 5 个具有实际开发价值的 JavaScript 函数案例,涵盖常见业务场景,每个案例都包含详细注释和实现思路。
案例 1:表单验证工具函数
/*** 表单验证工具* @param {Object} formData - 表单数据对象 {field1: value1, field2: value2}* @param {Object} rules - 验证规则 {field1: [rule1, rule2], field2: [rule1]}* @returns {Object} 验证结果 {isValid: Boolean, errors: {field1: '错误信息'}}*/
function validateForm(formData, rules) {const errors = {};let isValid = true;// 内置验证规则const validators = {required: (value) => !!value || '必填字段',email: (value) => /.+@.+\..+/.test(value) || '邮箱格式不正确',minLength: (min) => (value) => value.length >= min || `至少需要${min}个字符`,phone: (value) => /^1[3-9]\d{9}$/.test(value) || '手机号格式不正确'};Object.keys(rules).forEach(field => {const value = formData[field];rules[field].forEach(rule => {// 处理字符串规则如 'required'if (typeof rule === 'string') {if (!validators[rule](value)) {errors[field] = validators[rule](value);isValid = false;}} // 处理对象规则如 {minLength: 6}else if (typeof rule === 'object') {const [ruleName, param] = Object.entries(rule)[0];if (!validators[ruleName](param)(value)) {errors[field] = validators[ruleName](param)(value);isValid = false;}}});});return { isValid, errors };
}// 使用示例
const form = {username: 'test',email: 'test@',phone: '13812345678',password: '123'
};const rules = {username: ['required', { minLength: 4 }],email: ['required', 'email'],phone: ['required', 'phone'],password: ['required', { minLength: 6 }]
};const result = validateForm(form, rules);
console.log(result);
/*
{isValid: false,errors: {username: "至少需要4个字符",email: "邮箱格式不正确",password: "至少需要6个字符"}
}
*/
案例 2:API 请求封装
/*** 封装fetch请求* @param {string} url - 请求地址* @param {string} method - 请求方法(GET/POST等)* @param {Object} data - 请求数据* @param {Object} headers - 自定义请求头* @param {number} timeout - 超时时间(毫秒)* @returns {Promise} 包含响应数据的Promise*/
async function request({url,method = 'GET',data = {},headers = {},timeout = 5000
}) {// 处理GET请求的URL参数if (method === 'GET') {const params = new URLSearchParams(data).toString();url = params ? `${url}?${params}` : url;}// 创建AbortController用于超时控制const controller = new AbortController();const timer = setTimeout(() => controller.abort(), timeout);try {const options = {method,headers: {'Content-Type': 'application/json',...headers},signal: controller.signal};// POST请求添加请求体if (method !== 'GET') {options.body = JSON.stringify(data);}const response = await fetch(url, options);clearTimeout(timer);if (!response.ok) {throw new Error(`HTTP error! status: ${response.status}`);}const contentType = response.headers.get('content-type');if (contentType && contentType.includes('application/json')) {return await response.json();}return await response.text();} catch (error) {clearTimeout(timer);if (error.name === 'AbortError') {throw new Error(`请求超时 (${timeout}ms)`);}throw error;}
}// 使用示例
async function fetchUserData() {try {// GET请求const users = await request({url: 'https://api.example.com/users',params: { page: 1, limit: 10 }});// POST请求const newUser = await request({url: 'https://api.example.com/users',method: 'POST',data: { name: 'John', age: 30 }});console.log('Users:', users);console.log('New user:', newUser);} catch (error) {console.error('请求失败:', error.message);}
}fetchUserData();
案例 3:购物车计算函数
/*** 计算购物车总价* @param {Array} cartItems - 购物车商品数组* @param {Object} discount - 折扣信息* @returns {Object} 计算结果*/
function calculateCartTotal(cartItems, discount = { type: 'none', value: 0 }) {// 计算小计const subtotal = cartItems.reduce((sum, item) => {return sum + (item.price * item.quantity);}, 0);// 计算折扣let discountAmount = 0;switch (discount.type) {case 'percentage':discountAmount = subtotal * (discount.value / 100);break;case 'fixed':discountAmount = Math.min(discount.value, subtotal);break;case 'coupon':// 假设优惠券逻辑更复杂,这里简化处理discountAmount = subtotal >= 100 ? 20 : 0;break;}// 计算运费 (满100免运费)const shippingFee = subtotal - discountAmount >= 100 ? 0 : 10;// 计算总价const total = subtotal - discountAmount + shippingFee;return {subtotal: formatCurrency(subtotal),discount: formatCurrency(discountAmount),shippingFee: formatCurrency(shippingFee),total: formatCurrency(total),breakdown: {subtotalRaw: subtotal,discountRaw: discountAmount,shippingFeeRaw: shippingFee,totalRaw: total}};
}// 辅助函数:格式化货币
function formatCurrency(amount) {return '$' + amount.toFixed(2);
}// 使用示例
const cartItems = [{ id: 1, name: 'T-Shirt', price: 25.99, quantity: 2 },{ id: 2, name: 'Jeans', price: 49.99, quantity: 1 },{ id: 3, name: 'Socks', price: 8.5, quantity: 3 }
];// 测试不同折扣场景
console.log('无折扣:', calculateCartTotal(cartItems));
console.log('8折优惠:', calculateCartTotal(cartItems, { type: 'percentage', value: 20 }));
console.log('满减优惠:', calculateCartTotal(cartItems, { type: 'fixed', value: 15 }));
console.log('优惠券:', calculateCartTotal(cartItems, { type: 'coupon' }));
案例 4:数据缓存函数
/*** 带缓存功能的异步数据获取* @param {string} key - 缓存键* @param {Function} fetchFn - 数据获取函数(返回Promise)* @param {number} ttl - 缓存有效期(毫秒)* @returns {Promise} 数据Promise*/
function createCachedFetch(key, fetchFn, ttl = 60000) {const cache = {data: null,timestamp: 0,isFetching: false,queue: []};return async function() {const now = Date.now();// 缓存有效且存在,直接返回缓存数据if (cache.data && now - cache.timestamp < ttl) {return Promise.resolve(cache.data);}// 如果正在请求中,加入队列等待结果if (cache.isFetching) {return new Promise((resolve) => {cache.queue.push(resolve);});}// 设置获取状态cache.isFetching = true;try {const data = await fetchFn();cache.data = data;cache.timestamp = Date.now();// 通知所有等待的请求cache.queue.forEach(resolve => resolve(data));cache.queue = [];return data;} catch (error) {// 出错时清除获取状态,但不更新缓存cache.isFetching = false;cache.queue = [];throw error;} finally {cache.isFetching = false;}};
}// 使用示例
// 模拟API请求函数
async function fetchUserData() {console.log('实际发起API请求');// 模拟网络延迟await new Promise(resolve => setTimeout(resolve, 1000));return { id: 1, name: 'John Doe', timestamp: Date.now() };
}// 创建带缓存的函数
const cachedFetchUser = createCachedFetch('userData', fetchUserData, 5000);// 测试
async function test() {// 第一次调用会发起实际请求console.log('第一次调用:', await cachedFetchUser());// 5秒内再次调用会使用缓存console.log('第二次调用(立即):', await cachedFetchUser());// 模拟6秒后再次调用await new Promise(resolve => setTimeout(resolve, 6000));console.log('第三次调用(6秒后):', await cachedFetchUser());// 测试并发请求console.log('并发测试:');await Promise.all([cachedFetchUser().then(data => console.log('请求1:', data)),cachedFetchUser().then(data => console.log('请求2:', data)),cachedFetchUser().then(data => console.log('请求3:', data))]);
}test();
案例 5:DOM 操作工具函数
/*** DOM操作工具集*/
const dom = {/*** 创建元素* @param {string} tag - 标签名* @param {Object} attributes - 属性对象* @param {Array|string} children - 子元素或文本* @returns {HTMLElement} 创建的元素*/create(tag, attributes = {}, children = []) {const el = document.createElement(tag);// 设置属性for (const [key, value] of Object.entries(attributes)) {if (key === 'className') {el.className = value;} else if (key === 'style' && typeof value === 'object') {Object.assign(el.style, value);} else if (key.startsWith('on') && typeof value === 'function') {el.addEventListener(key.substring(2), value);} else {el.setAttribute(key, value);}}// 添加子元素if (typeof children === 'string') {el.textContent = children;} else if (Array.isArray(children)) {children.forEach(child => {if (typeof child === 'string') {el.appendChild(document.createTextNode(child));} else if (child instanceof HTMLElement) {el.appendChild(child);}});}return el;},/*** 查找元素* @param {string} selector - CSS选择器* @param {HTMLElement} parent - 父元素(默认document)* @returns {HTMLElement|null} 找到的元素*/find(selector, parent = document) {return parent.querySelector(selector);},/*** 查找所有匹配元素* @param {string} selector - CSS选择器* @param {HTMLElement} parent - 父元素(默认document)* @returns {NodeList} 元素列表*/findAll(selector, parent = document) {return parent.querySelectorAll(selector);},/*** 添加事件委托* @param {string} event - 事件类型* @param {string} selector - 目标元素选择器* @param {Function} handler - 事件处理函数* @param {HTMLElement} parent - 委托父元素(默认document)*/delegate(event, selector, handler, parent = document) {parent.addEventListener(event, (e) => {let target = e.target;while (target && target !== parent) {if (target.matches(selector)) {handler.call(target, e);break;}target = target.parentNode;}});},/*** 切换元素显示/隐藏* @param {HTMLElement} element - 目标元素* @param {boolean} [show] - 强制显示或隐藏(可选)*/toggle(element, show) {if (typeof show === 'boolean') {element.style.display = show ? '' : 'none';} else {element.style.display = element.style.display === 'none' ? '' : 'none';}}
};// 使用示例
document.addEventListener('DOMContentLoaded', () => {// 创建并添加元素const header = dom.create('header', { className: 'main-header' }, [dom.create('h1', {}, 'DOM工具演示'),dom.create('nav', {}, [dom.create('a', { href: '#', className: 'nav-link' }, '首页'),dom.create('a', { href: '#', className: 'nav-link' }, '产品'),dom.create('a', { href: '#', className: 'nav-link' }, '关于')])]);document.body.appendChild(header);// 添加事件委托dom.delegate('click', '.nav-link', function(e) {e.preventDefault();console.log('导航点击:', this.textContent);dom.toggle(this); // 点击后隐藏该链接});// 查找元素const firstLink = dom.find('.nav-link');console.log('第一个链接:', firstLink);// 切换显示setTimeout(() => {dom.toggle(firstLink);}, 2000);
});
这些案例涵盖了前端开发中的常见场景,包括表单验证、API请求、购物车逻辑、数据缓存和DOM操作。每个案例都遵循了以下原则:
- 清晰的函数职责划分
- 完善的参数验证和错误处理
- 详细的代码注释
- 实际业务场景的模拟
- 可复用的代码结构
相关文章:
JavaScript学习教程,从入门到精通, JavaScript 函数全面解析与案例实践(11)
JavaScript 函数全面解析与案例实践 项目导读 JavaScript 函数是编程中的核心概念,是执行特定任务的代码块。本教程将全面讲解函数的定义、参数、返回值及调用方式,并通过实际案例加深理解。 学习目标 掌握 JavaScript 函数的定义与调用方法理解函数…...
音视频之H.265/HEVC编码框架及编码视频格式
一、编码框架: H.265/HEVC采用混合编码框架,包括变换、量化、熵编码、帧内预测、帧预测以及环路滤波等模块。但是,H.265/HEVC几乎在每个模块都引入了新的编码技术。 1、帧内预测: 该模块主要用于去除图像的空间相关性。通过编码后…...
栈与队列:两种经典线性数据结构的深度解析
一、栈:LIFO 特性的完美诠释 (一)核心概念与抽象模型 定义与特性 栈是一种严格遵循后进先出(LIFO)原则的线性数据结构,其操作被限制在栈顶(Top)进行。形象化理解:如同堆…...
0x01、Redis 主从复制的实现原理是什么?
Redis 主从复制概述 Redis 的主从复制是一种机制,允许一个主节点(主实例)将数据复制到一个或多个从节点(从实例)。通过这一机制,从节点可以获取主节点的数据并与之保持同步。 复制流程 开始同步…...
Python实现贪吃蛇一
贪吃蛇是一款经典的小游戏,最近尝试用Python实现它。先做一个基础版本实现以下目标: 1、做一个按钮,控制游戏开始 2、按Q键退出游戏 3、右上角显示一个记分牌 4、随机生成一个食物,蛇吃到食物后长度加一,得10分 5、蛇碰…...
01-libVLC的视频播放器:环境搭建以及介绍
项目展示项目播放器 VLC简介VLC媒体播放器(VideoLAN Client)是一款开源、跨平台的自由多媒体播放器,由VideoLAN项目开发。它支持众多音频与视频格式(如MPEG-2、MPEG-4、H.264、MKV、WebM、WMV、MP3等),以及DVD、VCD和各种流媒体协议。 VLC的特点跨平台支持:Windows、mac…...
linux内核升级
这里介绍一下linux内核升级 因为需要搭建k8s集群内核内核版本过低会导致集群出现问题,为了避免问题发生我们对集群内核进行升级处理 这个是我目前本身的内核版本 用了很多的镜像站去进行更新发现更新不了(阿里云不能用了,貌似是删除了&…...
电感详解:定义、作用、分类与使用要点
一、电感的基本定义 电感(Inductor) 是由导线绕制而成的储能元件,其核心特性是阻碍电流变化,将电能转化为磁能存储。 基本公式: 自感电动势: E -L * (di/dt) (L:电感值,…...
扩散模型简介
扩散模型简介 基本原理 扩散模型是一种基于概率扩散过程的生成模型,其核心思想是通过正向扩散过程和反向去噪过程生成数据: 正向扩散过程:从真实数据(如图像)开始,逐步添加高斯噪声,最终将数据…...
MySQL安装实战分享
一、在 Windows 上安装 MySQL 1. 下载 MySQL 安装包 访问 MySQL 官方下载页面。选择适合你操作系统的版本。一般推荐下载 MySQL Installer。 2. 运行安装程序 双击下载的安装文件(例如 mysql-installer-community-<version>.msi)。如果出现安全…...
掌握 Git 的十大基础命令
李升伟 编译 在 IT 领域,很少有技术能像 Git 一样占据绝对主导地位,几乎无人能及。Git 在软件开发中扮演着核心角色,其影响力之大甚至让其他版本控制系统(如 SVN 和 Mercurial)几乎被淘汰。如今,我们已难以…...
58-使用wordpress快速创建个人网站
直接找台可以联网的linux(我的环境是rocky8.9)一顿运行,思路就是安装docker,然后启动一个数据库,然后启动一个wordpress,然后就是把端口暴露出来。 227 yum remove podman 228 yum install -y yum-utils…...
若依前后端分离版运行教程、打包教程、部署教程
后端打包教程 注意:需要先运行redis 2、前端运行教程 2.1安装依赖 2.2运行 打开浏览器查看,地址:http://localhost:80 3、前端打包教程 3.1打包 3.2运行打包好的文件,先找到打包好的文件 这是nginx的文件结构 将打包好的文件放到html目录下…...
【Python3教程】Python3基础篇之数据结构
博主介绍:✌全网粉丝22W+,CSDN博客专家、Java领域优质创作者,掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域✌ 技术范围:SpringBoot、SpringCloud、Vue、SSM、HTML、Nodejs、Python、MySQL、PostgreSQL、大数据、物联网、机器学习等设计与开发。 感兴趣的可…...
transformers的 pipeline是什么:将模型加载、数据预处理、推理等步骤进行了封装
transformers的 pipeline是什么:将模型加载、数据预处理、推理等步骤进行了封装 pipe = pipeline("text-generation", model=model, tokenizer=tokenizer, max_new_tokens=50 )pipeline :这是 transformers 库中一个非常实用的工具函数。它可以基于预训练模型快速构…...
十七、TCP编程
TCP 编程是网络通信的核心,其 API 围绕面向连接的特性设计,涵盖服务端和客户端的交互流程。以下是基于 C 语言的 TCP 编程核心 API 及使用流程的详细解析: 核心 API 概览 函数角色描述socket()通用创建套接字,指定协议族…...
Obsidian 技巧篇
Obsidian 技巧篇 本篇文章主要汇总分享几个 Ob 中好用的小技巧,包括嵌入视频播放、文本颜色设置、插入大纲、Mermaid 绘制图形。原文见于:Obsidian技巧篇。 嵌入视频播放 <iframe width"860" height"700" src"https://ww…...
使用Fortran读取HDF5数据
使用Fortran读取HDF5数据 下面我将介绍如何在Fortran中读取HDF5文件中的各种类型数组数据,包括一维数组、二维数组、元数组和变长数组。 准备工作 首先需要确保系统安装了HDF5库,并且在编译时链接了HDF5库。例如使用gfortran编译时: gfor…...
L36.【LeetCode题解】查找总价格为目标值的两个商品(剑指offer:和为s的两个数字) (双指针思想,内含详细的优化过程)
目录 1.LeetCode题目 2.分析 方法1:暴力枚举(未优化的双指针) 方法2:双指针优化:利用有序数组的单调性 版本1代码 提问:版本1代码有可以优化的空间吗? 版本2代码 提问:版本2代码有可以优化的空间吗? 版本3代码(★推荐★) 3.牛客网题目:和为s的数字 1.LeetCode题目 …...
mysql 商城商品属性开发的动态解决方案
终极方案:动态属性解决方案 推荐使用 JSON 字段 虚拟列索引 的组合方案 结合灵活存储与查询优化,平衡扩展性与性能 完整实现步骤 步骤 1:创建基础表结构 CREATE TABLE products (id INT PRIMARY KEY AUTO_INCREMENT,name VARCHAR(100) NO…...
Java递归练习----猴子偷桃
问题: 有一堆桃子,猴子第一天吃灵其中的一般,并在多吃了一个!以后每天猴子都吃其中的一半,然后多吃一个。当到第十天时,想再吃时(即还没吃),发现只有1个桃子了ÿ…...
[干货]PHM学习软件|PHM预测性维护系统
使用步骤教程如下 1、登录 用户名:52phm 密码:xxx (区别在于不同用户密钥不一样) 2、上传需要分析的数据集 支持数据集格式:csv、xlsx、xls、mat、json 3、主题1:机械参数计算 计算轴承、齿轮、皮带的…...
详解正则表达式中的?:、?= 、 ?! 、?<=、?<!
1、?: - 非捕获组 语法: (?:pattern) 作用: 创建一个分组但不捕获匹配结果,不会将匹配的文本存储到内存中供后续使用。 优势: 提高性能和效率 不占用编号(不会影响后续捕获组的编号) 减少内存使用 // 使用捕获组 let regex1 /(hell…...
Java常见面试问题
一.Liunx 二.Java基础 1.final 2.static 3.与equals 三.Collection 1.LIst 2.Map 3.Stream 四、多线程 1.实现方法 2.线程池核心参数 3.应用场景 五、JVM 1.堆 2.栈 六、Spring 1.面向对象 2.IOC 3.AOP 七、Springboot 1.自动装配 八、SpringCloud 1.Nacos 2.seata 3.ga…...
C#MQTT协议服务器与客户端通讯实现(客户端包含断开重连模块)
C#MQTT协议服务器与客户端通讯实现 1 DLL版本2 服务器3 客户端 1 DLL版本 MQTTnet.DLL版本-2.7.5.0 基于比较老的项目中应用的DLL,其他更高版本变化可能较大,谨慎参考。 2 服务器 开启服务器 关闭服务器 绑定事件【客户端连接服务器事件】 绑定事件【客户…...
GGML源码逐行调试(上)
目录 前言1. 简述2. 环境配置3. ggml核心概念3.1 gguf3.2 ggml_tensor3.3 ggml_backend_buffer3.4 ggml_context3.5 backend3.6 ggml_cgraph3.7 ggml_gallocr 4. 推理流程整体梳理4.1 时间初始化与参数设置4.2 模型加载与词汇表构建4.3 计算图与内存分配4.4 文本预处理与推理过…...
智能测试用例生成:老旧平台页面查询功能的大模型改造
引言 由于GUI小工具【Deepseek APIPython 测试用例一键生成与导出】的不断升级实践,发现大模型的需求文档解析生成测试用例的可直接复用率不太理想,因此萌生了对老旧系统升级改造的想法。旧测试用例生成平台主要在于采集用户输入的字段名称、字段类型及…...
使用Python解决Logistic方程
引言 在数学和计算机科学中,Logistic 方程是描述人口增长、传播过程等现象的一种常见模型。它通常用于表示一种有限资源下的增长过程,比如动物种群、疾病传播等。本文将带领大家通过 Python 实现 Logistic 方程的求解,帮助你更好地理解这一经典数学模型。 1.什么是 Logist…...
文件上传基本原理靶场实现
一. 漏洞原理 未经验证的上传机制: 应用程序未对用户上传的文件进行充分验证,包括: 文件类型/扩展名:仅依赖客户端提交的MIME类型或简单检查扩展名(如.jpg),但未验证文件实际内容。 文件内容&a…...
灰色预测模型:GM(1,1)预测模型
灰色预测模型 灰色预测的主要特点是模型使用的不是原始数据序列,而是生成的数据序列。核心体系是灰色模型,即对原始数据作累加生成(或其他方法生成)得到近似的指数规律再进行建模的方法,优点是不需要很多的数据&#…...
SPORT(Serial Port)接口
SPORT(Serial Port)接口是DSP芯片中常用的高速同步串行通信接口,主要用于与外部设备(如ADC、DAC、编解码器等)进行数据传输。以下是对SPORT接口的详细介绍: 1. SPORT接口概述 SPORT接口设计用于高效传输连…...
Python及C++中的字典
一、Python中的字典 (一)基本概念 字典(dict)是Python中一种可变容器模型,用于存储键值对(key:value)。字典的键必须是不可变类型(如字符串、数字或元组),而…...
Neo4j GDS-11-neo4j GDS 库中相似度算法实现
neo4j GDS 系列 Neo4j APOC-01-图数据库 apoc 插件介绍 Neo4j GDS-01-graph-data-science 图数据科学插件库概览 Neo4j GDS-02-graph-data-science 插件库安装实战笔记 Neo4j GDS-03-graph-data-science 简单聊一聊图数据科学插件库 Neo4j GDS-04-图的中心性分析介绍 Neo…...
网络互连与互联网2
1.IP数据报首部在IHL 字段的最小值为5 2.三层交换机包括二层交换和三层转发,二层交换由硬件实现,三层转发采用软件实现 3.在BGP路由选择协议中,AS_PATH属性可以避免在AS之间产生环路 4.常用的电子邮件协议:SMTP(25&…...
4月12日随笔
今天大风天气的第一天,周六,早上九点半起来听了排球技术台培训。结果一天都没顾得上看教学视频。黄老师说有排球基础的可以试试当主裁,那一定要争取一下! 上午看了两集小排球,然后开始了解一些中介相关信息。因为下午…...
web自动化测试
自动化测试理论 UI:User Interface(用户接口-用户界面),主要包括:app、web ui自动化测试:使用工具或代码执行用例的过程 什么样的项目适合做自动化 1、需要回归测试项目(甲方自营项目、金…...
代码随想录二叉树小结1;(递归与迭代法小结)
一、递归遍历 1.递归算法三要素: 确定递归函数的参数和返回值: 在递归函数里加上递归的过程中需要处理的参数, 然后明确每次递归的返回值是什么,最后确定递归函数的返回类型。 确定终止条件: 递归算法运行的时候&…...
Audacity命令:“播录”菜单相关命令
1 Audacity命令:“播录”菜单相关命令 1.1 播录菜单 播录菜单中的命令可让您播放、停止、循环播放、擦洗音频或录制音频(包括定时录制和声控录制)。 Scripting IdActionParameters描述RescanDevice:Rescan Audio Devicesnone重新扫描连接到…...
Python及C++中的集合
1. Python 中的集合(set) 1.1 特性 无序性:集合中的元素没有顺序,不能通过索引访问。唯一性:集合中的元素不能重复,如果尝试添加重复的元素,集合会自动忽略。可变性:集合是可变的&…...
[CF2086E] Zebra-like Numbers 题解
确简单的啊,可是自己就是想不到。 考虑计算一个数的斑马值。贪心地,尽量选大的斑马数减即可。 考虑 DP,设 d p i , j dp_{i, j} dpi,j 表示 [ 1 , i ] [1, i] [1,i] 中斑马值为 j j j 的数的个数。那么显然有 d p i , j d p i − m …...
Linux-内核驱动
open uboot.bin target-connect U-Boot(Universal Boot Loader)是一种广泛使用的开源引导加载程序,它允许用户从各种设备(如硬盘、USB设备、网络等)加载操作系统。U-Boot提供了丰富的命令行接口(CLI&#…...
[Dify] 使用 Docker 本地部署 Dify 并集成 Ollama 模型的详细指南
在 AI 应用快速发展的今天,开源项目如 Dify 正成为构建本地化 AI 应用的利器。通过 Dify,你可以轻松地集成不同的大语言模型(LLM),如 Ollama,并快速创建可交互的 AI 应用。本篇文章将带你一步步通过 Docker…...
ESP32+Arduino入门(三):连接WIFI获取当前时间
ESP32内置了WIFI模块连接WIFI非常简单方便。 代码如下: #include <WiFi.h>const char* ssid "WIFI名称"; const char* password "WIFI密码";void setup() {Serial.begin(115200);WiFi.begin(ssid,password);while(WiFi.status() ! WL…...
软件架构评估两大法:ATAM 和 SAAM 的对比与实践
架构权衡分析方法(ATAM)和软件架构分析方法(SAAM)是软件架构评估领域中非常重要的两种方法,以下为你详细介绍: 一、架构权衡分析方法(ATAM) 1.背景与起源:ATAM 是由卡耐…...
《AI大模型应知应会100篇》第13篇:大模型评测标准:如何判断一个模型的优劣
第13篇:大模型评测标准:如何判断一个模型的优劣 摘要 近年来,大语言模型(LLMs)在自然语言处理、代码生成、多模态任务等领域取得了显著进展。然而,随着模型数量和规模的增长,如何科学评估这些模…...
编译 OpenCV 时,cmake 找到 TBB 的方法
编译 OpenCV 时,cmake 找到 TBB 的方法 编译 OpenCV 时,cmake 找到 TBB 的方法 编译 OpenCV 时,cmake 找到 TBB 的方法 HKEY_LOCAL_MACHINE\SOFTWARE\Intel\oneAPI\TBB\2022.1.0cmake 是从上面的注册表里找到的 TBB 安装路径。 这个键下面有…...
SMT贴片组装工艺优化与高效生产
内容概要 现代SMT贴片组装工艺的优化与高效生产涉及多维度技术协同,其核心在于构建精密可控的制造体系。本文系统梳理了从焊接参数调控到智能检测部署的全链路关键环节,重点解析影响生产效能的核心变量及其相互作用机制。通过对比不同贴装设备的速度-精…...
leetcode刷题日记——有效的数独
[ 题目描述 ]: [ 思路 ]: 题目要求求一个数独题目是否有效,即每行,每列,每个九宫格都不能出现相同的数字暴力求解:对每行,每列,以及九宫格进行检查是否存在相同数字运行如下 boo…...
Agent2Agent协议学习资源大全:从理论到实践
下面整理了一份关于谷歌 A2A 协议的学习资源,分为官方资源、开发教程/实践、行业解读和视频教程四个部分,方便您系统性地学习和掌握相关知识: 1. 官方资源 A2A 协议 GitHub 仓库 官方开源代码库,包含协议规范、示例代码和详细文档…...
PCDN收益高低的关键因素
PCDN(P2P内容分发网络)收益好的三个主要关键因素是:硬件配置与性能、网络环境与质量、业务调度与策略。 1. 硬件配置与性能 设备稳定性与兼容性 PCDN节点需长时间稳定运行,硬件性能直接影响收益。例如,使用高性能CPU、…...