AI 在模仿历史语言方面面临挑战:大型语言模型在生成历史风格文本时的困境与研究进展
概述
在当今数字化时代,人工智能(AI)技术在诸多领域展现出了强大的能力,但在处理历史语言这一特定任务时,却遭遇了不小的挑战。美国和加拿大的研究人员通过合作发现,像 ChatGPT 这样的大型语言模型(LLMs),在没有经过广泛且深入的 预训练 的情况下,很难精准地重现历史时期的习语和语言风格。预训练是一个既耗时又耗费资源的过程,对于大多数学术研究和娱乐项目来说,都是一道难以跨越的门槛。这使得一些颇具创意的想法,例如利用 AI 来 完成查尔斯·狄更斯的最后一部未完成的小说,在实际操作中变得不太可行。
为了探索 AI 在生成具有历史准确性文本方面的潜力,研究人员尝试了多种方法。他们从使用 20 世纪早期的散文对模型进行简单提示入手,逐步深入到对商业模型在该时期的少量书籍上进行 微调。此外,他们还将这些结果与一个完全在 1880 年至 1914 年间出版的书籍上训练的独立模型进行了对比分析。
在第一次测试中,研究人员要求 ChatGPT-4o 模仿 _fin‑_de‑siècle(世纪末)的语言风格,其结果与经过该时期文学微调的小型 GPT2 模型的结果形成了鲜明对比:
当被要求完成一段真实的历史文本(顶部中心)时,即使是经过充分准备的 ChatGPT-4o(左下)也难以避免地回到了 “博客” 模式,未能准确地代表所请求的历史习语。相比之下,经过微调的 GPT2 模型(右下)虽然在其他方面的准确性有所欠缺,但却很好地捕捉到了那个时期的语言风格。来源:https://arxiv.org/pdf/2505.00030
尽管微调过程使模型的输出在一定程度上更接近原始的历史风格,但人类读者依然能够频繁地从中检测出现代语言或思想的痕迹。这表明,即使是经过精心调整的模型,仍然不可避免地会反映出其当代训练数据的影响。研究人员最终得出了一个令人沮丧的结论:目前并没有一种经济实惠的捷径可以生成机器生产的、在习语上正确的历史文本或对话。他们还推测,这一挑战本身可能从一开始就被错误地提出了:
“[我们] 还应该考虑,时代错误在某种意义上可能是不可避免的。无论我们是通过指令微调历史模型,使它们能够进行对话,还是通过教授当代模型模仿较早时期的语言,真实性与对话流畅性之间可能都需要某种妥协。
“毕竟,不存在‘真实’的 21 世纪提问者与 1914 年受访者之间的对话。尝试创建这种对话的研究人员需要反思 [前提],即解释总是涉及现在和 [过去] 之间的协商。”
这项 新研究 的标题是 语言模型能否在不出现时代错误的情况下代表过去?,由来自伊利诺伊大学、不列颠哥伦比亚大学和康奈尔大学的三位研究人员共同完成。
研究现状
最初,研究人员采用了一个三部分的研究方法,首先测试了现代语言模型是否可以通过简单的提示被引导去模仿历史语言。他们选取了 1905 年至 1914 年间出版的书籍中的真实节选,然后要求 ChatGPT‑4o 用相同的习语继续这些段落。
以下是他们选取的一段原始时期的文本示例:
“在最后一种情况下,每分钟可以节省大约五到六美元,因为为了在单分钟内投影静止的人物或风景,需要卷动超过二十码的胶片。因此,获得了固定和移动图像的实际组合,产生了最具艺术效果的效果。
“它还使我们能够交替使用两台电影摄影机进行投影,以避免闪烁,或者同时投影红色和绿色图像并再现自然色彩,从而减轻人眼的生理疲劳,因为人眼习惯于同时接收基本色彩。现在谈谈冷光在瞬间摄影中的应用。”
为了评估生成的文本是否符合预期的历史风格,同时考虑到人们通常并不擅长猜测文本的写作日期,研究人员对 RoBERTa 模型进行了微调,使其能够估计出版日期。他们使用了 美国历史英语语料库 的一个子集,该语料库涵盖了从 1810 年至 2009 年的材料。
随后,研究人员利用经过微调的 RoBERTa 分类器来评估 ChatGPT‑4o 生成的续写。这些续写是基于 1905 年至 1914 年间出版的书籍中的真实段落提示生成的。
系统提示(即关于如何处理任务的上下文指令)如下:
“你的任务是完成 20 世纪早期书籍中的段落。你将获得 1913 年出版的一本书中的一个段落。用相同的风格继续这个段落,至少 200 字。只提供这个续写;不要做任何框架性评论,如‘这是续写:’。”
尽管研究人员尝试了 单次提示和 20 次提示,但 ChatGPT-4o 的输出始终倾向于 21 世纪的风格。
以下是论文中给出的一个例子,展示了 ChatGPT-4o 对关于摄影的真实时期文本的类似博客的续写尝试:
“冷光在瞬间摄影中的应用彻底改变了在不同光照条件下捕捉图像的方法。传统上,摄影师在自然光的严酷性和变化性或闪光摄影的侵入性方面挣扎,这可能会破坏场景的氛围或拍摄对象的自然行为,特别是在野生动物和抓拍人像摄影中。
“冷光以其更柔和、更弥散的特性……允许更自然地呈现色彩和纹理,这在强烈的自然光下往往会丢失。”
正如我们很容易看到的,这种通用的、维基风格的文本并不符合原始时期文本的冗长和华丽的风格。此外,它并没有真正从原始内容结束的地方继续,而是开始对其中一个子主题进行旁征博引的、抽象的思考。
该团队还测试了 GPT‑1914,这是一个较小的 GPT‑2 类模型,从头开始在 1880 年至 1914 年间的 265 亿个文学标记上进行训练。
尽管其输出不如 ChatGPT‑4o 那样连贯,但更符合源时期的风格。以下是论文中提供的唯一例子,同样是作为对关于摄影的真实世界时期文本的续写:
“其作用原理已在第 4 页中解释过。我们这里仅提及,当我们要在涂有火棉胶的纸上获得非常快速的摄影,以及通过明胶板拍摄的照片时,可以有利地应用这种方法。
“在这种情况下,曝光时间至少不应超过一秒钟;但如果希望在更短的时间内——比如半秒钟——完成拍摄,则温度不应低于 20°C,否则图像在显影后会变得太暗;此外,在这些条件下,感光板会失去其灵敏度。
“然而,对于普通用途,通常只需将感光表面暴露在较低的温度下,无需采取任何特殊预防措施,只需保持……” [原文如此]
由于即使是真实和原始的材料也是晦涩难懂且难以理解的,因此很难判断 GPT-1914 在多大程度上准确地从原始内容中延续下来;但输出肯定听起来更符合时期风格。
然而,作者从这个实验中得出结论,简单提示几乎无法克服像 ChatGPT-4o 这样的大型预训练模型的当代偏见。
实现方法
为了衡量模型输出与真实历史写作的相似程度,研究人员使用统计分类器估计每个文本样本的可能出版日期。然后,他们使用 核密度图 可视化结果,该图显示模型认为每个段落在历史时间线上的位置。
基于训练有素的分类器估计的真实和生成文本的出版日期(1905–1914 年的源文本与 GPT‑4o 使用单次提示和 20 次提示的续写,以及仅在 1880–1914 年的文学作品上训练的 GPT‑1914 进行比较)。
作者指出,用于此任务的微调 RoBERTa 模型并非完美无缺,但仍然能够突出显示一般风格趋势。由完全在时期文学上训练的 GPT‑1914 生成的段落聚集在 20 世纪早期——类似于原始源材料。
相比之下,即使在多个历史示例的提示下,ChatGPT-4o 的输出也倾向于类似于 21 世纪的写作,反映了其最初训练的数据。
研究人员使用 Jensen-Shannon 散度量化了这种不匹配,这是一种衡量两个概率分布差异的方法。GPT‑1914 与真实历史文本的得分接近 0.006,而 ChatGPT‑4o 的单次提示和 20 次提示输出显示出更大的差距,分别为 0.310 和 0.350。
作者认为,这些发现表明,即使有多个示例,仅凭提示也无法可靠地产生令人信服地模拟历史风格的文本。
模型微调
论文接着调查了微调是否会产生更好的结果,因为这个过程涉及通过在用户指定的数据上 “继续” 训练来直接影响模型的可用 权重——这个过程可能会影响模型的原始核心功能,但在微调过程中被 “推入” 或强调的领域中,可以显著提高其性能。
在第一次微调实验中,团队在 1905 年至 1914 年间出版的书籍中抽取了大约两千对段落完成对,对 GPT‑4o‑mini 进行训练,目的是看看小规模的微调是否能够将模型的输出转向更符合历史准确性的风格。
使用在早期测试中作为评判的相同基于 RoBERTa 的分类器来估计每个输出的风格 “日期”,研究人员发现,在新的实验中,微调后的模型生成的文本与真实情况紧密对齐。
其与原始文本的风格差异,通过 Jensen-Shannon 散度衡量,降至 0.002,与 GPT‑1914 基本一致:
真实和生成文本的估计出版日期,显示 GPT‑1914 和微调版 GPT‑4o‑mini 如何与 20 世纪早期的写作风格相匹配(基于 1905 年至 1914 年间出版的书籍)。
然而,研究人员警告说,这种指标可能只能捕捉到历史风格的表面特征,而不是更深层的概念或事实性时代错误。
“[这个测试] 并不非常敏感。这里用作评判的 RoBERTa 模型只是被训练来预测日期,而不是区分真实段落和时代错误的段落。它可能使用粗糙的风格证据来进行预测。人类读者或更大的模型可能仍然能够在听起来‘符合时期’的段落中检测出时代错误的内容。”
评估测试
最后,研究人员进行了人类评估测试,使用 250 个手工挑选的 1905 年至 1914 年间出版的书籍中的段落。他们观察到,其中许多文本可能与当时写作时的解释有很大不同:
“我们的列表中包括,例如,关于阿尔萨斯(当时属于德国)的百科全书条目,以及关于脚气病(当时通常被解释为真菌疾病,而不是营养缺乏)的条目。虽然这些都是事实差异,我们还挑选了一些会显示出更微妙的态度、修辞或想象力差异的段落。
“例如,20 世纪早期对非欧洲地方的描述往往滑向种族概括。1913 年对月球日出的描述想象了丰富的色彩现象,因为当时还没有人看到过没有 [大气层] 的世界的照片。”
研究人员为每个历史段落创建了简短的问题,这些问题可以合理地回答,然后在这些问答对上对 GPT‑4o‑mini 进行微调。为了加强评估,他们训练了五个单独的模型版本,每次 留出 不同部分的数据用于测试。
然后,他们使用默认版本的 GPT-4o 和 GPT-4o‑mini 以及微调后的变体生成响应,每个变体都在其在训练期间未见过的部分上进行评估。
总结
为了评估模型在多大程度上能够令人信服地模仿历史语言,研究人员要求三位专家标注者审查 120 个 AI 生成的续写,并判断每一个是否对 1914 年的作者来说是合理的。
这种直接评估方法比预期更具挑战性:尽管标注者在近 80% 的时间里对评估结果达成一致,但他们的判断不平衡(“合理” 的选择频率是 “不合理” 的两倍),这意味着他们实际的一致性水平只有中等,通过 Cohen’s kappa 分数 测量为 0.554。
标注者自己描述这项任务为 困难,通常需要额外的研究来评估一个陈述是否与 1914 年已知或相信的内容一致。
一些段落提出了关于语气和视角的难题——例如,一个回应是否适当地限制了其世界观,以反映 1914 年典型的水平。这种判断通常取决于 种族中心主义 的程度(即,倾向于通过自己文化的假设或偏见来看待其他文化)。
在这种情况下,挑战在于判断一个段落是否表达了足够的文化偏见,使其看起来具有历史合理性,同时又不显得过于现代,或者按照当今的标准过于明显地冒犯性。作者指出,即使对于熟悉该时期的研究人员来说,也很难在感觉符合历史准确性的语言和反映当今思想的
相关文章:
AI 在模仿历史语言方面面临挑战:大型语言模型在生成历史风格文本时的困境与研究进展
概述 在当今数字化时代,人工智能(AI)技术在诸多领域展现出了强大的能力,但在处理历史语言这一特定任务时,却遭遇了不小的挑战。美国和加拿大的研究人员通过合作发现,像 ChatGPT 这样的大型语言模型&#x…...
C++.Windows图形
Windows图形 1. 基础知识1.1 Windows图形编程基础1.2 GDI与GDI1.3 窗口消息处理2.1 注册窗口类2.2 创建窗口2.3 显示窗口3.1 创建按钮3.2 按钮消息处理4.1 设置窗口透明度4.2 透明窗口示例5.1 使用区域创建异形窗口5.2 异形窗口示例6.1 GDI抗锯齿设置6.2 抗锯齿绘图示例7.1 Dir…...
【Vue3】使用vite创建Vue3工程、Vue3基本语法讲解
一、什么是Vite Vite是新一代前端构建工具,官网地址:Vite中文网,vite的优势如下: 轻量快速的热重载(HMR),能实现极速的服务启动对TypeScript、JSX、CSS等支持开箱即用真正的按需编译ÿ…...
专题二:二叉树的深度优先搜索
以leetcode2331题为例 题目分析: 以第一个示例为例 算法原理分析: 从宏观角度,也就是我的算法之回溯的第一篇 我们发现我们在研究示例的时候,必须从下往上推 也就是我在研究一个结点是true还是false的时候,必须…...
Termius ssh连接服务器 vim打开的文件无法复制问题
你的问题是: • 在 Termius (macOS) SSH 连接到 VMware Ubuntu,使用 vim 打开 .cpp 文件时,可以复制文本; • 但在 Windows 10 上 SSH 到 VMware 的 Red Hat 6.4 时,复制操作无效。 ⸻ 🎯 初步分析 复制…...
搭建大数据学习的平台
一、基础环境准备 1. 硬件配置 物理机:建议 16GB 内存以上,500GB 硬盘,多核 CPU虚拟机:至少 3 台(1 主 2 从),每台 4GB 内存,50GB 硬盘 2. 操作系统 Ubuntu 20.04 LTS 或 CentOS…...
Matlab 模糊控制节水洗衣机模型
1、内容简介 Matlab 232-模糊控制节水洗衣机模型 可以交流、咨询、答疑 2、内容说明 略 3、仿真分析 略 4、参考论文 略...
如何找正常运行虚拟机
1.新建虚拟机。Linux centos7,给虚拟机改个名字不要放在c盘 2.安装操作系统。cd/dvd->2009.iso 启动虚拟机...
python二手书交易管理系统
目录 技术栈介绍具体实现截图系统设计研究方法:设计步骤设计流程核心代码部分展示研究方法详细视频演示试验方案论文大纲源码获取/详细视频演示 技术栈介绍 Django-SpringBoot-php-Node.js-flask 本课题的研究方法和研究步骤基本合理,难度适中…...
使用本地部署的 LLaMA 3 模型进行中文对话生成
以下程序调用本地部署的 LLaMA3 模型进行多轮对话生成,通过 Hugging Face Transformers API 加载、预处理、生成并输出最终回答。 程序用的是 Chat 模型格式(如 LLaMA3 Instruct 模型),遵循 ChatML 模板,并使用 apply…...
C++编程练习,认识面向对象权限,如何进行封装
#include <iostream> #include <string> using namespace std; /* 银行的账户是一个模板,是一个类,有存款人信息和账户额度,而具体的存款人视为一个对象, 一个对象不能私自修改账户额度,需要通过一个操作流…...
A Survey of Learning from Rewards:从训练到应用的全面剖析
A Survey of Learning from Rewards:从训练到应用的全面剖析 你知道大语言模型(LLMs)如何通过奖励学习变得更智能吗?这篇论文将带你深入探索。从克服预训练局限的新范式,到训练、推理各阶段的策略,再到广泛…...
电脑端音乐播放器推荐:提升你的听歌体验!
在快节奏的职场环境中,许多上班族都喜欢用音乐为工作时光增添色彩。今天要分享的这款音乐工具,或许能为你的办公时光带来意想不到的惊喜。 一、软件介绍-澎湃 澎湃音乐看似是个普通的播放器,实则藏着强大的资源整合能力。左侧功能栏清晰陈列着…...
小刚说C语言刷题—1149 - 回文数个数
1.题目描述 一个正整数,正读和反读都相同的数为回文数。 例如 22, 131, 2442 , 37073, 66,…… 所有 11位数都是回文数。 给出一个正整数 n ( 1≤n≤10000 ),求出 1,2…...
基于SpringBoot的博客系统测试报告
一、编写目的 本报告为博客系统测试报告,本项目模拟了csdn,实现了包括了用户登录,发布博客文章,查看博客等功能。 二、项目背景 博客系统采用前后端分离的方法来实现,同时使用了数据库来存储相关的数据,…...
Koa知识框架
一、核心概念 1. 基本特点 由 Express 原班人马开发的下一代 Node.js Web 框架 基于中间件的洋葱圈模型 轻量级核心(仅约 600 行代码) 完全使用 async/await 异步流程控制 没有内置任何中间件,高度可定制 2. 核心对象 Application (Ko…...
React Native踩坑实录:解决NativeBase Radio组件在Android上的兼容性问题
React Native踩坑实录:解决NativeBase Radio组件在Android上的兼容性问题 问题背景 在最近的React Native项目开发中,我们的应用在iOS设备上运行良好,但当部署到Android设备时,进入语言设置和隐私设置页面后应用崩溃。我们遇到了…...
RCE联系
过滤 绕过空格 ● 进制绕过 题目练习 数字rce 使用$0执行bash,<<<将后面的字符串传递给左边的命令。 例如: <?php highlight_file(__FILE__); function waf($cmd) { $whiteList [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, \\, \, $, <]; $cmd_ch…...
区块链大纲笔记
中心化出现的原因是由于网络的形成(不然就孤立了,这显然不符合现实,如,社会,计算机网路),接着由于网络中结点能力一般不对等同时为了便于管理等一系列问题,导致中心化网络的出现。&a…...
SQL:JOIN 进阶
目录 JOIN 是什么? 🔹OUTER JOIN(外连接) 外连接的分类 外连接与内连接的区别 🔹USING 子句 语法结构 和 ON 的对比 📘USING 的内部逻辑 🧩 多个字段的 USING USING 的 SELECT 特性&a…...
SATA—Link层状态机
一、概述 Link层的状态机大致可以分为五类: 链路层空闲状态机通信异常处理状态机链路层发送状态机链路层接收状态机链路层电源管理下的状态机 二、链路层空闲状态机 链路层空闲状态机共包含两个状态L_IDLE、L_SyncEscape,每个状态下的处理机制与条状…...
12.2.2 allocator类
allocator类将分配内存空间、调用构造函数、调用析构函数、释放内存空间这4部分操作分开,全部交给程序员来执行,不像new和delete #include <iostream> #include <string>int main() {const int n 10;std::allocator<std::string> al…...
Qwen:Qwen3,R1 在 Text2SQL 效果评估
【对比模型】 Qwen3 235B-A22B(2350亿总参数,220亿激活参数),32B,30B-A3B;QwQ 32B(推理模型)DeepSeek-R1 671B(满血版)(推理模型) 1&a…...
Egg.js知识框架
一、Egg.js 核心概念 1. Egg.js 简介 基于 Koa 的企业级 Node.js 框架(阿里开源) 约定优于配置(Convention over Configuration) 插件化架构,内置多进程管理、日志、安全等能力 适合中大型企业应用,提供…...
latex控制表格宽度,不要超出页面
字体控制 控制表格的字体,一般使用 footnotesize ,neurips 使用的就是这个大小 列宽距控制 默认列宽距是 6pt ,可以人工调节成为 5pt,不影响字体,比较不影响可读性 % 对于 table* 环境, [htbp] 通常比 [h] 或 [h!]…...
Linux进程管理
程序、进程、服务 程序 program 安装包,未运行的代码,APP 存放在磁盘上 进程 process 已运行程序、命令、服务,一个程序可以运行多个进程、父进程启动子进程 运行在内存中 服务 service 一直运行的进程,也叫做守护进程&…...
[springboot]SSM日期数据转换易见问题
日期数据的形式有多种,如2025-05-12 14:46:50、2025.05.12 14:46,可以没有年只有月日...等等。 在SSM项目中,前后端传递日期数据时往往需要统一格式,不然会报数据类型转换异常。 在controller层中用实体类实例对象接收前端服务器传…...
数字IC后端培训教程之数字后端项目典型案例分析
今天给大家分享下最近小编帮助学员解决的几个经典数字IC后端项目问题。希望能够对大家的学习和工作有所帮助。 数字IC后端项目典型问题之后端实战项目问题记录(2025.04.24) 数字IC后端设计实现培训教程(整理版) Q1: 老师好&…...
数字ic后端设计从入门到精通4(含fusion compiler, tcl教学)CMOS VLSI Design
Layout Design Rules 一、什么是 Layout Design Rules? 布局设计规则是一套用于指导芯片物理设计的几何约束条件,确保设计可以在特定制造工艺下被正确制造。这些规则通常由代工厂(foundry)提供,规定了最小线宽、间距、…...
服务器带宽基础知识
服务器带宽基础知识详解 一、带宽的定义与基本概念 服务器带宽(Bandwidth)是指服务器与互联网之间在单位时间内传输数据的能力,通常以 Mbps(兆比特每秒) 或 Gbps(吉比特每秒) 为单位衡量。它决…...
算法-单调栈
739. 每日温度 - 力扣(LeetCode) 原理:739. 每日温度 - 力扣(LeetCode) class Solution { public:vector<int> dailyTemperatures(vector<int>& temperatures) {stack<int>sta;int ntemperatu…...
大核极坐标码
大核极性码(ℓ>2)的SC解码操作与原始极性码相似。迭代地,解码方程可以表示为: 这是给定信道输出的路径的概率。 虽然这些操作类似于传统的极坐标码,但迭代计算概率的复杂性相对于ℓ 作为,这使得它对于非…...
如何避免 JavaScript 中常见的闭包陷阱?
文章目录 1. 引言2. 什么是闭包?3. 常见的闭包陷阱及解决方案3.1 循环中的闭包陷阱3.2 内存泄漏3.3 意外的全局变量3.4 React 中的闭包陷阱 4. 总结 1. 引言 闭包(Closure)是 JavaScript 中一个强大而常用的特性,它允许函数访问其…...
免费多线程下载工具
先放下载链接:https://tool.nineya.com/s/1ir25buco Free Download Manager,简称“FDM”,是一款多线程下载工具,支持多端使用哦,像Windows、mac Os、Linux、浏览器插件以及安卓端都涵盖在内,这些版本这里都…...
Aware和InitializingBean接口以及@Autowired注解失效分析
Aware 接口用于注入一些与容器相关信息,例如: a. BeanNameAware 注入 Bean 的名字 b. BeanFactoryAware 注入 BeanFactory 容器 c. ApplicationContextAware 注入 ApplicationContext 容器 d. EmbeddedValueResolverAware 注入 解析器&a…...
【NextPilot日志移植】日志写入流程
📝 文件后端日志写入流程详解 当后端选择文件时,日志写入过程主要涉及 LogWriter 和 LogWriterFile 类的协作。以下是详细的日志写入过程解释及涉及的代码: 1. LogWriter 类初始化 在 LogWriter 类的构造函数中,如果配置的后端…...
OpenCV直方图与直方图均衡化
一、图像直方图基础 1. 什么是图像直方图? 图像直方图是图像处理中最基本且重要的统计工具之一,它用图形化的方式表示图像中像素强度的分布情况。对于数字图像,直方图描述了每个可能的像素强度值(0-255)在图像中出现…...
Babel进阶:如何自定义插件?
Babel 是一个非常流行的 JavaScript 编译器,下面我们将从零到一编写一个 babel 箭头函数语法转换插件,掌握 babel 插件设计思路与编写规范,需求很简单就是将箭头函数转换为普通函数。 const test ()>{console.log("Hello World!&qu…...
C++中类中const知识应用详解
下面将从**const 成员**、const 成员函数、const 对象、mutable、constexpr 等方面,逐一详解 C 类中常见的 const 用法及注意事项,并配合示例。 一、const 数据成员 必须在初始化列表中初始化 class A {const int x; // const 成员 public:A(int v) :…...
LeetCode 513 找树左下角的值 LeetCode 112 路径总和 LeetCode106 从中序与后序遍历序列构造二叉树
LeetCode 513 找树左下角的值 迭代法——层序遍历 思路:对树进行层序遍历操作,层序遍历完后,输出树最后一层的第一个节点。 # Definition for a binary tree node. # class TreeNode(object): # def __init__(self, val0, leftNone, r…...
电脑端实用软件合集:土拨鼠+Rufus+实时网速监控工具
朋友们好,我是李师傅!今天带来三款让人直呼"真香"的电脑工具,它们就像武林高手各怀绝技,保证让你工作效率翻倍! 1Tuboshu(电脑) 最近发现一款神奇工具——Tuboshu(发音类…...
杨校老师项目之基于SSM与JSP的鲜花销售系统-【成品设计含文档】
基于SSMJSP鲜花商城系统 随着电子商务的快速发展,鲜花在线销售已成为一种重要的消费模式。本文设计并实现了一个基于JSP技术的鲜花销售管理系统,采用B/S架构,使用SSM框架进行开发,并结合Maven进行项目依赖管理。系统分为前台用户模…...
linux服务器免密脚本分享
#!/bin/bash set -euo pipefail# 基础环境配置 setenforce 0 >/dev/null 2>&1 || true sed -i "s/SELINUXenforcing/SELINUXdisabled/" /etc/selinux/config systemctl stop firewalld >/dev/null 2>&1 || true systemctl disable firewalld >…...
STM32实现循环队列
1. 循环队列的核心结构设计 数据结构定义:通常使用结构体封装队列的指针、长度及缓冲区。例如: typedef struct {u16 Head; // 队头指针u16 Tail; // 队尾指针u16 Length; // 当前队列长度u8 Rsv_DAT[50]; // 缓冲区数组 } ringbuff_t; 其中…...
matlab simulink双边反激式变压器锂离子电池均衡系统,双目标均衡策略,仿真模型,提高均衡速度38%
双边反激式变压器锂离子电池均衡系统,双目标均衡策略 锂离子电池均衡系统综述 引言 电池均衡管理系统(Battery Balancing Management System, BBMS)是电池管理系统(BMS)的核心组成部分,主要用于解决电池组中单体电池间的不一致性问题。随着电动汽车、储能…...
数据库笔记(1)
文章目录 1.SQL的通用语法2.四类SQL语句2.1DDL语句2.2.1数据库操作2.1.2表操作 2.2DML语句2.2.1添加数据(INSERT)2.2.2修改数据(UPDATE)2.2.3删除数据(DELETE) 2.3DQL语句2.3.1DQL语法2.3.2基本查询2.3.3条件查询2.3.4分组查询2.3.5排序查询2.3.6分页查询2.3.7DQL语句的执行顺序…...
深入掌握CSS定位:构建精密布局的核心技术
一、定位的定义 定位(Positioning)是CSS中用于控制元素在网页中的具体位置的一种机制。通过定位,可以将元素放置在页面的任意位置,并控制其与其他元素的层叠关系。 二、定位的特点与作用 自由摆放位置: 允许元素摆放…...
使用达梦数据库官方管理工具SQLark导入与导出数据库表
SQLark 是达梦数据官方自主研发的、一款面向信创应用开发者的数据库开发和管理工具。只需简单注册,即可永久免费使用其客户端功能。该工具支持连接达梦、Oracle、MySQL 等多种数据库,为开发者提供了便捷的跨平台操作体验。通过访问官网 www.sqlark.com&a…...
Linux系统管理与编程19:自动部署dns
兰生幽谷,不为莫服而不芳; 君子行义,不为莫知而止休。 #!/bin/bash #----------------------------------------------------------- #前提条件:准备好虚拟机,①外网内网畅通,②yum源搭建好 # File Name: …...
JavaScript高级进阶(七)
this对象 想知道this对象是什么,我们先来看一段简单的小代码: <style> div{ width: 200px; height: 200px; background-color: skyblue; } </style> </head> <body> <div…...