最新资讯

  • useReducer的理解与应用

useReducer的理解与应用

2026-01-31 01:39:32 栏目:最新资讯 1 阅读

useReducer 你可以把它当成 “更规范、更可控的 useState”

当你的状态变复杂、更新方式很多、或者你想把“怎么改状态”集中管理时,用它会非常爽。


1)useReducer 是什么(核心概念)

useReducer 的核心思想来源于 Flux/Redux 架构,它遵循 “action -> reducer -> new state” 的数据流。其基本形式由三部分组成:

  1. state:当前状态

  2. dispatch(action):你发出一个“指令”(action)

  3. reducer(state, action):一个纯函数,根据指令,接收当前状态和动作,并返回新的状态。(state, action) => newState

  4. initialState:状态的初始值。

const [state, dispatch] = useReducer(reducer, initialState);

记住一句话:dispatch 发动作,reducer 负责算新状态。


2)为什么要用 useReducer,而不是 useState?

useState 适合:

  • 状态简单(1~2 个字段)

  • 更新方式少(就 setX)

useReducer 适合:

  • 状态是对象/数组,字段多

  • 更新逻辑分散在很多地方,容易乱

  • “更新方式”很多(新增/删除/切换/编辑/批量更新/回滚)

  • 想要:所有状态变化都走同一套“动作(Action) → 规则(Reducer)”

一个经典场景:

add / toggle / delete 三种操作,如果继续扩展成 edit / clearCompleted / reorder,用 useState 会越来越乱。


3)最小例子:计数器(理解 dispatch + reducer)

const ACTIONS = {
  INC: "inc",
  DEC: "dec",
}

function reducer(state, action) {
  switch (action.type) {
    case ACTIONS.INC:
      return { count: state.count + 1 }
    case ACTIONS.DEC:
      return { count: state.count - 1 }
    default:
      return state
  }
}

export default function Counter() {
  const [state, dispatch] = React.useReducer(reducer, { count: 0 })

  return (
    <>
      
      {state.count}
      
    
  )
}

这里的重点不是“写起来更长”,而是:

你把“如何更新”从组件里抽走了,组件只负责“发动作”。


4)带 payload:把参数一起发给 reducer

比如 Todo:新增时需要 name,toggle/delete 需要 id。

dispatch({ type: "add", payload: { name } })
dispatch({ type: "toggle", payload: { id } })
dispatch({ type: "delete", payload: { id } })

reducer 里拿到 action.payload 来做事。


5)你真正会遇到的实战例子

例 1:表单很多字段 + 校验 + 重置

场景:登录/注册/创建项目表单

动作:setField、setError、reset、submitStart/Success/Fail

function reducer(state, action) {
  switch (action.type) {
    case "setField":
      return { ...state, values: { ...state.values, [action.field]: action.value } }
    case "setError":
      return { ...state, errors: { ...state.errors, [action.field]: action.error } }
    case "reset":
      return action.initial
    default:
      return state
  }
}

好处:表单逻辑集中,不会散落在 10 个 setState 里。


例 2:请求状态机(loading/error/data + 取消/重试)

场景:拉取列表、分页、刷新

动作:fetchStart / fetchSuccess / fetchError / reset

function reducer(state, action) {
  switch (action.type) {
    case "fetchStart":
      return { ...state, loading: true, error: null }
    case "fetchSuccess":
      return { loading: false, error: null, data: action.data }
    case "fetchError":
      return { ...state, loading: false, error: action.error }
    default:
      return state
  }
}

你会发现:useReducer 非常适合“状态机”这种结构。


例 3:Web3 钱包连接状态(连接/断开/切链/更新余额)

state:address, chainId, status, balance, error
actions:connectStart/connectOk/connectFail/disconnect/chainChanged/balanceUpdated

WalletProvider.tsx

import React, { createContext, useContext, useEffect, useReducer } from "react"

// 1) 类型
type WalletStatus = "idle" | "connecting" | "connected" | "error"

type WalletState = {
  address: string | null
  chainId: number | null
  status: WalletStatus
  balance: string | null // 用 string 存,避免浮点问题(ETH/Wei)
  error: string | null
}

type Action =
  | { type: "connectStart" }
  | { type: "connectOk"; payload: { address: string; chainId: number } }
  | { type: "connectFail"; payload: { error: string } }
  | { type: "disconnect" }
  | { type: "chainChanged"; payload: { chainId: number } }
  | { type: "balanceUpdated"; payload: { balance: string } }

const initialState: WalletState = {
  address: null,
  chainId: null,
  status: "idle",
  balance: null,
  error: null,
}

// 2) reducer:只负责“怎么算新 state”
function walletReducer(state: WalletState, action: Action): WalletState {
  switch (action.type) {
    case "connectStart":
      return { ...state, status: "connecting", error: null }

    case "connectOk":
      return {
        ...state,
        status: "connected",
        error: null,
        address: action.payload.address,
        chainId: action.payload.chainId,
      }

    case "connectFail":
      return { ...state, status: "error", error: action.payload.error }

    case "disconnect":
      return { ...initialState }

    case "chainChanged":
      // 切链后一般余额要重新拉
      return { ...state, chainId: action.payload.chainId, balance: null }

    case "balanceUpdated":
      return { ...state, balance: action.payload.balance }

    default:
      return state
  }
}

// 3) Context
type WalletContextValue = {
  state: WalletState
  dispatch: React.Dispatch
  connect: () => Promise
  disconnect: () => void
  refreshBalance: () => Promise
}

const WalletContext = createContext(null)

