赋予AI更强的“思考”能力
刚刚!北大校友、OpenAI前安全副总裁Lilian Weng最新博客来了:Why We Think
原文链接:Why We Think by Lilian Weng
这篇文章关注:如何让AI不仅仅是“知道”答案,更能“理解”问题并推导出答案。通过赋予AI更强的“思考”能力,未来的AI系统有望在更多复杂和关键的领域发挥更大的作用。探讨的是如何让AI模型(尤其是大型语言模型,LLM)在回答问题或解决任务前,能有更多的“思考时间”,从而变得更“聪明”,能处理更复杂的问题。 这对我们程序员来说,就像我们写代码解决复杂逻辑时,需要时间去构思、打草稿、调试,而不是一蹴而就。
核心观点:给AI更多“思考时间”
文章开篇就点明,让模型在预测前花更多时间去“思考”(例如通过巧妙的解码策略、思维链推理、潜在思考等),对于解锁更高层次的智能非常有效。
- AI的“快思考”:像程序员写个“Hello World”,或者依靠肌肉记忆快速敲出常用代码片段。
- AI的“慢思考”:像程序员要设计一个复杂的算法,或者调试一个隐藏很深的bug,需要仔细分析、一步步推演。这篇文章主要讨论如何赋予AI这种“慢思考”的能力。
“思考时间”在AI里,主要指的是模型在“测试阶段”(也就是我们实际使用它,让它生成答案或执行任务的阶段)所进行的计算量。计算量越大,可以认为它的“思考”就越充分。
为什么“思考时间”能提升AI表现?理论基础
Lilian Weng从几个角度解释了为什么这样做是有效的:
-
借鉴人类的思考模式:系统1 vs 系统2
- 系统1 (快思维):自动、快速、凭直觉。比如我们开车时的一些本能反应。AI直接输出答案,没有中间步骤,可以看作是系统1。
- 系统2 (慢思维):需要集中注意力,进行逻辑推理,比较费力但更可靠。比如我们做复杂的数学题。AI通过一步步推理(比如思维链)得出答案,就是在启用系统2。
- 文章认为,通过激活AI的“系统2”,让它有意识地放慢速度,进行更多反思和分析,可以做出更理性、更准确的决策。
-
计算也是一种宝贵资源
- 神经网络可以看作是通过计算和存储资源来解决问题的。如果我们设计的模型架构允许在测试时调用更多计算资源,并且模型学会了有效利用这些资源,那么性能自然会更好。
- 这就像给我们的程序更多的CPU时间和内存,它就能处理更大数据量或运行更复杂的算法。
-
用潜变量来建模思考过程 (Latent Variable Modeling)
- 我们可以把AI解决问题的过程看作一个概率模型。最终的答案 (y) 是基于输入 (x) 和一些我们观察不到的“中间思考步骤” (潜变量z) 生成的。
- 目标是优化 P(y|x) = ∑ P(z|x)P(y|x,z),也就是说,AI需要考虑所有可能的“思考路径”z,并综合它们来得到最好的答案y。
- 对程序员来说,潜变量z就像一个复杂函数内部的那些局部变量或中间计算结果,它们对最终输出至关重要,但从外部是看不到的。
AI如何实现“多思考一会儿”?技术方法
文章介绍了很多让模型在输出答案前进行更多计算和推理的具体技术:
-
思维链 (Chain-of-Thought, CoT)
- 核心思想:不是直接给出答案,而是先让模型生成一系列中间的推理步骤,就像我们解应用题时写的演算过程一样。
- 怎么做:
- 监督学习:用人工编写的、包含详细解题步骤的数据去训练模型。
- 提示工程 (Prompting):通过给模型一些提示,比如“让我们一步一步地思考(Let’s think step by step)”,来引导它生成推理过程。
- 强化学习 (RL):对于那些有标准答案、可以自动验证对错的任务(比如数学题、编程题的单元测试),如果模型生成的推理步骤能得到正确答案,就给它奖励,从而强化这种能力。
- 效果:CoT能显著提升模型解决复杂问题的能力,特别是数学问题,模型规模越大,CoT带来的好处越明显。
-
优化解码策略:并行与修正
- 并行采样 (Parallel Sampling):一次性生成多个可能的答案或推理路径,然后从中选最好的。
- Best-of-N:生成N个候选,然后用一个评估标准(比如一个验证器模型)来打分,选得分最高的。就像我们写代码时可能会尝试几种不同的实现方式,然后选效果最好的那个。
- 束搜索 (Beam Search):在生成答案的每一步都保留几个最有可能的选项,逐步扩展。
- 自洽性 (Self-Consistency):生成多个不同的CoT推理序列,然后看哪个最终答案出现的次数最多(多数投票)。
- 序列修订 (Sequential Revision):让模型对它自己之前生成的答案进行反思和迭代修改。
- 自我修正学习:专门训练一个“修正器模型”,它接收初始模型的输出以及一些反馈信号(比如编译器错误、单元测试结果),然后生成一个修正后的版本。 这就像我们写完代码后,根据测试结果或同事的代码评审意见来修改代码。
- SCoRe (Self-Correction via Reinforcement Learning):用强化学习的方法,鼓励模型在第二次尝试时,能比第一次做得更好。
- 并行采样 (Parallel Sampling):一次性生成多个可能的答案或推理路径,然后从中选最好的。
-
强化学习 (RL) 的妙用
- RL在提升模型推理能力方面非常成功,尤其是那些答案可以被自动验证对错的任务。
- DeepSeek-R1 模型的训练案例 :它通过多轮“监督微调 (SFT) + 强化学习 (RL)”的流程,在数学、编程等复杂推理任务上取得了很好的效果。 训练时会给两类奖励:一是“格式奖励”,鼓励模型按特定格式生成CoT;二是“准确性奖励”,奖励最终答案的正确性。
- 一个很有意思的发现是“顿悟时刻 (Aha moment)” :即使没有精心的监督微调,单纯依靠强化学习,模型也能自发学会一些高级的推理能力,比如反思之前的错误并尝试新的解法。 这有点像我们程序员在调试一个难题时,突然灵光一闪,找到了问题所在或想到了新的解决思路。
-
调用外部“大脑”:整合外部工具
- AI模型并不需要自己从零开始学习所有事情。对于某些计算密集型或需要特定知识的任务,它可以调用外部工具来帮忙。
- PAL (Program-Aided Language Models) 和 Chain of Code:让LLM生成代码(比如Python代码),然后交给外部的代码解释器去执行,得到结果后再返回给LLM。 这对于数学计算、符号推理等特别有效。
- ReAct (Reason+Act):让模型能够将“思考”(生成推理步骤)和“行动”(调用外部API,比如搜索维基百科)结合起来,从而将外部知识融入到它的推理过程中。
- 这就像我们程序员在写代码时,会大量使用各种库函数、第三方API来完成特定功能,而不是所有东西都自己写。
“让AI好好思考”的挑战与难题
虽然让AI“多思考”听起来很美好,但在实践中也面临很多困难:
-
AI真的在“思考”吗?思维的忠实性 (Faithfulness of Thought)
- 当模型生成了一长串“思维链”(CoT)时,这些步骤真的反映了它是如何得到答案的内部逻辑吗?还是说,它只是学会了生成一些看起来像那么回事的“解释文本”?
- 研究表明,有时CoT中的某些步骤即使是错误的,或者被替换成无关紧要的填充文本,模型依然能给出正确答案,这说明CoT可能并不总是那么“忠实”。
- 对程序员来说,这就像代码注释:注释写得再好,也不一定完全等于代码的实际行为。我们需要警惕这种“表里不一”。
-
小心AI“钻空子”:奖励破解 (Reward Hacking)
- 在使用强化学习训练AI时,如果奖励机制设计得不够好,AI可能会找到一些“捷径”来获得奖励,但并没有真正学会解决问题。
- 比如,在一个编程任务中,AI可能学会了利用单元测试的某个漏洞提前结束,从而“骗过”测试获得奖励,但它并没有写出正确的代码。
- 这就像我们玩游戏时可能会利用bug来快速通关,但并没有真正体验游戏的乐趣和挑战。
-
“自我批评”太难了:自我修正的困境
- 让AI模型有效地进行自我反思和修正错误,其实非常困难,尤其是在没有外部反馈(比如正确答案或人类指导)的情况下。
- 模型可能会把原本正确的答案改成错误的,或者陷入“原地踏步”不怎么修改的状态,甚至产生新的“幻觉”。
- 这有点像我们自己写完文章后,往往很难发现里面所有的问题,需要别人帮忙校对。
-
对CoT的优化压力可能适得其反
- 如果在训练时,过于强调CoT本身要“写得好”(比如给“流畅的CoT”额外奖励),模型可能会学会隐藏它真实的、可能存在问题的推理过程,只给你看它精心“粉饰”过的CoT。这使得发现和修复潜在的“奖励破解”行为更加困难。
为“思考”而生的新模型架构
为了更好地支持AI进行深度思考,研究者们也在探索新的模型架构:
-
让信息“循环起来”:递归架构 (Recursive Architectures)
- 传统的Transformer模型是一层层往前计算的。递归架构则允许模型的某些部分(或者整个模型)可以被重复调用和执行多次,从而实现更深层次的计算和“思考”。
- Universal Transformer 就是一个早期的例子,它结合了Transformer的自注意力和RNN的递归机制。
- 最近有研究在Transformer中加入一个“递归块”,让信息可以在这个块里进行多次迭代处理,每次迭代都会结合原始输入,从而逐步精炼思考结果。
- 这有点像我们编程中的递归函数,通过不断调用自身来解决可以被分解的子问题。
-
“沉默的思考者”:思考Token (Thinking Tokens)
- 这是一种很有意思的方法:在模型的输入或生成过程中,插入一些特殊的“思考Token”。这些Token本身并不对应任何实际的词语或输出,它们的作用是给模型提供额外的计算“时间片”,让模型在内部进行更多的“思考”和信息整合,然后再生成下一个实际的Token。
- 比如,可以在句子的每个词后面都插入一个
<T>
(思考)Token来训练模型。或者在输入序列的末尾添加一些“暂停Token”(比如.
或#
字符)来延迟模型的输出,从而争取更多的计算时间。 - Quiet-STaR 则更进一步,它训练模型在生成每个真实Token之前,先在内部生成一个解释未来文本的“理由”(rationale),这个理由是隐式的,不直接输出,但能帮助模型做出更好的预测。
- 这有点像我们程序员在思考一个复杂逻辑时,脑子里可能会闪过很多中间念头和推理片段,这些并不直接写到代码里,但对最终形成解决方案至关重要。
把“思考”看作潜变量:迭代学习与优化
-
期望最大化 (Expectation-Maximization, EM) 算法
- 这是一种经典的优化含有潜变量(比如我们这里说的“潜在思考过程”)模型参数的方法。它通过在E步(期望步,猜测潜变量是什么样的)和M步(最大化步,根据猜测的潜变量来优化模型参数)之间迭代,来逐步提升模型。
- 研究者尝试用EM算法来训练带有“潜在思维”的模型,比如先用一个大模型根据观察到的数据去“脑补”出中间的潜在思维步骤,然后再用这些“数据+潜在思维”去训练目标模型。
-
迭代式自我学习:STaR算法
- STaR (Self-Taught Reasoner) 算法的核心思想是:让模型先生成多个思维链(CoT),然后只用那些能够推导出正确答案的CoT来对模型自身进行微调。
- 如果模型一开始解决不了某个问题(生成的CoT是错的),STaR还会引入一个“合理化 (Rationalization)”的步骤:让模型回头看,根据问题和已知的正确答案,来“事后诸葛亮”式地生成一个好的、能通向正确答案的CoT。这样模型也能从失败中学习。
- 通过这种不断的“生成-筛选-学习-合理化”的迭代,模型解决问题的能力和生成高质量CoT的能力都会逐步提升。
“思考时间”的缩放规律 (Scaling Law)
- 研究发现,在AI模型中,投入更多的“测试时计算”(即思考时间)确实能带来性能提升,这与我们熟知的通过增加模型参数规模、训练数据量来提升性能的“缩放定律”是互补的。
- 有时候,让一个小模型进行充分的“思考”,其效果可能比一个只是参数量巨大但“思考”不足的大模型更好,这在计算成本和性能之间提供了一个新的权衡。
- 不过,测试时计算和预训练计算(即训练模型时消耗的算力)并非完全等价。对于非常困难的问题,或者当基础模型能力本身就比较弱时,单纯增加“思考时间”可能效果有限。强大的基础模型仍然是根本。
- 一个有趣的现象是,虽然通常情况下,让模型思考更久(生成更长的CoT)能提升准确率,但如果只是简单粗暴地强迫模型生成更长的CoT(比如通过拒绝采样),有时反而会导致性能下降。这说明“思考”的质量比单纯的“时长”更重要。
未来展望:AI将如何“思考”?
文章最后也畅想了未来,并提出了一些值得进一步研究的开放性问题:
- 我们能否训练出既能生成人类可读、又忠实反映其内部推理过程的CoT,同时还能避免“奖励破解”的模型?
- 当没有标准答案可供参考时(比如创意写作、人生建议这类任务),如何让模型有效地进行自我纠正,而不产生幻觉或性能倒退?
- AI模型如何能根据当前问题的难度,来自适应地调整它需要投入的“思考时间”和计算资源?
启示
- 复杂问题的解决之道:无论是人类还是AI,处理复杂问题都需要系统性的思考和分析,而不是单凭直觉。
- 过程比结果更重要(有时是这样):CoT和各种解码策略都强调了“思考过程”对于得出正确结果的价值。我们写代码时,清晰的逻辑、良好的注释、模块化的设计,这些“过程”的质量直接影响最终软件的质量。
- 迭代、反思与修正:AI的自我修正、序列修订等方法,与我们软件开发中的迭代开发、代码评审、重构、调试等过程异曲同工。
- 善用工具:AI模型通过调用外部工具来增强自身能力,这和我们程序员依赖各种库、框架、API来提升开发效率和软件功能是一样的。
- 保持批判性思维:对AI“思维忠实性”的探讨提醒我们,在使用AI工具(尤其是那些声称能“解释”自己的AI)时,不能盲目相信其输出,要多一份审视。
相关文章:
赋予AI更强的“思考”能力
刚刚!北大校友、OpenAI前安全副总裁Lilian Weng最新博客来了:Why We Think 原文链接:Why We Think by Lilian Weng 这篇文章关注:如何让AI不仅仅是“知道”答案,更能“理解”问题并推导出答案。通过赋予AI更强的“思…...
微服务项目->在线oj系统(Java版 - 1)
相信自己,终会成功 目录 C/S架构与B/S架构 C/S架构(Client/Server,客户端/服务器架构) 特点: 优点: 缺点: 典型应用: B/S架构(Browser/Server,浏览器/服务器架构&a…...
【深度学习】使用块的网络(VGG)
虽然 AlexNet 证明深层神经网络卓有成效,但它没有提供一个通用的模板来指导后续的研究人员设计新的网络。 也就是说尽管我知道了更深更大的网络更有效,但是不清楚怎么让它更深更大,从而起到一个更好的效果。 于是,研究人员开始从单…...
Python数据可视化 - Pyecharts绘图示例
文章目录 一、Pyecharts简介及安装1. Pyecharts简介2. 安装Pyecharts 二、准备数据三、饼图示例1. 初始化选项配置2. 饼图相关设置3. 全局配置项3.1 标题配置项3.2 图例配置项3.3 提示框配置项3.4 工具箱配置项3.5 视觉映射配置项 4. 系列配置项4.1 标签选项配置4.2 图元样式配…...
Day29
复习日 知识点回顾 类的装饰器装饰器思想的进一步理解:外部修改、动态类方法的定义:内部定义和外部定义 作业:复习类和函数的知识点,写下自己过去29天的学习心得,如对函数和类的理解,对python这门工具的理…...
Python列表全面解析:从入门到精通
文章目录 Python列表全面解析:从入门到精通一、列表基础1. 什么是列表?2. 列表特性总结表 二、列表的基本操作(基础)1. 访问元素2. 修改列表 三、列表的常用方法(基础)1. 添加元素的方法2. 删除元素的方法3. 查找和统计方法4. 排序和反转 四、列表的高级…...
Nacos数据写入流程
在 3 节点的 Nacos 集群中,数据写入流程和主节点(Leader)的角色基于 Nacos 的分布式一致性协议(通常使用 Raft 协议)来实现。以下以 Markdown 格式详细说明 3 节点 Nacos 集群的数据写入流程以及主节点的角色和确定方式…...
《P4551 最长异或路径》
题目描述 给定一棵 n 个点的带权树,结点下标从 1 开始到 n。寻找树中找两个结点,求最长的异或路径。 异或路径指的是指两个结点之间唯一路径上的所有边权的异或。 输入格式 第一行一个整数 n,表示点数。 接下来 n−1 行,给出…...
Ansible模块——文件属性查看,文件或目录创建和属性修改
ansible.builtin.stat 可以查看文件信息。 选项 类型 默认值 描述 pathstrnull 要检查的文件或目录的完整路径(必需)。 followboolfalse 如果是符号链接,是否跟随到目标路径上获取其状态。 get_attributesbooltrue 是否返回扩展属性&#…...
【图像生成大模型】Wan2.1:下一代开源大规模视频生成模型
Wan2.1:下一代开源大规模视频生成模型 引言Wan2.1 项目概述核心技术1. 3D 变分自编码器(Wan-VAE)2. 视频扩散 Transformer(Video Diffusion DiT)3. 数据处理与清洗 项目运行方式与执行步骤1. 环境准备2. 安装依赖3. 模…...
AGI大模型(25):LangChain提示词模版
我们也可以创建prompt template, 并引入一些变量到prompt template中,这样在应用的时候更加灵活。 1 代码实现 # 我们也可以创建prompt template, 并引入一些变量到prompt template中,这样在应用的时候更加灵活 from langchain_core.prompts import ChatPromptTemplate from…...
mybatis中的resultMap的association及collectio的使用
目录 1.reusltmap的说明 2.association的使用 3.collection的使用 4.总结 1.reusltmap的说明 resultmap定义了数据库的结果映射到java对象的规则,resultmap包含4个属性: id: ResultMap 的唯一标识 type: 映射到的 Java 类型(全限定类名或…...
静态网站部署:如何通过GitHub免费部署一个静态网站
GitHub提供的免费静态网站托管服务可以无需担心昂贵的服务器费用和复杂的设置步骤,本篇文章中将一步步解如何通过GitHub免费部署一个静态网站,帮助大家将创意和作品快速展现给世界。 目录 了解基础情况 创建基础站点 在线调试站点 前端项目部署 部署…...
Android 手写签名功能详解:从原理到实践
Android 手写签名功能详解 1. 引言2. 手写签名核心实现:SignatureView 类3. 交互层实现:MainActivity 类4. 布局与配置5. 性能优化与扩展方向 1. 引言 在电子政务、金融服务等移动应用场景中,手写签名功能已成为提升用户体验与业务合规性的关…...
【iOS(swift)笔记-9】WKWebView无法访问网络
对于iOS 在info中添加App Transport Security Settings,然后在App Transport Security Settings里添加Allow Arbitrary Loadstrue 对于macOS 除了上面的操作,还需在项目信息的App Sandbox里有个Network打钩选项...
Adapter适配器模式
Adapter适配器模式是一种结构设计模式,用于解决接口不兼容的问题,通过适配器类,可以将一个类的接口转换为客户渴望的另一个接口,从而使原来无法协作的对象能够一起工作。 角色和职责: 目标接口(Target&…...
七、xlib窗口渲染
文章目录 1.渲染图片2.双缓冲3.混合图片4.渐变窗口 1.渲染图片 在上篇文章中的最后,我们使用libpng加载了一个png图片,并显示到窗口上,但是我们可以看到显示到窗口的图片周边有黑色的背景。原因是在我测试的操作系统下使用xlib创建的窗口默认…...
python中http.cookiejar和http.cookie的区别
在Python中,http.cookiejar和http.cookie(通常指http.cookies模块)是两个不同的模块,它们的主要区别如下: 1. 功能定位 http.cookiejar 用于管理HTTP客户端的Cookie,提供自动化的Cookie存储、发送和接收功…...
架构设计模式:构建健壮、可扩展的 Serverless 应用
架构设计模式:构建健壮、可扩展的 Serverless 应用 到目前为止,我们已经掌握了 Serverless 的基本概念,了解了 FaaS 和 BaaS 如何协同工作,学会了使用框架进行开发部署,并知道了如何监控和排查问题。现在,是时候从“能用”向“好用”迈进了。 仅仅将代码部署到 Lambda 函…...
2- PyTorch
文章目录 1. Overview2. 线性模型 1. Overview 在人的智能中,最经常做的事情是推理和预测,在机器学习中也是如此。我们在以往的算法课中,所接触的穷举、贪心、分治和动规等算法都是由人设计的,而在机器学习中,算法是由…...
MinIO:从入门到精通,解锁云原生存储的奥秘
一、引言:为什么 MinIO 正在重塑存储世界? 在云计算和大数据时代,传统存储系统面临扩展性差、成本高、兼容性不足等挑战。MinIO 凭借其 S3 兼容性、分布式架构、高性能存储 等特性,成为企业构建现代化存储基础设施的首选。 本文…...
【LeetCode 热题100】739:每日温度(详细解析)(Go语言版)
🌡️ LeetCode 739:每日温度(详解 单调栈 多种思路对比) 📌 题目描述 给定一个整数数组 temperatures,表示每天的温度,返回一个数组 answer,其中 answer[i] 是指在第 i 天之后&am…...
Linux学习笔记|GCC编译指令基础|静动态库|makefile
一、GCC 编译指令基础 基本编译命令 gcc -o code code.c和gcc code.c -o code:这两条命令功能相同,都是使用 GCC 编译器将code.c源文件编译成名为code的可执行文件。-o选项用于指定输出文件名,选项位置在源文件前后不影响最终结果。 编译过程…...
【LeetCode 热题100】17:电话号码的字母组合(详细解析)(Go语言版)
☎️ LeetCode 17. 电话号码的字母组合(回溯 DFS 详解) 📌 题目描述 给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按任意顺序返回。 数字到字母的映射如下(与电话按键相同)…...
C++学习:六个月从基础到就业——C++17:std::optional/variant/any
C学习:六个月从基础到就业——C17:std::optional/variant/any 本文是我C学习之旅系列的第四十七篇技术文章,也是第三阶段"现代C特性"的第九篇,主要介绍C17引入的三个重要工具类型:std::optional、std::varia…...
Go语言中函数 vs 方法
函数(Function):不属于任何类型,是全局可调用的。 方法(Method):绑定在某个类型上的函数,调用时依赖于这个类型的值或指针。 一、函数(Function) func 函数…...
代码随想录算法训练营第六十五天| 图论10—卡码网94. 城市间货物运输 I,95. 城市间货物运输 II
被学校课程轰炸了一周,回过头发现训练营已经要结束了,抓紧时间补完。不过算法这边也很难,感觉每天都是勉强理解在干什么的状态。 94. 城市间货物运输 I 94. 城市间货物运输 I SPFA算法,也是Bellman_ford 队列优化算法 优化原理…...
TDengine 在新能源领域的价值
能源数据的定义 能源数据是指记录和描述能源产业各个方面的信息,包括能源生产、供应、消费、储备、价格、排放以及相关政策和技术的数据。这些数据可以通过各种途径收集和整理,如能源企业的统计报表、政府部门的调查和监测、国际组织的发布数据等。 能…...
浅谈Frida 检测与绕过
目录 ptrace 占位与进程名检测端口检测与 D-Bus 协议通信扫描 /proc 目录(maps、task、fd)定位 so 中的 SVC syscall内存动态释放代码 1. ptrace 占位与进程名检测 检测方式 遍历运行进程列表,检查是否存在 frida-server 或相关进程名&…...
WaterStamp —— 一个实用的网页水印生成器开发记
我正在参加CodeBuddy「首席试玩官」内容创作大赛,本文所使用的 CodeBuddy 免费下载链接:腾讯云代码助手 CodeBuddy - AI 时代的智能编程伙伴 最近,我和 CodeBuddy 一起完成了一个名为 WaterStamp 的网页水印生成器项目。这个小工具主要用于给…...
【MySQL】存储过程,存储函数,触发器
目录 准备工作 一. 存储过程 1.1.什么是存储过程 1.2.创建存储过程 1.3.创建只显示大于等于指定值的记录的存储过程 1.4.显示,删除存储过程 二. 存储函数 2.1.什么是存储函数 2.2.使用存储函数 2.2.1.使用存储函数之前 2.2.2.使用存储函数计算标准体重 …...
python打卡第29天
知识点回顾 类的装饰器装饰器思想的进一步理解:外部修改、动态类方法的定义:内部定义和外部定义 作业:复习类和函数的知识点,写下自己过去29天的学习心得,如对函数和类的理解,对python这门工具的理解等&…...
vim - v
在 Vim 中,使用 可视模式(Visual Mode) 可以选中文本并进行复制、剪切、粘贴等操作。以下是详细的使用方法: 1. 进入可视模式 命令功能v字符可视模式(按字符选择)V(大写)行可视模式…...
Linux 线程(上)
前言:大家早上中午晚上好!!今天来学习一下linux系统下所谓的线程吧!!! 一、重新理解进程,什么是进程? 1.1 图解 其中黑色虚线部分一整块就是进程,注意:一整…...
# 终端执行 java -jar example.jar 时(example.jar为项目jar包)报错:“没有主清单属性” 的解决方法
终端执行 java -jar example.jar 时(example.jar为项目jar包)报错:“没有主清单属性” 的解决方法 在Java中,一个JAR文件必须包含一个主清单属性(Main-Class属性)才能在命令行中直接运行。如果你在尝试运行…...
4:OpenCV—保存图像
将图像和视频保存到文件 在许多现实世界的计算机视觉应用中,需要保留图像和视频以供将来参考。最常见的持久化方法是将图像或视频保存到文件中。因此,本教程准备解释如何使用 OpenCV C将图像和视频保存到文件中。 将图像保存到文件 可以学习如何保存从…...
[C++面试] const相关面试题
1、非 const 的引用必须指向一个已存在的变量 int main() {int &a 20; // 错误const int &b 30; } 字面量 20 是临时值(右值),没有明确的内存地址。非常量引用(左值引用)不能直接绑定到右值(如…...
#Redis黑马点评#(六)Redis当中的消息队列
目录 Redis当中的消息队列 一 基于List 二 基于PubSub 三 基于Stream 单消费模式 消费者组 Redis当中的消息队列 消息队列,字面意思就是存放消息的队列。最简单的消息队列模型包括3个角色: 消息队列:存储和管理消息,也称为…...
Git基础原理和使用
Git 初识 一、版本管理痛点 在日常工作和学习中,我们经常遇到以下问题: - 通过不断复制文件来保存历史版本(如报告-v1、报告-最终版等) - 版本数量增多后无法清晰记住每个版本的修改内容 - 项目代码管理存在同样问题 二、版本控…...
Java程序员学AI(一)
一、前言 最近刷技术圈,满眼都是 GPT、DeepSeek、QWen 这些 AI 名词。看着同行们在群里聊 AI 写代码、做数据分析,我这个摸了 Java 老程序员突然慌了 —— 再不出手,怕是真要被时代落下了! 作为一个 Java 死忠粉,学 …...
《Python星球日记》 第91天:端到端 LLM 应用(综合项目:医疗文档助手)
名人说:路漫漫其修远兮,吾将上下而求索。—— 屈原《离骚》 创作者:Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊) 目录 一、项目概述与需求分析1. 项目背景2. 项目目标3. 技术栈概览二、数据准备与处理1. 文档收集策略2. 文本预处理流程3. 向量化与知识库构建三、模…...
目前主流的AI测试工具推荐
以下是目前备受关注的AI测试工具及平台,涵盖功能测试、视觉测试、性能测试及国产化解决方案等多个领域,结合其核心特性与适用场景进行综合推荐: 一、主流AI测试工具推荐 Testim 核心功能:基于AI的动态元素定位技术,…...
vscode优化使用体验篇(快捷键)
本文章持续更新中 最新更新时间为2025-5-18 1、方法查看方法 1.1当前标签跳到新标签页查看方法实现 按住ctrl 鼠标左键点击方法。 1.2使用分屏查看方法实现(左右分屏) 按住ctrl alt 鼠标左键点击方法。...
uniprot中PTM数据的下载
首先是PTM的介绍: 参考:https://en.wikipedia.org/wiki/Post-translational_modification 蛋白质的翻译后修饰(PTM)通过改变氨基酸残基的化学结构,显著影响其带电性质,从而调控蛋白质的功能、定位和相互作…...
【QGIS二次开发】地图编辑-04
系列目录: 【QGIS二次开发】地图显示与交互-01_qgis二次开发加载地图案例-CSDN博客 【QGIS二次开发】地图显示与交互-02_setlayerlabeling-CSDN博客 【QGIS二次开发】地图符号与色表-03-CSDN博客 4 地图编辑 4.1 添加点要素 功能演示: 运行程序后…...
Qt 信号和槽-核心知识点小结(11)
目录 小结表格索引 disconnect函数 lambda表达式 啥是耦合,啥是内聚 简介:这是Qt信号和槽的最后一篇文章,最主要的是总结该信号和槽的核心知识点。以及该核心知识点的文章索引(表格太长了,手机可能看不完整&#…...
React响应事件中onClick={handleClick} 的结尾有没有小括号的区别
你可以通过在组件中声明 事件处理 函数来响应事件: function MyButton() {function handleClick() {alert(You clicked me!);}return (<button onClick{handleClick}>点我</button>);} 注意,onClick{handleClick} 的结尾没有小括号&#x…...
React-Query使用react-testing-library进行测试
1.测试react-query首先我们必须得拥有queryClient,所以我们初始化queryClient,因为默认是重试三次,这意味着如果想测试错误的查询,测试可能会超时。所以可以在初始化时关闭 const createWrapper () > {const queryClient new…...
软件设计师CISC与RISC考点分析——求三连
一、考点分值占比与趋势分析(CISC与RISC) 综合知识分值统计表 年份考题数量分值分值占比考察重点2018111.33%指令特征对比2019111.33%控制器实现方式2020222.67%寄存器数量/流水线技术2021111.33%寻址方式对比2022222.67%指令复杂度/译码方式2023111.3…...
GO语言(一期)常用关键字总结
GO语言(主题一)常用关键字总结 我们这里列出一些go语言关键字,方便各位友友们检查一下自己的学习效果,也方便友友们学习查询。 break default func interface select case defer go map …...