Java开发经验——阿里巴巴编码规范实践解析3
摘要
本文深入解析了阿里巴巴编码规范中关于错误码的制定与管理原则,强调错误码应便于快速溯源和沟通标准化,避免过于复杂。介绍了错误码的命名与设计示例,推荐采用模块前缀、错误类型码和业务编号的结构。同时,探讨了项目错误信息管理机制,建议采用分层但统一的管理方式。强调错误码不能直接作为用户提示信息,使用者应避免随意定义新错误码,业务信息应由错误信息承载而非错误码本身。还讨论了获取第三方服务错误码时的处理方式,以及错误码的宏观分类、与HTTP状态码的关系、对跨文化协作的帮助等。最后,涉及异常体系的设计,包括常见异常分类、统一异常基类设计、统一异常处理器、标准错误返回结构等。
1. 【强制】错误码的制定原则:快速溯源、沟通标准化。 说明:错误码想得过于完美和复杂,就像康熙字典的生僻字一样,用词似乎精准,但是字典不容易随身携带且简单易懂。
正例:错误码回答的问题是谁的错?错在哪?
- 错误码必须能够快速知晓错误来源,可快速判断是谁的问题。
- 错误码必须能够进行清晰地比对(代码中容易 equals)。
- 错误码有利于团队快速对错误原因达到一致认知。
1.1. 错误码的制定原则
快速溯源
- 错误码应该一眼就能知道是哪个系统、模块、接口、哪一类错误。
- 不能出现“模糊”、“需要查源码”、“要问人”的情况。
沟通标准化
- 错误码不仅是给开发看的,也是给测试、运维、客服看的。
- 应避免个性化描述,比如“老王说接口挂了” vs “支付系统-用户认证失败(P100201)”。
不要康熙字典式复杂
- 错误描述越精准、越细分,并不代表越好。
- 错误码是为“快速识别 + 标准沟通”服务的,要简单、可识别、可比对(如 equals)。
1.2. 错误码命名与设计示例
正确示例(推荐结构):
模块前缀 + 错误类型码 + 业务编号
例如:U010001,P100201
错误码 | 模块 | 描述 |
| 用户系统 | 用户未登录 |
| 用户系统 | 用户Token已失效 |
| 支付系统 | 支付渠道认证失败 |
| 订单系统 | 订单不存在 |
| 风控系统 | 命中黑名单规则 |
- 前缀如:
U
=User模块、P
=Payment、O
=Order、R
=Risk - 中间两位如:
01
代表“认证错误”,02
是“资源问题”,03
是“参数非法” - 后三位为具体错误编号
错误示例
错误码 | 问题说明 |
| 没有上下文,完全不知是哪个系统的错 |
| 太长了,不利于代码中 equals 比对 |
| 非结构化格式,难以管理和比对 |
| 没有语义,无法直观看出模块来源 |
2. 【强制】项目错误信息是使用代码的全局统一error类处理还是每一层有自己error处理,还是直接写入代码里面?
推荐采用 “全局统一错误信息管理 + 层内扩展” 的方式,而不是“随便写”或“每层乱管”。
2.1. 最佳实践建议:分层但统一的错误信息管理机制
推荐结构:
- 统一错误码定义(全局 Enum / Code 类)
-
- 定义所有错误码、错误信息(用于开发、测试、运维统一查阅)
- 每个模块一个子枚举或前缀,方便归类
- 按模块/层封装异常类(可继承通用异常)
-
- 各层有自己的异常类型,但共享统一的错误码体系
- 每层处理只关心与其职责相关的错误(解耦)
- 异常中间层(统一异常处理器)
-
- 如 Spring 中的
@ControllerAdvice
+ExceptionHandler
- 负责把业务异常转换为 API 规范响应格式(例如统一返回 JSON 包含 code/message)
- 如 Spring 中的
2.2. 三种常见做法对比
做法 | 优点 | 缺点 / 风险 | 推荐程度 |
✅ 统一 error 定义 + 分层封装 | 清晰、可追踪、 标准化,便于维护 | 初期定义需要一定规划 | 强烈推荐 |
⚠️ 每一层自己定义 error 信息 | 模块清晰 | 错误码不统一,可能重复、歧义、难排查 | 不推荐 |
❌ 直接写死在代码中(写字符串) | 快捷开发 | 混乱、无法比对、无法维护、代码耦合严重 | 禁止使用 |
2.3. 推荐的错误管理设计示例
2.3.1. 全局错误码定义(推荐用 Enum)
public enum ErrorCode {SUCCESS("000000", "成功"),USER_NOT_LOGIN("U010001", "用户未登录"),USER_TOKEN_EXPIRED("U010002", "用户Token已过期"),ORDER_NOT_FOUND("O020301", "订单不存在"),SYSTEM_ERROR("S999999", "系统异常,请联系管理员");private final String code;private final String message;// 构造、getter略
}
2.3.2. 定义通用业务异常类
public class BizException extends RuntimeException {private final String code;public BizException(ErrorCode errorCode) {super(errorCode.getMessage());this.code = errorCode.getCode();}public String getCode() {return code;}
}
2.3.3. 统一异常处理器
@RestControllerAdvice
public class GlobalExceptionHandler {@ExceptionHandler(BizException.class)public ResponseEntity<ApiResult> handleBizException(BizException ex) {return ResponseEntity.status(HttpStatus.BAD_REQUEST).body(ApiResult.fail(ex.getCode(), ex.getMessage()));}@ExceptionHandler(Exception.class)public ResponseEntity<ApiResult> handleException(Exception ex) {return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body(ApiResult.fail(ErrorCode.SYSTEM_ERROR));}
}
2.4. 项目中error信息打印总结
要点 | 建议 |
错误码管理 | 全局统一 |
每层处理异常 | 封装业务异常类,使用统一错误码 |
对外返回 | 使用统一响应结构,统一异常处理器输出 |
禁止 | 直接在代码中写 |
3. 【强制】错误码不能直接输出给用户作为提示信息使用。
说明:堆栈(stack_trace)、错误信息(error_message) 、错误码(error_code)、提示信息(user_tip)是一个有效关联并互相转义的和谐整体,但是请勿互相越俎代庖。
3.1. 规则深度理解
系统中的异常响应,通常包含这些字段:
字段 | 作用 | 使用对象 |
| 错误编号,唯一定位错误来源 | 开发、测试、运维 |
| 系统级说明,记录异常详细信息 | 开发排查 |
| 调试信息,展示调用栈 | 仅开发环境调试时使用 |
| 提示给用户看的友好语言 | 最终用户 / 客户 |
这四者应彼此关联,但不得混用。
例如不能把 "U010001" 或 "NullPointerException" 直接显示给用户!
3.2. 异常返回错误示例(越俎代庖)
{"error_code": "U010001","message": "用户未登录,请登录系统","stack_trace": "...NullPointerException at...","user_tip": "U010001" ←❌ 错:直接暴露错误码给用户
}
或者:
{"error_code": "500","message": "java.lang.IllegalStateException: user is null", ←❌ 直接暴露底层异常信息"user_tip": "user is null" ←❌ 不友好,普通用户看不懂
}
3.3. 异常返回正确示例(职责分离)
{"error_code": "U010001","error_message": "用户未登录,token为空","stack_trace": null, // 生产环境不展示"user_tip": "登录已过期,请重新登录"
}
- error_code:给技术人员看,一眼知道是用户系统的问题
- error_message:可写入日志,便于问题溯源
- stack_trace:仅调试使用,生产环境屏蔽
- user_tip:简洁友好的提示,告诉用户“该做什么”
4. 【强制】错误码使用者避免随意定义新的错误码。 说明:尽可能在原有错误码附表中找到语义相同或者相近的错误码在代码中使用即可。
❗不要每次遇到错误就随便新定义一个错误码,而是优先复用已有语义相近的错误码。
原因:
- 控制错误码数量:错误码越多,管理成本越高,排查难度越大。
- 提高语义一致性:同一种错误使用同一个错误码,减少团队歧义。
- 避免重复定义:很多错误其实是“变种”,可以共用一个错误码。
4.1. 错误示例:重复造码
// 登录校验失败
throw new BizException("U010001", "用户未登录");// 注册校验失败
throw new BizException("U010005", "未登录用户无法注册");
实际上这两种情况都是“用户未登录”,本质一样,却用了两个不同的错误码,属于“重复造码”。
4.2. 正确示例:共用语义相近错误码
// 统一使用已定义的“用户未登录”错误码
throw new BizException(ErrorCode.USER_NOT_LOGIN);
登录页、注册页、敏感操作,都可以复用 U010001
。
5. 【推荐】错误码之外的业务信息由 error_message 来承载,而不是让错误码本身涵盖过多具体业务属性。
5.1. 规则理解
不要让错误码承担太多含义,它的职责只是:标识错误的“类型”或“分类”
而像:
- 错误发生时的具体数据(如“用户ID”、“订单号”)
- 具体错误描述(如“商品【123】库存不足,仅剩余1件”)
这些内容都不应该写入错误码本身,而是通过 error_message
或其他字段承载。
5.2. 错误码 vs 错误信息职责分工
字段 | 作用 | 示例 | 特性 |
| 错误类别编号 |
(支付失败) | 稳定、可比对 |
| 具体业务场景的解释 |
| 动态、可读 |
| 面向用户的友好提示 |
| 本地化、用户可见 |
5.3. 反例:错误码“负载过多信息”
{"error_code": "P10001_OUT_OF_STOCK_ITEM_12345","error_message": "商品12345库存不足"
}
❌ 错误码中包含了具体商品ID,这是 动态业务属性,不利于归类、比对和复用。
5.4. 正例:错误码用于分类,信息分离
{"error_code": "P10001","error_message": "商品 [12345] 库存不足,仅剩余 [1] 件","user_tip": "库存不足,请减少购买数量"
}
✅ 错误码 P10001
表示“通用库存不足”
✅ error_message
根据具体情况动态拼接,便于日志排查
✅ user_tip
可做国际化提示给用户
5.5. 实际工程建议
项目做法 | 建议 |
错误码只承载语义分类 | 如:参数错误、鉴权失败、业务失败等 |
不携带动态 ID、金额、字段名等 | 这些应放在 message |
message 和 tip 支持模板填充 | 例如 |
使用枚举或错误码常量类 | 限制错误码的随意性 |
6. 【推荐】在获取第三方服务错误码时,向上抛出允许本系统转义,由 C 转为 B, 并且在错误信息上带上原 有的第三方错误码。
当你调用第三方系统(C系统),它报错了,你不能直接把它的错误码暴露给用户或前端(B系统),而是要在自己系统内“转义”一层,抛出你本系统标准的错误码,并将原始错误码保留下来用于日志排查或内部分析。
6.1. 规则理解
场景角色:
- C系统:第三方接口,例如支付平台、银行接口、OCR识别服务等。
- B系统:你的调用方,比如前端、业务方、APP。
- 你自己:中间的服务系统(通常是网关 / 后端接口 / 业务中台)。
规则拆解:
- 不要让第三方系统的错误码直接向上冒泡(因为对方的码可能不规范、不稳定、无法识别)。
- 要“转义”:用你系统的统一错误码替代它
- 同时,原始的第三方错误码 + 错误信息保留用于排查或打日志,不让它丢失。
6.2. 错误示例:直接抛出第三方错误码
{"error_code": "4003", ← 这是支付平台的错误码"error_message": "签名无效"
}
问题:
- 前端和用户不知道“4003”代表啥
- 错误码不属于你系统的体系,破坏统一性
- 后续如果支付平台换服务、换码,前端也得改
6.3. 正确示例:本系统转义后抛出
{"error_code": "P100201", ← 本系统定义:支付认证失败"error_message": "支付渠道认证失败,请稍后重试","extra_info": {"third_error_code": "4003","third_error_msg": "签名无效"}
}
处理方式:
throw new BizException(ErrorCode.PAY_CHANNEL_AUTH_FAIL)
.withExtra("third_error_code", response.getCode())
.withExtra("third_error_msg", response.getMsg());
优势:
- 前端拿到的
P100201
可读可识别,统一标准 - 原始错误码保留,方便你打日志、出问题溯源
6.4. 实际应用建议
场景 | 建议做法 |
调用第三方支付、银行、OCR等 | 不要直接返回对方错误码 |
把第三方错误码转成系统内错误码 | 使用枚举或错误码映射 |
原始错误信息不要丢 | 记录在日志、extra字段、监控平台 |
抛出时用系统统一 BizException | 方便统一处理和返回结构 |
6.5. 进阶:错误码映射表(推荐)
你可以为每个对接的第三方准备一张 错误码映射表:
第三方错误码 | 本系统错误码 | 含义 |
|
| 支付签名无效 |
|
| 商户余额不足 |
|
| 授权过期 |
当第三方接口返回错误时,从映射表中找出对应的“本地错误码”抛出。
7. 【参考】错误码分为一级宏观错误码、 二级宏观错误码、 三级宏观错误码。
说明: 在无法更加具体确定的错误场景中, 可以直接使用一级宏观错误码, 分别是: A0001(用户端错误) 、 B0001(系统执行出错) 、 C0001(调用第三方服务出错)。
正例:调用第三方服务出错是一级,中间件错误是二级,消息服务出错是三级。
8. 【参考】错误码的后三位编号与 HTTP 状态码没有任何关系。
9. 【参考】错误码有利于不同文化背景的开发者进行交流与代码协作。
说明:英文单词形式的错误码不利于非英语母语国家(如阿拉伯语、希伯来语、俄罗斯语等)之间的开发者互相协作。
10. 【参考】错误码即人性,感性认知+口口相传,使用纯数字来进行错误码编排不利于感性记忆和分类。
说明:数字是一个整体,每位数字的地位和含义是相同的。
反例:一个五位数字 12345,第 1 位是错误等级,第 2 位是错误来源,345 是编号,人的大脑不会主动地拆开并分辨每位数字的不同含义。
10.1. 规则理解
纯数字错误码(如 12345
)虽然简洁,但不具备“人性化、可读性、可记忆性”,也不利于团队协作、语义理解和错误分类。
10.2. 推荐做法:半结构化 + 可读的错误码设计
使用【字符 + 分类 + 数字】的组合模式,让错误码更易识别和传播。
[A][B][NNNNN]
字段 | 含义 | 示例 | 说明 |
A | 业务域缩写(系统模块) |
| 用户系统 |
B | 错误级别 / 类型标识 |
| 1 代表“校验类错误” |
NNNN | 错误编号(可读、递增) |
| 同类错误内递增编号 |
错误码 | 含义说明 |
| 用户未登录 |
| 用户权限不足 |
| 支付失败,余额不足 |
| OCR识别失败,图像模糊 |
这种格式即使不看文档,也能凭直觉猜出模块与大概的错误方向。
11. Exception(异常)体系的设计
在一个中大型项目中,设计一套**清晰、统一、可扩展的异常体系(Exception Architecture)**是非常关键的,它决定了:
- 错误信息的可追踪性 ✅
- 用户提示的友好性 ✅
- 系统稳定性与可维护性 ✅
- 日志告警与监控的精确性 ✅
异常体系设计目标
目标 | 说明 |
职责单一 | 每类异常只处理一类问题 |
分级处理 | 明确哪些是业务异常,哪些是系统异常 |
统一格式 | 所有错误响应结构一致 |
便于扩展 | 后续新模块、新错误类型可无缝接入 |
可追踪溯源 | 包括错误码、日志、traceId、堆栈等信息 |
11.1. 常见异常分类(强烈推荐)
11.1.1. BizException
(业务异常)
- 用户操作不符合业务规则,如余额不足、权限不足
- 是可预期、需要提示用户的异常
throw new BizException("BALANCE_NOT_ENOUGH", "余额不足");
11.1.2. SystemException
(系统异常)
- 系统内部出错,如数据库连接失败、服务不可用
- 不直接提示用户,返回通用友好提示即可
throw new SystemException("数据库连接失败: " + e.getMessage(), e);
11.1.3. ParamException
/ ValidationException
(参数异常)
- 请求参数格式错误、缺失、越界等
- 返回明确提示,前端能快速改正
throw new ParamException("手机号不能为空");
11.1.4. RemoteCallException
(远程服务异常)
- 第三方/下游系统异常
- 支持带入原始返回码和消息
throw new RemoteCallException("ALIPAY_ERROR_001", "支付宝支付失败", aliPayResponse);
11.1.5. 衍生类建议:
如需更细分:
DbException
CacheException
ThirdPartyException
11.2. 统一异常基类设计
public abstract class BaseException extends RuntimeException {private final String errorCode;private final String errorMessage;public BaseException(String code, String msg) {super(msg);this.errorCode = code;this.errorMessage = msg;}public String getErrorCode() { return errorCode; }public String getErrorMessage() { return errorMessage; }
}
所有异常都继承自 BaseException
,便于统一处理。
11.3. 统一异常处理器(Spring)
@RestControllerAdvice
public class GlobalExceptionHandler {@ExceptionHandler(BizException.class)public ResponseEntity<ErrorResponse> handleBiz(BizException e) {return ResponseEntity.ok(ErrorResponse.fail(e.getErrorCode(), e.getErrorMessage()));}@ExceptionHandler(ParamException.class)public ResponseEntity<ErrorResponse> handleParam(ParamException e) {return ResponseEntity.badRequest().body(ErrorResponse.fail(e.getErrorCode(), e.getErrorMessage()));}@ExceptionHandler(SystemException.class)public ResponseEntity<ErrorResponse> handleSystem(SystemException e) {log.error("系统异常", e);return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body(ErrorResponse.fail("SYS_ERROR", "系统开小差了,请稍后再试"));}@ExceptionHandler(Exception.class)public ResponseEntity<ErrorResponse> handleOther(Exception e) {log.error("未知异常", e);return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body(ErrorResponse.fail("UNKNOWN_ERROR", "系统错误,请联系管理员"));}
}
11.4. 标准错误返回结构(统一响应体)
@Data
@AllArgsConstructor(staticName = "fail")
public class ErrorResponse {private String errorCode;private String errorMessage;
}
⚠️ 可以进一步扩展 userTip
, traceId
, timestamp
, debugMessage
等字段。
11.5. 异常体系设计总结
模块 | 内容 |
异常分类 |
|
统一基类 |
|
统一响应结构 | 统一返回 |
全局拦截器 |
|
统一错误码系统 | 错误码与异常结合使用,便于识别与追踪 |
11.6. 异常体系设计图(示意)
┌────────────────────┐│ BaseException │└────────┬───────────┘│┌────────────────────┼──────────────────────┐│ │ │
▼ ▼ ▼
BizException SystemException ParamException
(业务异常) (系统异常) (参数异常)↓GlobalExceptionHandler↓ ↓ ↓errorCode errorMessage userTip
博文参考
《阿里巴巴java规范》
相关文章:
Java开发经验——阿里巴巴编码规范实践解析3
摘要 本文深入解析了阿里巴巴编码规范中关于错误码的制定与管理原则,强调错误码应便于快速溯源和沟通标准化,避免过于复杂。介绍了错误码的命名与设计示例,推荐采用模块前缀、错误类型码和业务编号的结构。同时,探讨了项目错误信…...
ChatGPT:OpenAI Codex—一款基于云的软件工程 AI 代理,赋能 ChatGPT,革新软件开发模式
ChatGPT:OpenAI Codex—一款基于云的软件工程 AI 代理,赋能 ChatGPT,革新软件开发模式 导读:2025年5月16日,OpenAI 发布了 Codex,一个基于云的软件工程 AI 代理,它集成在 ChatGPT 中,…...
iOS 内存分区
iOS内存分区 文章目录 iOS内存分区前言五大分区static、extern、const关键字比较conststaticextern与.h文件的关系extern引用变量extern声明 static和const联合使用extern和const联合使用 前言 笔者之前学习OC源码的时候,发现对于这里的几个static,extern,const的内容有遗忘,所…...
LWIP的Socket接口
Socket接口简介 类似于文件操作的一种网络连接接口,通常将其称之为“套接字”。lwIP的Socket接口兼容BSD Socket接口,但只实现完整Socket的部分功能 netconn是对RAW的封装 Socket是对netconn的封装 SOCKET结构体 struct sockaddr { u8_t sa_len; /* 长…...
【Linux笔记】——线程同步条件变量与生产者消费者模型的实现
🔥个人主页🔥:孤寂大仙V 🌈收录专栏🌈:Linux 🌹往期回顾🌹:【Linux笔记】——线程互斥与互斥锁的封装 🔖流水不争,争的是滔滔不息 一、线程同步的…...
Popeye
概览与定位 Popeye 是由 derailed 团队开源的 Kubernetes 集群资源 “Sanitizer”,它以只读方式扫描集群内的各种资源(如 Pod、Service、Ingress、PVC、RBAC 等),并基于社区最佳实践给出问题等级及修复建议,覆盖配置误…...
ES(ES2023/ES14)最新更新内容,及如何减少内耗
截至2023年10月,JavaScript(ECMAScript)的最新版本是 ES2023(ES14)。 ES2023 引入了许多新特性,如findLast、toSorted等,同时优化了性能。通过减少全局变量、避免内存泄漏、优化循环、减少DOM操作、使用Web Workers、懒加载、缓存、高效数据结构和代码压缩,可以显著降低…...
电子数据取证(数字取证)技术全面指南:从基础到实践
为了后续查阅方便,推荐工具先放到前面 推荐工具 数字取证基础工具 综合取证平台 工具名称类型主要功能适用场景EnCase Forensic商业全面的证据获取和分析、强大的搜索能力法律诉讼、企业调查FTK (Forensic Toolkit)商业高性能处理和索引、集成内存分析大规模数据处…...
【通用智能体】Serper API 详解:搜索引擎数据获取的核心工具
Serper API 详解:搜索引擎数据获取的核心工具 一、Serper API 的定义与核心功能二、技术架构与核心优势2.1 技术实现原理2.2 对比传统方案的突破性优势 三、典型应用场景与代码示例3.1 SEO 监控系统3.2 竞品广告分析 四、使用成本与配额策略五、开发者注意事项六、替…...
基于 STM32 的手持式安检金属探测器设计与实现
一、硬件设计:芯片与功能模块选型及接线 1. 主控芯片选型 芯片型号:STM32F103C8T6 核心优势: 32 位 Cortex-M3 内核,主频 72MHz,满足实时数据处理需求64KB Flash+20KB SRAM,支持程序存储与数据缓存丰富外设:2 路 USART、2 路 SPI、1 路 I2C、12 位 ADC,适配多模块通信…...
虚幻引擎5-Unreal Engine笔记之Default Pawn与GamMode、Camera的关系
虚幻引擎5-Unreal Engine笔记之Default Pawn与GamMode、Camera的关系 code review! 文章目录 虚幻引擎5-Unreal Engine笔记之Default Pawn与GamMode、Camera的关系1.Default Pawn与Camera的关系1.1. Default Pawn 是什么?1.2. Default Pawn 的主要组件1.3. Default…...
Spring源码主线全链路拆解:从启动到关闭的完整生命周期
Spring源码主线全链路拆解:从启动到关闭的完整生命周期 一文看懂 Spring 框架从启动到销毁的主线流程,结合原理、源码路径与伪代码三位一体,系统学习 Spring 底层机制。 1. 启动入口与环境准备 原理说明 Spring Boot 应用入口是标准 Java 应…...
飞帆控件:可配置post/get接口
先上链接: post_get_ithttps://fvi.cn/796看一下这个控件的配置: 当 url 有某个 get 参数时,例如某些接口回传的参数。使用这个接口会发生这些: 如果检测到 url 中有该 url 参数则继续执行选择是否从 url 中删除该参数将这个参数…...
Android 自定义悬浮拖动吸附按钮
一个悬浮的拨打电话按钮,使用CardViewImageView可能会出现适配问题,也就是图片显示不全,出现这种问题,就直接替换控件了,因为上述的组合控件没有FloatingActionButton使用方便,还可以有拖动和吸附效果不是更…...
Spring AI Alibaba集成阿里云百炼大模型应用
文章目录 1.准备工作2.引入maven依赖3.application.yml4.调用4.1.非流式调用4.2.流式调用 阿里云百炼推出的智能体应用、工作流应用和智能体编排应用,有效解决了大模型在处理私有领域问题、获取最新信息、遵循固定流程以及自动规划复杂项目等方面的局限,…...
UI-TARS本地部署
UI-TARS本地部署 UI-TARS本地部署 UI-TARS 论文(arXiv) UI-TARS 官方仓库:包含部署指南、模型下载链接及示例代码。 UI-TARS-Desktop 客户端:支持本地桌面应用的交互控制。 模型部署框架:vLLM本地部署 1.下载项目…...
如何利用内网穿透实现Cursor对私有化部署大模型的跨网络访问实践
文章目录 前言1.安装Ollama2.QwQ-32B模型安装与运行3.Cursor安装与配置4. 简单使用测试5. 调用本地大模型6. 安装内网穿透7. 配置固定公网地址总结 前言 本文主要介绍如何在Windows环境下,使用Cursor接入Ollama启动本地部署的千问qwq-32b大模型实现辅助编程&#x…...
Linux的进程概念
目录 1、冯诺依曼体系结构 2、操作系统(Operating System) 2.1 基本概念 编辑 2.2 目的 3、Linux的进程 3.1 基本概念 3.1.1 PCB 3.1.2 struct task_struct 3.1.3 进程的定义 3.2 基本操作 3.2.1 查看进程 3.2.2 初识fork 3.3 进程状态 3.3.1 操作系统的进程状…...
(10)python开发经验
文章目录 1 cp35 cp36什么意思2 找不到pip3 subprocess编码错误4 导出依赖文件包含路径5 使用自己编译的python并且pyinstall打包程序 更多精彩内容👉内容导航 👈👉Qt开发 👈👉python开发 👈 1 cp35 cp36什…...
什么是时间戳?怎么获取?有什么用
时间戳的定义 时间戳(Timestamp)是指记录某个事件发生的具体时间点,通常以特定的格式表示。它可以精确到秒、毫秒甚至更小的单位,用于标识某个时刻在时间轴上的位置。 获取时间戳的方法 在不同的编程语言中,获取时间…...
Zookeeper 入门(二)
4. Zookeeper 的 ACL 权限控制( Access Control List ) Zookeeper 的ACL 权限控制,可以控制节点的读写操作,保证数据的安全性,Zookeeper ACL 权 限设置分为 3 部分组成,分别是:权限模式(Scheme)、授权对象(…...
[创业之路-361]:企业战略管理案例分析-2-战略制定-使命、愿景、价值观的失败案例
一、失败案例 1、使命方面的失败案例 真功夫创业者内乱:真功夫在创业过程中,由于股权结构不合理,共同创始人及公司大股东潘宇海与实际控制人、董事长蔡达标产生管理权矛盾。双方在公司发展方向、管理改革等方面无法达成一致,导致…...
dijkstra算法加训上 之 分层图最短路
来几个分层图的题练习下哈 P4568 [JLOI2011] 飞行路线 P4568 [JLOI2011] 飞行路线 - 洛谷https://www.luogu.com.cn/problem/P4568 题目描述 Alice 和 Bob 现在要乘飞机旅行,他们选择了一家相对便宜的航空公司。该航空公司一共在 n 个城市设有业务,设这…...
赋予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 队列优化算法 优化原理…...