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

基于 HTML5 Canvas 实现图片旋转与下载功能

一、引言

在 Web 开发中,经常会遇到需要对图片进行处理并提供下载功能的需求。本文将深入剖析一段基于 HTML5 Canvas 的代码,该代码实现了图片的旋转(90 度和 180 度)以及旋转后图片的下载功能。通过对代码的解读,我们可以学习到如何利用 Canvas API 进行图像操作,以及如何实现文件的下载功能。

二、HTML 结构分析

  1. 基本结构:这段 HTML 代码的基本结构比较简单,包含了一个<head>部分和一个<body>部分。<head>部分主要用于设置页面的元数据和引入外部样式表,<body>部分则包含了页面的实际内容。
  2. Canvas 元素:在<body>中,有一个<canvas>元素,其idcanvas。这个元素是 HTML5 提供的用于绘制图形和图像的容器。如果用户的浏览器不支持 HTML5 的<canvas>标签,那么在<canvas>标签内的文本 “您的浏览器不支持 HTML5 canvas 标签。” 将会显示出来。
  3. 下载按钮:还有一个<div>元素,类名为download,它作为一个下载按钮,文本内容为 “下载”。用户点击这个按钮时,将触发相应的 JavaScript 函数来实现图片的下载。

三、CSS 样式分析

  1. 下载按钮样式:通过 CSS 样式定义了.download类的样式。设置了按钮的宽度为100px,高度为40px,背景颜色为白色(#fff),文字颜色为#276787,边框为1px的实线,颜色为#276787。使用display: flex;align-items: center;justify-content: center;使按钮内的文本居中显示。border-radius: 20px;将按钮的边角设置为圆角,使其看起来更加美观。
  2. 交互样式:定义了按钮的交互样式。当鼠标悬停在按钮上时(.download:hover),背景颜色变为#276787,文字颜色变为白色,边框变为透明。当按钮被按下时(.download:active),按钮的透明度变为0.4,提供了视觉反馈。

四、JavaScript 功能实现

  1. 图像加载与 Canvas 初始化:首先创建一个<img>元素用于加载原始图像,并获取<canvas>元素及其 2D 绘图上下文ctx。设置原始图像的src属性为一个在线图片的 URL,并设置crossOrigin属性为anonymous,以处理跨域问题。当图像加载完成后(originImage.onload事件触发),获取图像的原始宽度ow和高度oh
  2. 图片旋转
    • 90 度旋转(注释部分):代码中注释掉了 90 度旋转的实现。原本的逻辑是将 Canvas 的宽度设置为图像的原始高度oh,高度设置为图像的原始宽度ow。然后使用ctx.rotate(-Math.PI / 2)将绘图上下文逆时针旋转 90 度,再通过ctx.drawImage(originImage, -ow, 0)将图像绘制到 Canvas 上。最后再使用ctx.rotate(Math.PI / 2)将绘图上下文顺时针旋转回原来的角度。
    • 180 度旋转(实际实现):将 Canvas 的宽度和高度设置为图像的原始宽度ow和高度oh。使用ctx.rotate(Math.PI)将绘图上下文顺时针旋转 180 度,然后通过ctx.drawImage(originImage, -ow, -oh)将图像绘制到 Canvas 上,实现了图像的 180 度旋转。
  3. 生成 Base64 编码:旋转后的图像通过canvas.toDataURL("image/jpeg", 0.5)方法生成一个 Base64 编码的字符串,这里设置图像格式为 JPEG,质量为 0.5。生成的 Base64 编码字符串存储在base64变量中。
  4. 下载功能实现
    • 方式一(注释部分):注释掉了一种下载实现方式。原本的逻辑是创建一个<a>元素,将其href属性设置为生成的 Base64 编码字符串,download属性设置为 “旋转后的图片.png”,然后模拟点击这个<a>元素来触发下载。
    • 方式二(实际实现):创建一个<a>元素,将其href属性设置为通过window.URL.createObjectURL(base64ToBlob(base64))生成的对象 URL,download属性设置为 “旋转后的图片.jpg”。base64ToBlob函数将 Base64 编码字符串转换为 Blob 对象,然后通过window.URL.createObjectURL创建一个可用于下载的 URL。最后模拟点击<a>元素来实现图片的下载。
  5. Base64 转 Blob 函数base64ToBlob函数用于将 Base64 编码字符串转换为 Blob 对象。它首先将 Base64 字符串分割,提取出 MIME 类型,然后使用atob方法将 Base64 编码的字符串解码为二进制字符串,再将二进制字符串转换为Uint8Array,最后创建一个新的 Blob 对象并返回。

完整代码展示

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><link rel="stylesheet" href="./assets/global.css"><style>.download {width: 100px;height: 40px;background-color: #fff;color: #276787;border: 1px solid #276787;margin-right: 10px;display: flex;align-items: center;justify-content: center;border-radius: 20px;font-size: 12px;transition: all .5s;}.download:hover {background-color: #276787;color: white;border: 1px solid transparent;}.download:active {opacity: .4;}</style></head><body><canvas id="canvas">您的浏览器不支持 HTML5 canvas 标签。</canvas><div class="download">下载</div><script>// 原始图像let originImage = document.createElement('img');// 画布let canvas = document.getElementById("canvas");let ctx = canvas.getContext("2d");// 转换后的base64let base64 = ''// 下载按钮let download = document.querySelector(".download");originImage.setAttribute("src", "https://t11.baidu.com/it/u=1760443654,877298532&fm=58")originImage.crossOrigin = "anonymous";originImage.onload = () => {let ow = originImage.naturalWidth;let oh = originImage.naturalHeight;// 90度// canvas.width = oh;// canvas.height = ow;// ctx.width = oh;// ctx.height = ow;// ctx.rotate(-Math.PI / 2) // 逆时针90度// ctx.drawImage(originImage, -ow, 0)// ctx.rotate(Math.PI / 2) // 顺时针90度// ctx.drawImage(originImage, 0, -oh)// 180度 canvas.width = ow;canvas.height = oh;ctx.width = ow;ctx.height = oh;ctx.rotate(Math.PI) // 顺时针180度ctx.drawImage(originImage, -ow, -oh)base64 = canvas.toDataURL("image/jpeg", 0.5);}// 方式一// download.addEventListener('click', () => {//     let a = document.createElement('a');//     a.href = base64;//     a.download = "旋转后的图片.png";//     a.click();// })// 方式二download.addEventListener('click', () => {let a = document.createElement('a');a.href = window.URL.createObjectURL(base64ToBlob(base64));a.setAttribute('download', '旋转后的图片.jpg');a.click();})// base64 转 Blobfunction base64ToBlob(base64) {let arr = base64.split(',');let mime = arr[0].match(/:(.*?);/)[1];let bstr = atob(arr[1]);let n = bstr.length;let u8arr = new Uint8Array(n);while (n--) {u8arr[n] = bstr.charCodeAt(n);}return new Blob([u8arr], { type: mime })}</script>
</body></html>

 

相关文章:

基于 HTML5 Canvas 实现图片旋转与下载功能

一、引言 在 Web 开发中&#xff0c;经常会遇到需要对图片进行处理并提供下载功能的需求。本文将深入剖析一段基于 HTML5 Canvas 的代码&#xff0c;该代码实现了图片的旋转&#xff08;90 度和 180 度&#xff09;以及旋转后图片的下载功能。通过对代码的解读&#xff0c;我们…...

学习路线(机器人系统)

机器人软件/系统学习路线&#xff08;从初级到专家&#xff09; 初级阶段&#xff08;6-12个月&#xff09;基础数学编程基础机器人基础概念推荐资源 中级阶段&#xff08;1-2年&#xff09;机器人运动学机器人动力学控制系统感知系统推荐资源 高级阶段&#xff08;2-3年&#…...

基于EFISH-SCB-RK3576工控机/SAIL-RK3576核心板的网络安全防火墙技术方案‌(国产化替代J1900的全栈技术解析)

‌基于EFISH-SCB-RK3576/SAIL-RK3576的网络安全防火墙技术方案‌ &#xff08;国产化替代J1900的全栈技术解析&#xff09; ‌一、硬件架构设计‌ ‌流量处理核心模块‌ ‌多核异构架构‌&#xff1a; ‌四核Cortex-A72&#xff08;2.3GHz&#xff09;‌&#xff1a;处理深度…...

基于 jQuery 实现复选框全选与选中项查询功能

在 Web 开发中&#xff0c;复选框是常见的交互元素&#xff0c;尤其是在涉及批量操作、数据筛选等场景时&#xff0c;全选功能和选中项查询功能显得尤为重要。本文将介绍如何使用 HTML、CSS 和 jQuery 实现一个具备全选、反选以及选中项查询功能的复选框组&#xff0c;帮助开发…...

Python中的JSON库,详细介绍与代码示例

目录 1. 前言 2. json 库基本概念 3. json 的适应场景 4. json 库的基本用法 4.1 导 json入 模块 4.2 将 Python 对象转换为 JSON 字符串 4.3 将 JSON 字符串转换为 Python 对象 4.4 将 Python 对象写入 JSON 文件 4.5 从 JSON 文件读取数据 4.6 json 的其他方法 5.…...

tensorflow 调试

tensorflow 调试 tf.config.experimental_run_functions_eagerly(True) 是 TensorFlow 中的一个配置函数&#xff0c;它的作用是&#xff1a; 让 tf.function 装饰的函数以 Eager 模式&#xff08;即时执行&#xff09;运行&#xff0c;而不是被编译成图&#xff08;Graph&…...

iptables的基本选项及概念

目录 1.按保护范围划分&#xff1a; 2.iptables 的基础概念 4个规则表&#xff1a; 5个规则链&#xff1a; 3.iptables的基础选项 4.实验 1.按保护范围划分&#xff1a; 主机防火墙&#xff1a;服务范围为当前一台主机 input output 网络防火墙&#xff1a;服务范围为防…...

使用AI 将文本转成视频 工具 介绍

&#x1f3ac; 文字生成视频工具 一款为自媒体创作者设计的 全自动视频生成工具&#xff0c;输入文本即可输出高质量视频&#xff0c;大幅提升内容创作效率。视频演示&#xff1a;https://leeseean.github.io/Text2Video/?t23 ✨ 功能亮点 功能模块说明&#x1f4dd; 智能分…...

Python生活手册-NumPy数组创建:从快递分拣到智能家居的数据容器

一、快递分拣系统&#xff08;列表/元组转换&#xff09; 1. 快递单号录入&#xff08;np.array()&#xff09; import numpy as np快递单号入库系统 快递单列表 ["SF123", "JD456", "EMS789"] 快递数组 np.array(快递单列表) print(f"…...

Cmake编译wxWidgets3.2.8

一、下载库源代码 去wxWidgets - Browse /v3.2.8 at SourceForge.net下载wxWidgets-3.2.8.7z 二、建立目录结构 1、在d:\codeblocks目录里新建wxWidgets_Src目录 2、把文件解压到该目录 3、建立 CB目录&#xff0c;并在该目录下分别建立 Debug 和 Release目录 三、使用Cmake…...

2.在Openharmony写hello world

原文链接&#xff1a;https://kashima19960.github.io/2025/03/21/openharmony/2.在Openharmony写hello%20world/ 前言 Openharmony 的第一个官方例程的是教你在Hi3861上编写hello world程序&#xff0c;这个例程相当简单编写 Hello World”程序&#xff0c;而且步骤也很省略&…...

「OC」源码学习——对象的底层探索

「OC」源码学习——对象的底层探索 前言 上次我们说到了源码里面的调用顺序&#xff0c;现在我们继续了解我们上一篇文章没有讲完的关于对象的内容函数&#xff0c;完整了解对象的产生对于isa赋值以及内存申请的内容 函数内容 先把_objc_rootAllocWithZone函数的内容先贴上…...

从0开始学习大模型--Day01--大模型是什么

初识大模型 在平时遇到问题时&#xff0c;我们总是习惯性地去运用各种搜索引擎如百度、知乎、CSDN等平台去搜索答案&#xff0c;但由于搜索到的内容质量参差不齐&#xff0c;检索到的内容只是单纯地根据关键字给出内容&#xff0c;往往看了几个网页都找不到答案&#xff1b;而…...

202533 | SpringBoot集成RocketMQ

SpringBoot集成RocketMQ极简入门 一、基础配置&#xff08;3步完成&#xff09; 添加依赖 <!-- pom.xml --> <dependency><groupId>org.apache.rocketmq</groupId><artifactId>rocketmq-spring-boot-starter</artifactId><version&g…...

大模型学习专栏-导航页

概要 本专栏是小编系统性调研大模型过程中沉淀的知识结晶&#xff0c;涵盖技术原理、实践应用、前沿动态等多维度内容。为助力读者高效学习&#xff0c;特整理此导航页&#xff0c;以清晰脉络串联核心知识点&#xff0c;搭建起系统的大模型学习框架&#xff0c;助您循序渐进掌握…...

互联网大厂Java面试:从Java SE到微服务的全栈挑战

场景概述 在这场面试中&#xff0c;谢飞机&#xff0c;一个搞笑但有些水的程序员&#xff0c;面对的是一位严肃的大厂面试官李严。面试官的目的是考察谢飞机在Java全栈开发&#xff0c;特别是微服务架构中的技术能力。面试场景设定在内容社区与UGC领域&#xff0c;模拟一个社交…...

2024年408真题及答案

2024年计算机408真题 2024年计算机408答案 2024 408真题下载链接 2024 408答案下载链接...

【datawhaleAI春训营】楼道图像分类

目录 图像分类任务的一般处理流程为什么使用深度学习迁移学习 加载实操环境的库加载数据集&#xff0c;默认data文件夹存储数据将图像类别进行编码自定义数据读取加载预训练模型模型训练&#xff0c;验证和预测划分验证集并训练模型 修改baseline处理输入数据选择合适的模型Ale…...

Unity:输入系统(Input System)与持续检测键盘按键(Input.GetKey)

目录 Unity 的两套输入系统&#xff1a; &#x1f50d; Input.GetKey 详解 &#x1f3af; 对比&#xff1a;常用的输入检测方法 技术底层原理&#xff08;简化版&#xff09; 示例&#xff1a;角色移动 为什么会被“新输入系统”替代&#xff1f; Unity 的两套输入系统&…...

day04_计算机常识丶基本数据类型转换

计算机常识 计算机如何存储数据 计算机底层只能识别二进制。计算机底层只识别二进制是因为计算机内部的电子元件只能识别两种状态&#xff0c;即开和关&#xff0c;或者高电平和低电平。二进制正好可以用两种状态来表示数字和字符&#xff0c;因此成为了计算机最基本的表示方…...

rvalue引用()

一、先确定基础:左值(Lvalue)和右值(Rvalue) 理解Rvalue引用,首先得搞清楚左值和右值的概念。 左值(Lvalue):有明确内存地址的表达式,可以取地址。比如变量名、引用等。 复制代码 int a = 10; // a是左值 int& ref = a; // ref也是左值右值(Rval…...

【Web3】上市公司利用RWA模式融资和促进业务发展案例

香港典型案例 朗新科技&#xff08;充电桩RWA融资&#xff09; 案例概述&#xff1a;2024年8月&#xff0c;朗新科技与蚂蚁数科合作&#xff0c;通过香港金管局“Ensemble沙盒”完成首单新能源充电桩资产代币化融资&#xff0c;募资1亿元人民币。技术实现&#xff1a;蚂蚁链提供…...

什么是IIC通信

IIC(Inter-Integrated Circuit),即IC,是一种串行通信总线,由飞利浦公司在1980年代开发,主要用于连接主板、嵌入式系统或手机中的低速外围设备1。IIC协议采用多主从架构,允许多个主设备和从设备连接在同一总线上进行通信。 IIC协议的工作原理: IIC协议使用两根信号线进…...

网络原理 TCP/IP

1.应用层 1.1自定义协议 客户端和服务器之间往往进行交互的是“结构化”数据&#xff0c;网络传输的数据是“字符串”“二进制bit流”&#xff0c;约定协议的过程就是把结构化”数据转成“字符串”或“二进制bit流”的过程. 序列化&#xff1a;把结构化”数据转成“字符串”…...

掌纹图像识别:解锁人类掌纹/生物识别的未来——技术解析与前沿数据集探索

概述 掌纹识别是一种利用手掌表面独特的线条、纹理和褶皱模式进行身份认证的生物识别技术。它具有非侵入性、高准确性和难以伪造的特点,被广泛应用于安全认证领域。以下将结合提供的链接,详细介绍掌纹识别的技术背景、数据集和研究进展。 提供的链接分析 香港理工大学掌纹数…...

【FPGA开发】Xilinx DSP48E2 slice 一个周期能做几次int8乘法或者加法?如何计算FPGA芯片的GOPS性能?

Xilinx DSP48E2 slice 在一个时钟周期内处理 INT8&#xff08;8 位整数&#xff09;运算的能力。 核心能力概述 一个 DSP48E2 slice 包含几个关键计算单元&#xff1a; 预加器 (Pre-Adder): 可以执行 A D 或 A - D 操作&#xff0c;其中 A 是 30 位&#xff0c;D 是 27 位。…...

APP 设计中的色彩心理学:如何用色彩提升用户体验

在数字化时代&#xff0c;APP 已成为人们日常生活中不可或缺的一部分。用户在打开一个 APP 的瞬间&#xff0c;首先映入眼帘的便是其色彩搭配&#xff0c;而这些色彩并非只是视觉上的装饰&#xff0c;它们蕴含着强大的心理暗示力量&#xff0c;能够潜移默化地影响用户的情绪、行…...

残差网络实战:基于MNIST数据集的手写数字识别

残差网络实战&#xff1a;基于MNIST数据集的手写数字识别 在深度学习的广阔领域中&#xff0c;卷积神经网络&#xff08;CNN&#xff09;一直是处理图像任务的主力军。随着研究的深入&#xff0c;网络层数的增加虽然理论上能提升模型的表达能力&#xff0c;但却面临梯度消失、…...

科学养生,开启健康生活新篇章

在快节奏的现代生活中&#xff0c;健康养生成为人们关注的焦点。科学合理的养生方式&#xff0c;能帮助我们远离疾病&#xff0c;提升生活质量&#xff0c;无需依赖传统中医理念&#xff0c;也能找到适合自己的养生之道。​ 饮食是养生的基础。遵循均衡饮食原则&#xff0c;每…...

如何扫描系统漏洞?漏洞扫描的原理是什么?

如何扫描系统漏洞?漏洞扫描的原理是什么&#xff1f; 漏洞扫描是网络安全中识别系统潜在风险的关键步骤&#xff0c;其核心原理是通过主动探测和自动化分析发现系统的安全弱点。以下是详细解答&#xff1a; 一、漏洞扫描的核心原理 主动探测技术 通过模拟攻击者的行为&#xf…...

Scrapy分布式爬虫实战:高效抓取的进阶之旅

引言 在2025年的数据狂潮中,单机爬虫如孤舟难敌巨浪,Scrapy分布式爬虫宛若战舰编队,扬帆远航,掠夺信息珍宝!继“动态网页”“登录网站”“经验总结”后,本篇献上Scrapy-Redis分布式爬虫实战,基于Quotes to Scrape,从单机到多机协同,代码简洁可运行,适合新手到老兵。…...

开元类双端互动组件部署实战全流程教程(第1部分:环境与搭建)

作者&#xff1a;一个曾在“组件卡死”里悟道的搬砖程序员 在面对一个看似华丽的开元类互动组件时&#xff0c;很多人以为“套个皮、配个资源”就能跑通。实际上&#xff0c;光是搞定环境配置、组件解析、控制端响应、前后端互联这些流程&#xff0c;已经足够让新手懵3天、老鸟…...

【实验笔记】Kylin-Desktop-V10-SP1麒麟系统知识 —— 开机自启Ollama

提示: 分享麒麟Kylin-Desktop-V10-SP1系统 离线部署Deepseek后,实现开机自动启动 Ollama 工具 的详细操作步骤 说明:离线安装ollama后,每次开机都需要手动启动,并且需要保持命令终端不能关闭;通过文档操作方法能实现开机自动后台启动 Ollama 工具 一、前期准备 1、离…...

Redis:现代服务端开发的缓存基石与电商实践-优雅草卓伊凡

Redis&#xff1a;现代服务端开发的缓存基石与电商实践-优雅草卓伊凡 一、Redis的本质与核心价值 1.1 Redis的技术定位 Redis&#xff08;Remote Dictionary Server&#xff09;是一个开源的内存数据结构存储系统&#xff0c;由Salvatore Sanfilippo于2009年创建。它不同于传…...

认识并理解什么是链路层Frame-Relay(帧中继)协议以及它的作用和影响

帧中继(Frame Relay)是一种高效的数据链路层协议,主要用于广域网(WAN)中实现多节点之间的数据通信。它通过**虚电路(Virtual Circuit)**和统计复用技术,优化了传统分组交换网络(如X.25)的性能,特别适合带宽需求高、时延敏感的场景。 一、帧中继的核心设计目标 简化协…...

Python基本语法(类和实例)

类和实例 类和对象是面向对象编程的两个主要方面。类创建一个新类型&#xff0c;而对象是这个 类的实例&#xff0c;类使用class关键字创建。类的域和方法被列在一个缩进块中&#xff0c;一般函数 也可以被叫作方法。 &#xff08;1&#xff09;类的变量&#xff1a;甴一个类…...

Netty的内存池机制怎样设计的?

大家好&#xff0c;我是锋哥。今天分享关于【Netty的内存池机制怎样设计的&#xff1f;】面试题。希望对大家有帮助&#xff1b; Netty的内存池机制怎样设计的&#xff1f; 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 Netty的内存池机制是为了提高性能&#xff…...

Python学习之路(七)-绘画and动画

Python 虽然不是专为图形设计或动画开发的语言,但凭借其丰富的第三方库,依然可以实现 2D/3D 绘画、交互式绘图、动画制作、游戏开发 等功能。以下是 Python 在绘画和动画方面的主流支持方式及推荐库。建议前端web端展示还是用其他语言好╮(╯▽╰)╭ 一、Python 绘画支持(2D…...

【HarmonyOS 5】鸿蒙应用数据安全详解

【HarmonyOS 5】鸿蒙应用数据安全详解 一、前言 大家平时用手机、智能手表的时候&#xff0c;最担心什么&#xff1f;肯定是自己的隐私数据会不会泄露&#xff01;今天就和大家唠唠HarmonyOS是怎么把应用安全这块“盾牌”打造得明明白白的&#xff0c;从里到外保护我们的信息…...

动态指令参数:根据组件状态调整指令行为

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》、《前端求职突破计划》 &#x1f35a; 蓝桥云课签约作者、…...

Linux:权限的理解

目录 引言&#xff1a;为何Linux需要权限&#xff1f; 一、用户分类与切换 1.1、用户角色 1.2、用户切换命令 二、权限的基础概念 2.1、文件属性 三、权限的管理指令 3.1、chmod&#xff1a;修改文件权限 3.2、chown与chgro&#xff1a;修改拥有者与所属组 四、粘滞位…...

/etc/kdump.conf 配置详解

/etc/kdump.conf 是 Linux kdump 机制的核心配置文件&#xff0c;用于定义内核崩溃转储&#xff08;vmcore&#xff09;的生成规则、存储位置、过滤条件及触发后的自定义操作。以下是对其配置项的详细解析及常见用法示例&#xff1a; 一、配置文件结构 文件通常位于 /etc/kdu…...

Redis 中简单动态字符串(SDS)的深入解析

在 Redis 中&#xff0c;简单动态字符串&#xff08;Simple Dynamic String&#xff0c;SDS&#xff09;是一种非常重要的数据结构&#xff0c;它在 Redis 的底层实现中扮演着关键角色。本文将详细介绍 SDS 的结构、Redis 使用 SDS 的原因以及 SDS 的主要 API 及其源码解析。 …...

GPIO引脚的上拉下拉以及转换速度到底怎么选

【摘要】本文讲述在进行单片机开发当中&#xff0c;新手小白常常为GPIO端口的种种设置感到迷惑&#xff0c;例如到底设置什么模式&#xff1f;它们之间的区别是什么&#xff1f;到底是设置上拉还是下拉电阻&#xff0c;有什么讲究&#xff1f;端口的输出速度又该如何设置&#…...

day16 numpy和shap深入理解

NumPy数组的创建 NumPy数组是Python中用于存储和操作大型多维数组和矩阵的主要工具。NumPy数组的创建非常灵活&#xff0c;可以接受各种“序列型”对象作为输入参数来创建数组。这意味着你可以将Python的列表&#xff08;List&#xff09;、元组&#xff08;Tuple&#xff09;…...

深入探索 51 单片机:从入门到实践的全面指南

深入探索 51 单片机&#xff1a;从入门到实践的全面指南 一、引言 在嵌入式系统发展的漫长历程中&#xff0c;51 单片机犹如一颗璀璨的明星&#xff0c;虽然诞生已有数十年&#xff0c;但至今仍在众多领域发挥着重要作用。它以结构简单、易于学习、成本低廉等优势&#xff0c…...

架构思维:构建高并发读服务_热点数据查询的架构设计与性能调优

文章目录 一、引言二、热点查询定义与场景三、主从复制——垂直扩容四、应用内前置缓存4.1 容量上限与淘汰策略4.2 延迟刷新&#xff1a;定期 vs. 实时4.3 逃逸流量控制4.4 热点发现&#xff1a;被动 vs. 主动 五、降级与限流兜底六、前端&#xff0f;接入层其他应对七、模拟压…...

时间同步服务核心知识笔记:原理、配置与故障排除

一、时间同步服务 在 Linux 系统中&#xff0c;准确的时间至关重要。对于服务器集群&#xff0c;时间同步确保各节点间数据处理和交互的一致性&#xff0c;避免因时间差异导致的事务处理错误、日志记录混乱等问题。在分布式系统中&#xff0c;时间同步有助于协调任务调度、数据…...

三种石墨烯(Graphene)拉伸模拟方法对比

免责声明:个人理解,仅供参考,若有问题欢迎讨论! 一、原理解释 1、fix deform 法——整体拉伸的理想模型 📌 模拟逻辑: 使用 fix deform 指令,对模拟盒子整体在 x 方向均匀伸长; 同时施加 npt 控制,使 y 和 z 方向维持零压状态(自由弛豫); 整个石墨烯结构在形变…...

Linux系统编程--基础指令(!!详细讲解+知识拓展)

第一讲 基础指令 ​ 我们现如今自己使用的电脑大部分是用的都是windows或者macOS&#xff0c;并配合上由微软和苹果开发的图形化界面&#xff0c;所以使用鼠标再屏幕上进行点击即可完成许多任务。但是作为操作系统的学习者&#xff0c;在linux的基础上不再使用图形化界进行操作…...