export function useWallet() {
  const ctx = useContext(WalletContext)
  if (!ctx) throw new Error("useWallet must be used within WalletProvider")
  return ctx
}

// 4) Provider:副作用(连接钱包/监听事件/请求余额)放这里或单独 hooks
export function WalletProvider({ children }: { children: React.ReactNode }) {
  const [state, dispatch] = useReducer(walletReducer, initialState)

  // --- 你项目里可以换成 ethers / wagmi / viem ---
  const getProvider = () => (window as any).ethereum as any | undefined

  const connect = async () => {
    const eth = getProvider()
    if (!eth) {
      dispatch({ type: "connectFail", payload: { error: "No wallet found (window.ethereum missing)" } })
      return
    }

    dispatch({ type: "connectStart" })

    try {
      // 请求账号
      const accounts: string[] = await eth.request({ method: "eth_requestAccounts" })
      const address = accounts?.[0]
      if (!address) throw new Error("No account returned")

      // 获取 chainId(hex -> number)
      const chainIdHex: string = await eth.request({ method: "eth_chainId" })
      const chainId = parseInt(chainIdHex, 16)

      dispatch({ type: "connectOk", payload: { address, chainId } })
    } catch (e: any) {
      dispatch({ type: "connectFail", payload: { error: e?.message ?? "Connect failed" } })
    }
  }

  const disconnect = () => {
    // 注意:EIP-1193 没有统一的“主动断开”标准,通常是本地清状态
    dispatch({ type: "disconnect" })
  }

  const refreshBalance = async () => {
    const eth = getProvider()
    if (!eth || !state.address) return

    try {
      // 这里只演示用 RPC 方法拿余额(wei 的 hex)
      const balanceHex: string = await eth.request({
        method: "eth_getBalance",
        params: [state.address, "latest"],
      })
      // 这里简单转成 BigInt string(你可以用 ethers.formatEther)
      const wei = BigInt(balanceHex)
      dispatch({ type: "balanceUpdated", payload: { balance: wei.toString() } })
    } catch (e: any) {
      // 拉余额失败不一定要把 status 变 error,看你需求
      dispatch({ type: "connectFail", payload: { error: e?.message ?? "Balance fetch failed" } })
    }
  }

  // 监听钱包事件:accountsChanged / chainChanged
  useEffect(() => {
    const eth = getProvider()
    if (!eth) return

    const onAccountsChanged = (accounts: string[]) => {
      const next = accounts?.[0] ?? null
      if (!next) {
        dispatch({ type: "disconnect" })
        return
      }
      // accountsChanged 通常不会给 chainId,这里读一下
      eth.request({ method: "eth_chainId" }).then((chainIdHex: string) => {
        dispatch({
          type: "connectOk",
          payload: { address: next, chainId: parseInt(chainIdHex, 16) },
        })
      })
    }

    const onChainChanged = (chainIdHex: string) => {
      dispatch({ type: "chainChanged", payload: { chainId: parseInt(chainIdHex, 16) } })
    }

    eth.on?.("accountsChanged", onAccountsChanged)
    eth.on?.("chainChanged", onChainChanged)

    return () => {
      eth.removeListener?.("accountsChanged", onAccountsChanged)
      eth.removeListener?.("chainChanged", onChainChanged)
    }
  }, [])

  // 连上后自动拉余额
  useEffect(() => {
    if (state.status === "connected" && state.address) {
      refreshBalance()
    }
  }, [state.status, state.address, state.chainId])

  const value: WalletContextValue = { state, dispatch, connect, disconnect, refreshBalance }

  return {children}
}

WalletPanel.tsx(使用)

import React from "react"
import { useWallet } from "./WalletProvider"

export function WalletPanel() {
  const { state, connect, disconnect, refreshBalance } = useWallet()

  return (
    
{ padding: 12, border: "1px solid #ddd" }}>
Status: {state.status}
Address: {state.address ?? "-"}
ChainId: {state.chainId ?? "-"}
Balance(wei): {state.balance ?? "-"}
{state.error &&
{ color: "red" }}>Error: {state.error}
}
{ marginTop: 8, display: "flex", gap: 8 }}> {state.status !== "connected" ? ( ) : ( <> )}
) }

这个比 useState 更清晰,因为“允许发生的变化”是你定义的动作集合。


例 4: 复杂列表(批量/全选/排序/移动分组/撤销重做)useReducer

我们做一个“任务列表 + 分组”的 reducer,支持:

  • CRUD:add/update/delete

  • 批量:select、selectAll、clearSelection、bulkDelete、bulkMove

  • 排序:按 name/createdAt

  • 撤销/重做:undo/redo(用 history 包一层)

listReducer.ts

// 1) 数据结构
export type Item = {
  id: string
  name: string
  groupId: string
  createdAt: number
  done: boolean
}

type SortKey = "createdAt" | "name"
type SortOrder = "asc" | "desc"

export type ListState = {
  items: Item[]
  selectedIds: Record // 用 map 更快
  sort: { key: SortKey; order: SortOrder }
}

const initialPresent: ListState = {
  items: [],
  selectedIds: {},
  sort: { key: "createdAt", order: "desc" },
}

// 2) action
export type ListAction =
  | { type: "add"; payload: { name: string; groupId: string } }
  | { type: "update"; payload: { id: string; patch: Partial> } }
  | { type: "delete"; payload: { id: string } }

  | { type: "toggleSelect"; payload: { id: string } }
  | { type: "selectAll" }
  | { type: "clearSelection" }

  | { type: "bulkDeleteSelected" }
  | { type: "bulkMoveSelected"; payload: { groupId: string } }

  | { type: "setSort"; payload: { key: SortKey; order: SortOrder } }

  | { type: "undo" }
  | { type: "redo" }

// 3) 工具
const uid = () => Math.random().toString(36).slice(2) + Date.now().toString(36)

function sortItems(items: Item[], sort: ListState["sort"]) {
  const { key, order } = sort
  const dir = order === "asc" ? 1 : -1
  return [...items].sort((a, b) => {
    if (key === "createdAt") return (a.createdAt - b.createdAt) * dir
    // name
    return a.name.localeCompare(b.name) * dir
  })
}

// 4) 纯 reducer:只处理 present
function presentReducer(state: ListState, action: ListAction): ListState {
  switch (action.type) {
    case "add": {
      const item: Item = {
        id: uid(),
        name: action.payload.name,
        groupId: action.payload.groupId,
        createdAt: Date.now(),
        done: false,
      }
      const items = sortItems([...state.items, item], state.sort)
      return { ...state, items }
    }

    case "update": {
      const { id, patch } = action.payload
      const items = state.items.map((it) => (it.id === id ? { ...it, ...patch } : it))
      return { ...state, items: sortItems(items, state.sort) }
    }

    case "delete": {
      const { id } = action.payload
      const items = state.items.filter((it) => it.id !== id)
      const nextSelected = { ...state.selectedIds }
      delete nextSelected[id]
      return { ...state, items, selectedIds: nextSelected }
    }

    case "toggleSelect": {
      const { id } = action.payload
      const selectedIds = { ...state.selectedIds }
      if (selectedIds[id]) delete selectedIds[id]
      else selectedIds[id] = true
      return { ...state, selectedIds }
    }

    case "selectAll": {
      const selectedIds: Record = {}
      for (const it of state.items) selectedIds[it.id] = true
      return { ...state, selectedIds }
    }

    case "clearSelection":
      return { ...state, selectedIds: {} }

    case "bulkDeleteSelected": {
      const ids = state.selectedIds
      const items = state.items.filter((it) => !ids[it.id])
      return { ...state, items, selectedIds: {} }
    }

    case "bulkMoveSelected": {
      const targetGroupId = action.payload.groupId
      const ids = state.selectedIds
      const items = state.items.map((it) => (ids[it.id] ? { ...it, groupId: targetGroupId } : it))
      return { ...state, items: sortItems(items, state.sort), selectedIds: {} }
    }

    case "setSort": {
      const sort = action.payload
      return { ...state, sort, items: sortItems(state.items, sort) }
    }

    default:
      return state
  }
}

// 5) history 包装:支持 undo/redo
type HistoryState = {
  past: ListState[]
  present: ListState
  future: ListState[]
}

export const initialHistoryState: HistoryState = {
  past: [],
  present: initialPresent,
  future: [],
}

function isHistoryFreeAction(action: ListAction) {
  // 选择/清选择这种“UI态”你也可以选择不进历史,看你需求
  return action.type === "toggleSelect" || action.type === "selectAll" || action.type === "clearSelection"
}

export function listReducerWithHistory(state: HistoryState, action: ListAction): HistoryState {
  switch (action.type) {
    case "undo": {
      if (state.past.length === 0) return state
      const previous = state.past[state.past.length - 1]
      const past = state.past.slice(0, -1)
      return { past, present: previous, future: [state.present, ...state.future] }
    }

    case "redo": {
      if (state.future.length === 0) return state
      const next = state.future[0]
      const future = state.future.slice(1)
      return { past: [...state.past, state.present], present: next, future }
    }

    default: {
      const newPresent = presentReducer(state.present, action)

      // 没变化:不推进历史
      if (newPresent === state.present) return state

      // 有些 action 你可能不想进历史(比如选择)
      if (isHistoryFreeAction(action)) {
        return { ...state, present: newPresent }
      }

      // 正常推进历史:past +1,future 清空
      return {
        past: [...state.past, state.present],
        present: newPresent,
        future: [],
      }
    }
  }
}

ListDemo.tsx(使用示例)

import React, { useReducer, useState } from "react"
import { initialHistoryState, listReducerWithHistory } from "./listReducer"

export function ListDemo() {
  const [state, dispatch] = useReducer(listReducerWithHistory, initialHistoryState)
  const present = state.present

  const [name, setName] = useState("")
  const [groupId, setGroupId] = useState("group-a")

  const selectedCount = Object.keys(present.selectedIds).length
  const canUndo = state.past.length > 0
  const canRedo = state.future.length > 0

  return (
    
{ padding: 12 }}>

Complex List Demo

{ display: "flex", gap: 8, marginBottom: 8 }}> setName(e.target.value)} placeholder="item name" />
{ display: "flex", gap: 8, marginBottom: 8, flexWrap: "wrap" }}>
    {present.items.map((it) => (
  • { display: "flex", gap: 8, alignItems: "center" }}> dispatch({ type: "toggleSelect", payload: { id: it.id } })} /> [{it.groupId}] {it.name}
  • ))}
) }

你会发现 useReducer 的“爽点”在哪里

  • 组件里只做:dispatch({type:..., payload:...})

  • 所有更新规则都在 reducer:可读、可控、可扩展

  • 复杂操作(批量、撤销重做)天然适合 reducer


6)useReducer 的两条“好习惯”(很关键)

✅ (1) reducer 必须是纯函数

  • 只根据输入算输出

  • 不要在 reducer 里发请求 / 写 localStorage / 读 DOM

副作用放在组件里或 useEffect 里。

✅ (2) action 类型用常量/枚举

避免字符串拼错,也方便重构、TS 自动提示。


7)什么时候不值得用 useReducer?

  • 状态就 1~2 个字段,更新很少:用 useState 更简单

  • reducer 写太大:需要拆分 reducer 或者引入更合适的状态方案


本文地址:https://www.yitenyun.com/3728.html

搜索文章

Tags

#服务器 #python #pip #conda #远程工作 #ios面试 #ios弱网 #断点续传 #ios开发 #objective-c #ios #ios缓存 香港站群服务器 多IP服务器 香港站群 站群服务器 #kubernetes #笔记 #平面 #容器 #linux #学习方法 #运维 #进程控制 #docker #后端 #数据库 #Conda # 私有索引 # 包管理 #Trae #IDE #AI 原生集成开发环境 #Trae AI #开发语言 #云原生 #iventoy #VmWare #OpenEuler #人工智能 #node.js #cpolar #fastapi #html #css #低代码 #爬虫 #音视频 #MobaXterm #ubuntu #物联网 #websocket #内网穿透 #网络 #vscode #mobaxterm #深度学习 #计算机视觉 #开源 #github #git #RTP over RTSP #RTP over TCP #RTSP服务器 #RTP #TCP发送RTP #数信院生信服务器 #Rstudio #生信入门 #生信云服务器 #安全 #nginx #tcp/ip #学习 #android #腾讯云 #c# #web安全 #unity #游戏引擎 #缓存 #kylin #golang #java #redis #我的世界 #算法 #大数据 #云计算 #windows #银河麒麟高级服务器操作系统安装 #银河麒麟高级服务器V11配置 #设置基础软件仓库时出错 #银河麒高级服务器系统的实操教程 #生产级部署银河麒麟服务系统教程 #Linux系统的快速上手教程 #qt #c++ #需求分析 #架构 #vllm #大模型 #Streamlit #Qwen #本地部署 #AI聊天机器人 #面试 #多个客户端访问 #IO多路复用 #回显服务器 #TCP相关API #hadoop #hbase #hive #zookeeper #spark #kafka #flink #C++ #Android #Bluedroid #jmeter #功能测试 #软件测试 #自动化测试 #职场和发展 #prometheus #gpu算力 #grafana #todesk #压力测试 #ssh #openlayers #bmap #tile #server #vue #ping通服务器 #读不了内网数据库 #bug菌问答团队 #udp #c语言 #网络协议 #性能优化 #改行学it #创业创新 #程序员创富 #jar #claude #Dell #PowerEdge620 #内存 #硬盘 #RAID5 #apache #http #cpp #项目 #高并发 #企业开发 #ERP #项目实践 #.NET开发 #C#编程 #编程与数学 #gemini #gemini国内访问 #gemini api #gemini中转搭建 #Cloudflare #screen 命令 #华为 #ModelEngine #mvp #个人开发 #设计模式 #n8n #金融 #mcp #金融投资Agent #Agent #凤希AI伴侣 #vue.js #前端 #我的世界服务器搭建 #minecraft #elasticsearch #ollama #ai #llm #pycharm #毕业设计 #车辆排放 #课程设计 #智能手机 #epoll #sqlite #stm32 #wordpress #雨云 #电气工程 #C# #PLC #AIGC #MCP #科技 #自然语言处理 #神经网络 #libosinfo #jenkins #自动化 #maven #gitlab #centos #分阶段策略 #模型协议 #单片机 #嵌入式硬件 #TCP #客户端 #嵌入式 #DIY机器人工房 #mcu #MCP服务器 #ide #万悟 #联通元景 #智能体 #镜像 #scala #测试用例 #测试工具 #webrtc #idm #spring #flask #微信小程序 #小程序 #微信 #健身房预约系统 #健身房管理系统 #健身管理系统 #NPU #CANN #asp.net #sqlserver #鸭科夫 #逃离鸭科夫 #鸭科夫联机 #鸭科夫异地联机 #游戏 #开服 #北京百思可瑞教育 #百思可瑞教育 #北京百思教育 #risc-v #deepseek #阿里云 #JumpServer #堡垒机 #spring boot #部署 #fiddler #振镜 #振镜焊接 #电脑 #1024程序员节 #搜索引擎 #debian #macos #pytorch #版本控制 #Git入门 #开发工具 #代码托管 #银河麒麟 #系统升级 #信创 #国产化 #东方仙盟 #API限流 # 频率限制 # 令牌桶算法 #SRS #流媒体 #直播 #黑群晖 #虚拟机 #无U盘 #纯小白 #蓝湖 #Axure原型发布 #AI编程 #单元测试 #集成测试 #php #网络安全 #守护进程 #复用 #screen #编辑器 #DisM++ # GLM-4.6V # 系统维护 #京东云 #ida #研发管理 #禅道 #禅道云端部署 #umeditor粘贴word #ueditor粘贴word #ueditor复制word #ueditor上传word图片 #深度优先 #DFS #RAID #RAID技术 #磁盘 #存储 #mamba #oracle #YOLOFuse # Base64编码 # 多模态检测 #进程 #操作系统 #进程创建与终止 #shell #unity3d #服务器框架 #Fantasy #SPA #单页应用 #django #web3.py #麒麟OS #swagger #java-ee #ms-swift # 大模型 # 模型训练 #LoRA # lora-scripts # 模型微调 #Java #javascript #企业级存储 #网络设备 #负载均衡 #mysql #sql #tomcat #intellij-idea #Spring AI #STDIO协议 #Streamable-HTTP #McpTool注解 #服务器能力 #pve #json #LangGraph #CLI #Python #JavaScript #langgraph.json #ssl #zotero #WebDAV #同步失败 #代理模式 #AI #工具集 #大模型应用 #API调用 #PyInstaller打包运行 #服务端部署 #计算机网络 #大语言模型 #Dify #ARM架构 #鲲鹏 #transformer #openEuler #欧拉 #EMC存储 #存储维护 #NetApp存储 #vuejs #高级IO #select #硬件架构 #语音识别 #说话人验证 #声纹识别 #CAM++ #openresty #lua #麒麟 #910B #rdp #YOLO #目标检测 #asp.net大文件上传 #asp.net大文件上传下载 #asp.net大文件上传源码 #ASP.NET断点续传 #asp.net上传文件夹 #NAS #Termux #Samba #Linux #大模型部署 #mindie #大模型推理 #langchain #大模型开发 #程序员 #FTP服务器 #网站 #截图工具 #批量处理图片 #图片格式转换 #图片裁剪 #harmonyos #鸿蒙PC #数据分析 #SSH反向隧道 # Miniconda # Jupyter远程访问 #大模型教程 #AI大模型 #大模型学习 #VMware #简单数论 #埃氏筛法 #chatgpt #codex #yum #windows11 #microsoft #系统修复 #flutter #数码相机 #微服务 #rtsp #转发 #三维 #3D #三维重建 #uni-app #notepad++ #react.js #CVE-2025-61686 #漏洞 #路径遍历高危漏洞 #算力一体机 #ai算力服务器 # GPU租赁 # 自建服务器 #web服务器 #GPU服务器 #8U #经验分享 #智能路由器 #5G #散列表 #数据结构 #哈希算法 #AI 推理 #NV #C2000 #TI #实时控制MCU #AI服务器电源 #leetcode #SSH公钥认证 # PyTorch # 安全加固 #远程桌面 #远程控制 #硬件 #UDP的API使用 #华为云 #部署上线 #动静分离 #Nginx #新人首发 #dify #bash #信号处理 #PowerBI #企业 #vnstat #监控 #YOLO26 #文心一言 #AI智能体 #jvm #AutoDL #分布式 #运维开发 #飞牛nas #fnos #iBMC #UltraISO #支付 #个人博客 #llama #opencv #语言模型 #管道Pipe #system V #系统架构 #Clawdbot #个人助理 #数字员工 #SAP #ebs #metaerp #oracle ebs #muduo库 #uv #uvx #uv pip #npx #Ruff #pytest #Nacos #web #参数估计 #矩估计 #概率论 #aws #DeepSeek #蓝耘智算 #昇腾 #html5 #Anaconda配置云虚拟环境 #C语言 #nfs #iscsi #svn #fabric #postgresql #密码学 #可信计算技术 #openHiTLS #TLCP #DTLCP #商用密码算法 #spring cloud #测评 #CCE #Dify-LLM #Flexus #jetty #毕设 #CPU #cursor #SA-PEKS # 关键词猜测攻击 # 盲签名 # 限速机制 #计算机 #rustdesk #p2p #mybatis #PyTorch # Triton # 高并发部署 #bootstrap #信息与通信 #tcpdump #Ansible #Playbook #AI服务器 #机器学习 #kmeans #聚类 #RustDesk #IndexTTS 2.0 #本地化部署 #文件IO #输入输出流 #数据仓库 #软件 #本地生活 #电商系统 #商城 #mariadb #Spring AOP #.netcore #https #paddleocr #wsl #多进程 #python技巧 #Go并发 #高并发架构 #Goroutine #系统设计 #Tracker 服务器 #响应最快 #torrent 下载 #2026年 #Aria2 可用 #迅雷可用 #BT工具通用 #.net #net core #kestrel #web-server #asp.net-core #numpy #eBPF #Puppet # IndexTTS2 # TTS # IndexTTS 2.0 # 自动化运维 #pjsip #云服务器 #个人电脑 #Harbor #LobeChat #vLLM #GPU加速 #ansible #PTP_1588 #gPTP #人脸识别sdk #视频编解码 #人脸识别 #unix #海外服务器安装宝塔面板 #翻译 #开源工具 #CS2 #debian13 #rust #Windows #业界资讯 #fpga开发 #laravel #信创国产化 #达梦数据库 #视频去字幕 #gitea #milvus #制造 #GPU ##租显卡 #CosyVoice3 # 语音合成 #进程等待 #wait #waitpid #树莓派 #温湿度监控 #WhatsApp通知 #IoT #MySQL #结构体 #eureka #Kylin-Server #国产操作系统 #服务器安装 #Android16 #音频性能实战 #音频进阶 #广播 #组播 #并发服务器 #x86_64 #数字人系统 #推荐算法 #渗透测试 #黑客技术 #文件上传漏洞 #VMWare Tool #gpu #nvcc #cuda #nvidia #其他 #CTF #A2A #GenAI #SSE # AI翻译机 # 实时翻译 #信令服务器 #Janus #MediaSoup #聊天小程序 #心理健康服务平台 #心理健康系统 #心理服务平台 #心理健康小程序 #SQL注入主机 #无人机 #Deepoc #具身模型 #开发板 #未来 #cesium #可视化 #nodejs #tdengine #时序数据库 #涛思数据 #LangFlow # 智能运维 # 性能瓶颈分析 #ffmpeg #数据挖掘 #devops #交互 #戴尔服务器 #戴尔730 #装系统 #adb #飞牛NAS #NVR #EasyNVR #SSH密钥 # CUDA #练习 #基础练习 #数组 #循环 #九九乘法表 #计算机实现 #ThingsBoard MCP #dynadot #域名 #ETL管道 #RAG #向量存储 #数据预处理 #DocumentReader #Proxmox VE #虚拟化 #esb接口 #走处理类报异常 #serverless #clickhouse #HeyGem # 服务器IP访问 # 端口映射 #arm开发 #遛狗 #bug #smtp #smtp服务器 #PHP #银河麒麟部署 #银河麒麟部署文档 #银河麒麟linux #银河麒麟linux部署教程 #idea #intellij idea #自动化运维 #ui #cosmic #DHCP #agent #ai大模型 #Llama-Factory # 树莓派 # ARM架构 #数据安全 #注入漏洞 #大剑师 #nodejs面试题 # 一锤定音 # 大模型微调 # WebUI # 网络延迟 #MC #SSH # ControlMaster #游戏机 #银河麒麟操作系统 #openssh #华为交换机 #信创终端 #chrome #处理器 #CUDA #Triton #昇腾300I DUO #排序算法 #智能体来了 #智能体对传统行业冲击 #行业转型 #AI赋能 #teamviewer #VMware Workstation16 #服务器操作系统 #googlecloud #Qwen3-14B # 大模型部署 # 私有化AI #sql注入 # 目标检测 #LLM #chat #muduo #TcpServer #accept #高并发服务器 #vp9 #Miniconda #远程开发 #机器人 #攻防演练 #Java web #红队 # 服务器配置 # GPU #web server #请求处理流程 #SSH跳板机 # Python3.11 #WT-2026-0001 #QVD-2026-4572 #smartermail #LVDS #高速ADC #DDR #驱动开发 #springboot #知识库 #交通物流 #screen命令 #Gunicorn #WSGI #Flask #并发模型 #容器化 #性能调优 #WinSCP 下载安装教程 #SFTP #FTP工具 #服务器文件传输 #copilot #Emby #视频 #媒体 #远程连接 # ARM服务器 # 大模型推理 #ArkUI #ArkTS #鸿蒙开发 #node #门禁 #梯控 #智能一卡通 #门禁一卡通 #消费一卡通 #智能梯控 #一卡通 #源代码管理 #政务 #超时设置 #客户端/服务器 #网络编程 #H5 #手机h5网页浏览器 #安卓app #苹果ios APP #手机电脑开启摄像头并排查 #挖矿 #Linux病毒 #ai编程 #rocketmq #selenium #scrapy #嵌入式编译 #ccache #distcc #蓝牙 #LE Audio #BAP #框架搭建 #链表 #状态模式 #AI-native #dba #Tokio #puppeteer #国产化OS #react native #KMS #slmgr #系统安全 #计算几何 #斜率 #方向归一化 #叉积 #scikit-learn #随机森林 # 批量管理 #安全威胁分析 #源码 #闲置物品交易系统 #ASR #SenseVoice #星图GPU #仙盟创梦IDE #glibc #中间件 #POC #问答 #交付 #MQTT协议 #动态规划 #xlwings #Excel #vivado license #CVE-2025-68143 #CVE-2025-68144 #CVE-2025-68145 #dlms #dlms协议 #逻辑设备 #逻辑设置间权限 #集成学习 #3d #证书 #winscp #ONLYOFFICE #MCP 服务器 #后端框架 #prompt #YOLOv8 # Docker镜像 #文件管理 #文件服务器 # 双因素认证 # TensorFlow #服务器繁忙 #小艺 #鸿蒙 #搜索 #树莓派4b安装系统 #连接数据库报错 #scanf #printf #getchar #putchar #cin #cout #运维工具 #硬件工程 #智能家居 #pyqt #DNS #ddos #win11 #C #V11 #kylinos #STDIO传输 #SSE传输 #WebMVC #WebFlux #KMS激活 #企业微信 #jdk #排序 #jupyter #visual studio code #CSDN #aiohttp #asyncio #异步 #人大金仓 #Kingbase #程序人生 #AI论文写作工具 #学术写作辅助 #论文创作效率提升 #AI写论文实测 #传统行业 #信息可视化 #挖漏洞 #攻击溯源 #编程 #iot #软件工程 #blender #warp #生信 #word #pdf #Smokeping #策略模式 #租显卡 #训练推理 #数字化转型 #实体经济 #商业模式 #软件开发 #数智红包 #商业变革 #创业干货 #微PE # GLM-4.6V-Flash-WEB # AI部署 #材料工程 #智能电视 #AB包 #VMware创建虚拟机 #远程更新 #缓存更新 #多指令适配 #物料关联计划 #蓝桥杯 #m3u8 #HLS #移动端H5网页 #APP安卓苹果ios #监控画面 直播视频流 #Prometheus #日志分析 #轻量化 #低配服务器 #Zabbix #语音合成 #Anything-LLM #IDC服务器 #私有化部署 #二值化 #Canny边缘检测 #轮廓检测 #透视变换 #DooTask #raid #raid阵列 #防毒面罩 #防尘面罩 #前端框架 #java大文件上传 #java大文件秒传 #java大文件上传下载 #java文件传输解决方案 #ambari #bigtop #hdp #hue #kerberos #pencil #pencil.dev #设计 #journalctl #docker安装seata #高斯溅射 #Langchain-Chatchat # 国产化服务器 # 信创 #postman #UEFI #BIOS #Legacy BIOS #产品运营 #分类 #PyCharm # 远程调试 # YOLOFuse #Socket #VoxCPM-1.5-TTS # 云端GPU # PyCharm宕机 #全链路优化 #实战教程 #database #身体实验室 #健康认知重构 #系统思维 #微行动 #NEAT效应 #亚健康自救 #ICT人 #儿童AI #图像生成 #云开发 #KMS 激活 #AI智能棋盘 #Rock Pi S #边缘计算 #MC群组服务器 #Syslog #系统日志 #日志监控 #生产服务器问题查询 #日志过滤 #Autodl私有云 #深度服务器配置 # 水冷服务器 # 风冷服务器 #BoringSSL #Docker #云计算运维 #SSH保活 #asp.net上传大文件 #excel #ceph #everything #能源 #漏洞挖掘 #AI生成 # outputs目录 # 自动化 #C/C++ #c++高并发 #百万并发 #stl #漏洞修复 #IIS Crypto #SSH别名 #ZooKeeper #ZooKeeper面试题 #面试宝典 #深入解析 #ComfyUI # 推理服务器 #n8n解惑 #STUN #turn #ICE #编程助手 #群晖 # 鲲鹏 #elk #rabbitmq #http头信息 #uip #esp32 arduino #决策树 #ci/cd #k8s #HistoryServer #Spark #YARN #jobhistory #内存接口 # 澜起科技 # 服务器主板 # HiChatBox # 离线AI # 显卡驱动备份 #模拟退火算法 #TCP服务器 #开发实战 #计算机毕业设计 #程序定制 #毕设代做 #课设 #全文检索 #Hadoop #银河麒麟服务器系统 #X11转发 #可撤销IBE #服务器辅助 #私钥更新 #安全性证明 #双线性Diffie-Hellman #性能 #优化 #RAM #mongodb #wireshark #短剧 #短剧小程序 #短剧系统 #微剧 #nacos #银河麒麟aarch64 #hibernate #nosql #uvicorn #uvloop #asgi #event # 服务器迁移 # 回滚方案 #esp32教程 #大模型入门 #homelab #Lattepanda #Jellyfin #Plex #Kodi #SMTP # 内容安全 # Qwen3Guard #yolov12 #研究生life #汽车 #开关电源 #热敏电阻 #PTC热敏电阻 #文件传输 #电脑文件传输 #电脑传输文件 #电脑怎么传输文件到另一台电脑 #电脑传输文件到另一台电脑 #gpt #TensorRT # 推理优化 #平板 #零售 #智能硬件 #vncdotool #链接VNC服务器 #如何隐藏光标 #zabbix #企业存储 #RustFS #对象存储 #高可用 #es安装 #网络安全大赛 #模块 #r-tree #RXT4090显卡 #RTX4090 #深度学习服务器 #硬件选型 #FHSS #音乐 #青少年编程 #IntelliJ IDEA #Spring Boot #neo4j #NoSQL #SQL #CNAS #CMA #程序文件 #Coturn #TURN #log4j #Jetty # CosyVoice3 # 嵌入式服务器 #IO #插件 #开源软件 #DAG # 服务器IP # 端口7860 #云服务器选购 #Saas #线程 #VibeVoice #建筑缺陷 #红外 #数据集 #NFC #智能公交 #服务器计费 #FP-增长 #outlook #错误代码2603 #无网络连接 #2603 #SMARC #ARM # 代理转发 # 跳板机 #实时检测 #卷积神经网络 #echarts #空间计算 #原型模式 # 云服务器 #具身智能 #junit #论文笔记 # 公钥认证 #Reactor #HarmonyOS APP #MinIO服务器启动与配置详解 #代理 #数据访问 #AI电商客服 #spring ai #oauth2 #gateway #Comate #reactjs #web3 #数据可视化 #网路编程 #I/O模型 #并发 #水平触发、边缘触发 #多路复用 #rtmp #Aluminium #Google #声源定位 #MUSIC #eclipse #servlet # 高温监控 #arm64 #fs7TF #SSH复用 # 远程开发 #ROS # 局域网访问 # 批量处理 #磁盘配额 #存储管理 #形考作业 #国家开放大学 #系统运维 #C++ UA Server #SDK #跨平台开发 #机器视觉 #6D位姿 #跨域 #发布上线后跨域报错 #请求接口跨域问题解决 #跨域请求代理配置 #request浏览器跨域 #UOS #海光K100 #统信 #mssql #npu #memcache #wpf #串口服务器 #Modbus #MOXA #GATT服务器 #蓝牙低功耗 #lucene #b树 #ansys #ansys问题解决办法 #ranger #MySQL8.0 #远程软件 #Fun-ASR # 语音识别 #密码 #firefox #safari # RTX 3090 #ESP32 # OTA升级 # 黄山派 #内网 #代理服务器 #rsync # 数据同步 #le audio #低功耗音频 #通信 #连接 #arm #设计师 #图像处理 #游戏美术 #技术美术 #memory mcp #Cursor #分布式数据库 #集中式数据库 #业务需求 #选型误 #nmodbus4类库使用教程 #docker-compose #目标跟踪 # Connection refused #windbg分析蓝屏教程 #HarmonyOS #c++20 #Buck #NVIDIA #算力 #交错并联 #DGX #Apple AI #Apple 人工智能 #FoundationModel #Summarize #SwiftUI #内存治理 #多线程 #claudeCode #content7 #Socket网络编程 #跳槽 #工作 #IFix # 远程连接 #odoo #opc ua #opc #Ubuntu # 环境迁移 #matplotlib #安全架构 # 串口服务器 # NPort5630 #appche #gerrit #Python办公自动化 #Python办公 #指针 #anaconda #虚拟环境 #GB28181 #SIP信令 #SpringBoot #视频监控 # GLM-TTS # 数据安全 #xshell #host key #ftp #sftp #TTS私有化 # IndexTTS # 音色克隆 #YOLO识别 #YOLO环境搭建Windows #YOLO环境搭建Ubuntu # 轻量化镜像 # 边缘计算 #OpenHarmony #cpu #工程设计 #预混 #扩散 #燃烧知识 #层流 #湍流 #量子计算 #系统管理 #服务 # 批量部署 #硬盘克隆 #DiskGenius # TTS服务器 # 键鼠锁定 #ip #Modbus-TCP #PN 结 #服务器线程 # SSL通信 # 动态结构体 #RWK35xx #语音流 #实时传输 #超算中心 #PBS #lsf #报表制作 #职场 #用数据讲故事 #语音生成 #TTS #网安应急响应 # GLM # 服务连通性 #AI写作 #bond #服务器链路聚合 #网卡绑定 #azure #AI部署 # ms-swift #go #lvs #adobe # 高并发 #数据恢复 #视频恢复 #视频修复 #RAID5恢复 #流媒体服务器恢复 #powerbi # GPU集群 #可再生能源 #绿色算力 #风电 #Gateway #认证服务器集成详解 #服务器开启 TLS v1.2 #IISCrypto 使用教程 #TLS 协议配置 #IIS 安全设置 #服务器运维工具 #uniapp #合法域名校验出错 #服务器域名配置不生效 #request域名配置 #已经配置好了但还是报错 #uniapp微信小程序 #麦克风权限 #访问麦克风并录制音频 #麦克风录制音频后在线播放 #用户拒绝访问麦克风权限怎么办 #uniapp 安卓 苹果ios #将音频保存本地或上传服务器 #express #cherry studio #Node.js # child_process #华为od #华为机试 #gmssh #宝塔 #1panel #SSH跳转 #宝塔面板部署RustDesk #RustDesk远程控制手机 #手机远程控制 #铁路桥梁 #DIC技术 #箱梁试验 #裂纹监测 #四点弯曲 #weston #x11 #x11显示服务器 #samba #RSO #机器人操作系统 #若依 #GLM-4.6V-Flash-WEB # AI视觉 # 本地部署 #AI应用编程 #套接字 #I/O多路复用 #字节序 #AI Agent #开发者工具 #Minecraft #Minecraft服务器 #PaperMC #我的世界服务器 #前端开发 #EN4FE #自由表达演说平台 #演说 #流程图 #论文阅读 #图论 # 数字人系统 # 远程部署 #国产开源制品管理工具 #Hadess #一文上手 #okhttp # TURN # NAT穿透 #MCP服务器注解 #异步支持 #方法筛选 #声明式编程 #自动筛选机制 #kong #Kong Audio #Kong Audio3 #KongAudio3 #空音3 #空音 #中国民乐 #范式 #计算机外设 #JNI #Karalon #AI Test #pxe #ET模式 #非阻塞 #free #vmstat #sar #健康医疗 #统信UOS #win10 #qemu #AI应用 #spine #图像识别 #TRO #TRO侵权 #TRO和解 #高考 #网络攻击模型 #Discord机器人 #云部署 #程序那些事 #工程实践 #r语言 #视觉检测 #visual studio #产品经理 #就业 #wps #Linux多线程 #服务器IO模型 #非阻塞轮询模型 #多任务并发模型 #异步信号模型 #多路复用模型 #ipmitool #BMC # 黑屏模式 #vps #Beidou #北斗 #SSR #领域驱动 #移动端h5网页 #调用浏览器摄像头并拍照 #开启摄像头权限 #拍照后查看与上传服务器端 #摄像头黑屏打不开问题 #API #taro #poll #工业级串口服务器 #串口转以太网 #串口设备联网通讯模块 #串口服务器选型 #embedding #IndexTTS2 # 阿里云安骑士 # 木马查杀 #入侵 #日志排查 #simulink #matlab #信息安全 #信息收集 #实时音视频 #webpack #Host #SSRF #FASTMCP #nas #联机教程 #局域网联机 #局域网联机教程 #局域网游戏 #测速 #iperf #iperf3 #后端开发 #交换机 #三层交换机 #模型训练 #面向对象 #基础语法 #标识符 #常量与变量 #数据类型 #运算符与表达式 #sglang # 权限修复 #SSH Agent Forwarding # 容器化 #模版 #函数 #类 #笔试 #H5网页 #网页白屏 #H5页面空白 #资源加载问题 #打包部署后网页打不开 #HBuilderX #服务器解析漏洞 #算力建设 #CPU利用率 # 远程访问 #AI技术 #tensorflow #Ubuntu服务器 #硬盘扩容 #命令行操作 #vmware #ServBay #模型上下文协议 #MultiServerMCPC #load_mcp_tools #load_mcp_prompt #ShaderGraph #图形 #雨云服务器 #教程 #MCSM面板 #扩展屏应用开发 #android runtime #ue5 #opc模拟服务器 #VS Code调试配置 #反向代理 #学术论文创作 #论文效率提升 #MBA论文写作 #数据迁移 #Exchange #系统安装 #静脉曲张 #腿部健康 #运动 #mtgsig #美团医药 #美团医药mtgsig #美团医药mtgsig1.2 #IPv6 #log #claude code #code cli #ccusage #边缘AI # Kontron # SMARC-sAMX8 #remote-ssh #sentinel #MinIO #CMake #Make #OpenAI #故障 #多模态 #微调 #超参 #LLamafactory #RK3576 #瑞芯微 #硬件设计 #Java程序员 #Java面试 #Spring源码 #Spring #c