【AI工程师内参】:VSCode大模型微调参数配置黄金法则

第一章:VSCode大模型微调参数面板概览

VSCode 作为现代开发者广泛使用的代码编辑器,通过插件生态支持对大语言模型(LLM)进行本地化微调配置。借助专用扩展如 **"LLM Tuner"** 或 **"ModelCraft"**,用户可在集成开发环境中直接访问微调参数面板,实现高效、可视化的超参数管理。

核心功能区域

  • 学习率控制:支持设置基础学习率与调度策略,如余弦退火或线性衰减
  • 批次大小配置:可调整全局批次与梯度累积步数,适配不同显存环境
  • 优化器选择:提供 AdamW、Lion 等主流优化器的切换选项
  • 预训练模型加载:支持 Hugging Face 模型 ID 或本地路径输入

典型参数配置示例

{
  "model_name": "meta-llama/Llama-3-8B",      // 指定基础模型
  "learning_rate": 2e-5,                      // 初始学习率
  "batch_size_per_device": 4,                // 单设备批次大小
  "gradient_accumulation_steps": 8,          // 梯度累积步数
  "num_train_epochs": 3,                      // 训练轮次
  "warmup_steps": 100,                        // 学习率预热步数
  "optimizer": "adamw_torch"                  // 使用 PyTorch 默认 AdamW
}
// 配置文件通常位于 .vscode/llm-tune.json
// 修改后需重启微调服务以生效

参数联动机制

参数组合推荐值范围影响说明
学习率 + 预热步数1e-6 ~ 5e-5, 100~1000避免初期梯度震荡
批次大小 + 累积步数总批次 = batch × accum决定实际训练粒度
graph TD A[启动微调任务] --> B{参数校验} B -->|通过| C[加载模型权重] B -->|失败| D[高亮错误字段] C --> E[初始化训练循环] E --> F[实时监控日志输出]

第二章:核心参数配置原理与实践

2.1 学习率策略与优化器选择的理论基础

在深度学习训练过程中,学习率策略与优化器的选择直接影响模型的收敛速度与最终性能。学习率决定了参数更新的步长,若设置过大可能导致震荡不收敛,过小则收敛缓慢。
常用优化器对比
  • SGD:基础随机梯度下降,简单但易陷入局部最优;
  • Adam:自适应学习率,结合动量与RMSProp,适合大多数场景;
  • RMSProp:对非稳态目标函数表现良好。
典型学习率调度策略
# 使用余弦退火策略
from torch.optim.lr_scheduler import CosineAnnealingLR
scheduler = CosineAnnealingLR(optimizer, T_max=50, eta_min=1e-6)
该代码实现余弦退火学习率调度,T_max表示周期长度,eta_min为学习率下限,有助于跳出局部极小值并提升泛化能力。

2.2 批量大小与梯度累积的平衡艺术

在深度学习训练中,批量大小(batch size)直接影响模型收敛性与内存占用。较大的批量能提供更稳定的梯度估计,但受限于GPU显存容量。梯度累积技术通过模拟大批次训练,解决了硬件资源受限的问题。
梯度累积工作原理
该方法将一个大批次拆分为多个小批次依次前向传播与反向传播,每步累加梯度,仅在累积完成后执行一次参数更新。

optimizer.zero_grad()
for i, (inputs, labels) in enumerate(dataloader):
    outputs = model(inputs)
    loss = criterion(outputs, labels)
    loss.backward()  # 累积梯度
    if (i + 1) % accumulation_steps == 0:
        optimizer.step()      # 更新参数
        optimizer.zero_grad() # 清零梯度
上述代码中,accumulation_steps 控制累积次数,等效于将批量大小放大相应倍数。例如,每步处理样本32,累积4步,等效批量为128。
权衡策略
  • 小批量+高频更新:增强泛化能力,但波动较大
  • 大批量+低频更新:收敛稳定,但需更多显存
  • 梯度累积:折中方案,兼顾稳定性与资源利用率

2.3 预训练模型加载与适配器设置实战

模型加载流程
使用 Hugging Face Transformers 库可快速加载预训练模型。以下代码展示如何加载 BERT 模型并指定本地缓存路径:

from transformers import AutoModel, AutoTokenizer

model_name = "bert-base-chinese"
tokenizer = AutoTokenizer.from_pretrained(model_name)
model = AutoModel.from_pretrained(model_name, cache_dir="./model_cache")
上述代码中,AutoTokenizerAutoModel 自动识别模型结构与分词器配置,cache_dir 参数确保模型文件本地化存储,提升后续加载效率。
适配器注入策略
为实现参数高效微调,可通过 peft 库注入适配器模块。常用配置如下:
  • LoRA(Low-Rank Adaptation):冻结主干参数,引入低秩矩阵进行微调;
  • Adapter 模块:在 Transformer 层间插入小型前馈网络;
  • Prompt Tuning:通过可学习的提示向量引导模型输出。
该方式显著降低训练资源消耗,同时保持较高任务性能。

2.4 上下文窗口管理与显存优化技巧

上下文窗口的动态管理
在大模型推理过程中,上下文窗口直接影响显存占用。通过滑动窗口或环形缓冲机制,可限制历史 token 的存储长度,避免无限制增长。
显存优化策略
  • 使用 KV Cache 复用机制,减少重复计算
  • 启用梯度检查点(Gradient Checkpointing),以时间换空间
  • 采用混合精度训练,降低参数存储开销

# 示例:启用混合精度
from torch.cuda.amp import autocast
with autocast():
    output = model(input_ids)
该代码利用自动混合精度(AMP)技术,在前向传播中自动切换 float16 和 float32 类型,显著减少显存消耗,同时保持数值稳定性。autocast 装饰器智能判断运算精度需求,适用于矩阵乘、归一化等操作。

2.5 参数冻结与微调范围的精准控制

在模型微调过程中,参数冻结是提升训练效率与防止过拟合的关键策略。通过选择性冻结主干网络的部分层,仅微调顶层或特定模块,可在保留预训练知识的同时适配下游任务。
冻结卷积基底的典型实现
model = torchvision.models.resnet50(pretrained=True)
for param in model.parameters():
    param.requires_grad = False
# 仅微调分类头
model.fc = nn.Linear(model.fc.in_features, num_classes)
上述代码冻结ResNet50所有参数,仅替换并训练最后的全连接层。`requires_grad=False`确保梯度不更新,显著减少计算开销。
分层微调策略对比
策略冻结层可训练参数比例
全量微调100%
头部微调除fc外全部~2%
渐进解冻逐步开放深层动态增长

第三章:高级调优功能深度解析

3.1 混合精度训练的启用与稳定性保障

混合精度训练通过结合单精度(FP32)和半精度(FP16)计算,在保证模型收敛性的同时显著提升训练速度并降低显存占用。现代深度学习框架如PyTorch提供了自动混合精度(AMP)模块,简化了实现流程。
启用自动混合精度
from torch.cuda.amp import autocast, GradScaler

scaler = GradScaler()

for data, target in dataloader:
    optimizer.zero_grad()
    with autocast():
        output = model(data)
        loss = criterion(output, target)
    scaler.scale(loss).backward()
    scaler.step(optimizer)
    scaler.update()
上述代码中,autocast上下文管理器自动选择合适的精度执行前向传播;GradScaler则对梯度进行动态缩放,防止FP16下梯度下溢,保障数值稳定性。
关键机制解析
  • 动态损失缩放:初始使用较大缩放因子,避免梯度值过小导致精度丢失;
  • 梯度裁剪兼容性:在scaler.step()前可安全应用torch.nn.utils.clip_grad_norm_
  • 参数更新原子性scaler.step()scaler.update()需成对调用,确保优化过程完整。

3.2 梯度裁剪与权重衰减的协同作用

在深度神经网络训练过程中,梯度爆炸与过拟合是两大常见挑战。梯度裁剪通过限制梯度范数防止参数更新过大,而权重衰减则在损失函数中引入L2正则项,抑制参数值过度增长。
协同优化机制
二者结合可在稳定训练的同时提升模型泛化能力。梯度裁剪保障优化方向的数值稳定性,权重衰减则持续约束模型复杂度。

# PyTorch 示例:联合使用梯度裁剪与权重衰减
optimizer = torch.optim.Adam(model.parameters(), lr=1e-3, weight_decay=1e-4)
torch.nn.utils.clip_grad_norm_(model.parameters(), max_norm=1.0)
上述代码中,weight_decay=1e-4 引入L2惩罚,clip_grad_norm_ 将所有参数的总梯度范数裁剪至1.0以内,避免异常梯度导致的训练震荡。
超参数搭配建议
  • 权重衰减系数宜设为1e-4 ~ 1e-2,依数据集复杂度调整;
  • 梯度裁剪阈值推荐1.0或5.0,过小会抑制学习,过大则失效。

3.3 自定义调度器在VSCode中的集成实践

在VSCode中集成自定义调度器,需通过扩展插件形式实现对任务调度逻辑的深度控制。首先,开发者需定义调度器的核心接口,并将其封装为独立模块。
扩展配置示例
{
  "contributes": {
    "taskDefinitions": [
      {
        "type": "customScheduler",
        "requires": {
          "properties": ["command", "schedule"]
        }
      }
    ]
  }
}
该配置注册了名为 customScheduler 的任务类型,支持指定命令与调度周期。其中 command 表示待执行指令,schedule 遵循 cron 表达式格式,用于设定触发时间。
调度逻辑注入流程
  • 加载插件时注册自定义任务提供者
  • 解析 tasks.json 中的调度配置
  • 启动定时器并绑定回调执行
  • 输出执行日志至集成终端

第四章:调试与性能监控配置

4.1 实时损失曲线与指标日志输出设置

在深度学习训练过程中,实时监控损失函数变化和关键评估指标至关重要。通过合理的日志配置,可以动态可视化模型收敛趋势。
日志回调函数配置
使用TensorFlow/Keras的TensorBoard回调可实现自动记录:

tensorboard_callback = tf.keras.callbacks.TensorBoard(
    log_dir='./logs',          # 日志存储路径
    histogram_freq=1,          # 每轮记录权重直方图
    write_graph=True,          # 记录计算图结构
    update_freq='batch'        # 每个batch更新损失曲线
)
model.fit(x_train, y_train,
          callbacks=[tensorboard_callback],
          epochs=10)
该配置支持在训练期间实时生成损失与准确率曲线,便于及时发现过拟合或梯度异常。
关键监控指标列表
  • 训练损失(Training Loss):反映模型拟合能力
  • 验证损失(Validation Loss):判断泛化性能
  • 学习率(Learning Rate):监控调度策略执行情况
  • 梯度范数(Gradient Norm):检测梯度爆炸/消失

4.2 断点恢复与检查点保存策略配置

在流式计算系统中,断点恢复依赖于检查点(Checkpoint)机制来保障状态一致性。通过定期持久化任务状态,系统可在故障后从最近的检查点恢复,避免重复处理或数据丢失。
检查点配置参数
  • checkpointInterval:设置检查点触发周期,影响恢复时间与性能开销;
  • stateBackend:指定状态存储方式,如 RocksDB 支持增量检查点;
  • exactlyOnce:确保每条记录仅被处理一次。
代码示例:Flink 检查点配置
StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();
env.enableCheckpointing(5000); // 每5秒触发一次检查点
env.getCheckpointConfig().setCheckpointingMode(CheckpointingMode.EXACTLY_ONCE);
env.getCheckpointConfig().setMinPauseBetweenCheckpoints(2000);
env.setStateBackend(new RocksDBStateBackend("hdfs://checkpoint-dir"));
上述配置启用精确一次语义,限制连续检查点最小间隔为2秒,防止背压。状态后端使用 RocksDB 并将快照保存至 HDFS,支持大状态与分布式恢复。

4.3 GPU资源监控与瓶颈诊断工具联动

在深度学习训练和高性能计算场景中,GPU资源的高效利用依赖于监控与诊断工具的协同工作。通过将NVIDIA的nvidia-smi与性能分析工具nsight systems联动,可实现从硬件状态到应用层性能的全链路观测。
数据同步机制
利用定时脚本采集GPU指标,并与应用日志对齐时间戳,确保分析一致性:

# 每秒采集一次GPU使用率、显存及温度
while true; do
  nvidia-smi --query-gpu=timestamp,utilization.gpu,memory.used,temperature.gpu \
             --format=csv >> gpu_metrics.log
  sleep 1
done
该脚本输出包含时间戳的CSV格式数据,便于后续与PyTorch或TensorFlow的日志进行时间轴对齐,定位高延迟操作对应的GPU负载突增。
瓶颈关联分析表
现象可能瓶颈建议工具
GPU利用率低但训练慢CPU预处理或I/O阻塞nsight + Py-Spy
显存占用高批量过大或内存泄漏nvprof + torch.cuda.memory_summary()

4.4 分布式训练参数的VSCode适配配置

在进行分布式深度学习开发时,VSCode作为主流IDE需针对性配置以支持多节点参数调试。首先应安装Python、Remote-SSH扩展,实现对远程计算节点的无缝连接。
配置 launch.json 支持多进程调试
{
  "name": "Python: Multiprocess Launch",
  "type": "python",
  "request": "launch",
  "program": "${workspaceFolder}/train_distributed.py",
  "console": "integratedTerminal",
  "args": [
    "--world-size", "4",
    "--rank", "${command:pickProcess}"
  ]
}
该配置通过--world-size指定总进程数,--rank动态绑定进程ID,结合VSCode的进程选择命令实现分布式断点调试。
推荐扩展组合
  • Python (Microsoft):提供语言服务与调试支持
  • Remote-SSH:连接远程GPU集群
  • PyTorch Tools:自动识别分布式训练日志结构

第五章:未来发展方向与生态展望

边缘计算与AI模型协同演进
随着物联网设备数量激增,边缘侧推理需求显著上升。以TensorFlow Lite为例,在树莓派部署轻量级BERT模型已成为现实:
# 加载TFLite模型并执行推理
import tflite_runtime.interpreter as tflite
interpreter = tflite.Interpreter(model_path="model_quantized.tflite")
interpreter.allocate_tensors()

input_details = interpreter.get_input_details()
output_details = interpreter.get_output_details()

interpreter.set_tensor(input_details[0]['index'], input_data)
interpreter.invoke()
output = interpreter.get_tensor(output_details[0]['index'])
此类部署已在智能工厂质检系统中落地,实现毫秒级缺陷识别。
开源生态的融合趋势
主流框架间的互操作性不断增强,PyTorch与ONNX的集成支持模型跨平台迁移。典型工作流如下:
  • 在PyTorch中训练ResNet-18模型
  • 导出为ONNX格式,保留动态轴配置
  • 使用ONNX Runtime在Windows/Linux/CUDA环境中部署
该流程已被Azure ML和AWS SageMaker纳入标准支持路径。
开发者工具链升级
现代MLOps平台整合了版本控制、自动化测试与灰度发布机制。下表对比两类主流方案:
特性MLflowKubeflow
实验追踪内置UI需集成
集群调度依赖外部系统原生Kubernetes支持
CI/CD集成GitHub Actions模板Argo Workflows深度绑定
源码直接下载地址: https://pan.quark.cn/s/a4b39357ea24 过采样与欠采样构成了数字信号处理领域中两种基础的采样策略,它们在工程实践应用时各自展现出独特的长处与短处及适用情境。以下将深入阐释这两种采样方法的运作机制,并对它们在实际操作中的区别进行细致对比。 我们首先阐释过采样的核心概念。过采样(Oversampling)一般是指运用高于必要标准频率对模拟信号实施采样。举例而言,当信号频率为70MHz且信号带宽为20MHz时,依据奈奎斯特采样准则,理论上采样频率只需略高于40MHz(即信号带宽频率的两倍)即可达成无失真采样。然而,在现实操作中,系统构造者常常会采用超过140MSPS(每秒百万次采样)的采样速率,这通常超出理论所需。过采样的主要不利之处涵盖:提升ADC输出数据速率,引发FPGA的时序挑战;增大功耗、ADC及FPGA的制造成本。尽管存在这些不足,过采样依然具备其有利之处,例如可提供处理增益、频率规划的伸缩性以及能够处理更宽的信号带宽。 接下来,我们探讨欠采样的基本原理。欠采样(Undersampling)是指以低于理论标准频率对信号进行采样,这在处理高输入信号频率时尤为有效。例如,针对70MHz的中频(IF)信号,通过欠采样能够采用低于40MHz的采样频率进行采样,从而将数据速率降至FPGA,减少时序挑战,节省能量消耗和成本。实现欠采样的关键设计考量在于它能够在系统设计中达成所需的ADC动态性能。 欠采样的优势体现为能够简化硬件构造,比如降低对高速数据捕获的需求,并且在设计条件允许时,可选用较慢的ADC来削减成本。然而,欠采样技术也存在其局限性,例如在ADC的非理想表现可能导致非线性失真,诸如二阶(HD2)和三阶(HD3)谐...
源码链接: https://pan.quark.cn/s/3523d8c4b5d2 ### Qt5.9.1开发的应用程序转换为可安装`.exe`文件的详细流程 #### 一、概述 本资料将系统性地阐述如何将基于Qt5.9.1版本或其他Qt框架版本开发的应用程序转化为可直接安装的`.exe`安装文件。这一过程不仅适用于Qt5.9.1版本,对其他版本的Qt框架开发的应用同样适用。 #### 二、前期准备 在开展相关操作前,需确保已达成以下准备要求: 1. **开发环境配置**: 利用Qt5.9.1或其他版本完成应用程序的开发工作,并保证能够顺利编译出可执行程序。 2. **NSIS安装**: NSIS(Nullsoft Scriptable Install System)作为一个开源的Windows安装系统,能够支持创建专业的安装程序。用户可从官方渠道或可靠来源获取最新版的NSIS并进行安装。 #### 三、制作可执行程序的流程 ##### 3.1 打包应用程序文件 需要将已开发好的Qt应用程序的所有组件和资源整合到一个文件夹中,例如命名为`Qt_Video`。确保该文件夹内包含所有必要的库文件和资源文件,以便应用程序能够独立运行。 ##### 3.2 压缩文件随后,将整个`Qt_Video`文件夹压缩成`.zip`格式的文件。这一步骤可通过Windows内置的压缩工具或第三方软件完成。 ##### 3.3 创建安装文件接下来,借助NSIS将压缩文件转化为安装文件。具体操作如下: 1. **启动NSIS**: 运行NSIS软件并进入其主界面。 2. **选择基于ZIP的安装模式**: 在主界面中选取“**Installer based on ZIP file**...
内容概要:本文介绍了一种结合单像素检测与数据融合技术的千亿体素级多维荧光成像方法,并提供了完整的Matlab代码实现。该方法融合压缩感知理论与单像素成像原理,通过优化测量矩阵设计、重构算法及多维度数据融合策略,实现了在大幅降低数据采集量的前提下,完成高分辨率、高通量的三维荧光成像,特别适用于大规模生物样本的快速、高效成像需求。文中系统阐述了成像系统的建模过程、关键算法的设计思路以及重建性能的优化路径,充分展现了其在超高体素规模下的成像能力与精确重构优势。; 适合人群:面向具备信号处理、光学成像或生物医学工程等相关专业背景的研究生、科研人员及工程技术开发者,尤其适合熟悉Matlab编程并致力于先进成像技术研究与算法复现的专业人士。; 使用场景及目标:①应用于大规模生物组织的三维荧光成像,显著提升成像效率与图像质量;②为单像素成像、压缩感知与多源数据融合等前沿技术提供可复现、可扩展的算法框架;③支撑高维医学影像重建、新型显微成像系统开发及相关科研与工程实践。; 阅读建议:建议结合所提供的Matlab代码进行模块化分析,重点理解测量过程的数学建模与图像重构算法的实现细节,宜在掌握基本理论的基础上开展仿真实验与参数调优,以深入把握核心技术原理与工程实现要点。
下载代码方式:https://pan.quark.cn/s/a4b39357ea24 Node.js 是一种开放源代码且能够在多种操作系统上运行的 JavaScript 执行环境,它使得开发人员能够在服务器端执行 JavaScript 代码。Node.js 采用了 V8 引擎,该引擎是由 Google 为 Chrome 浏览器开发的一个高性能的 JavaScript 解释器。Node.js 的 16.x 版本在其发展历程中占据着重要位置,其中包含了众多新功能以及性能上的改进。标题 "Nodejs16-x64 windows安装包" 指向的是专为 Windows 操作系统设计的 64 位版本的 Node.js 16 安装程序。在 Windows 平台上安装 Node.js 的 64 位版本对于处理大量数据或运行需要高性能的应用程序来说尤为关键,因为 64 位系统能够更有效地利用硬件资源。描述 "Nodejs-16 x64位windows 安装包" 明确了该安装程序是为 Windows 用户准备的,特别是对于那些需要运行 64 位应用程序的用户。x64 表明该版本兼容 64 位架构,意味着它能够充分利用 64 位计算机的内存和处理能力。标签 "Node Nodejs nodejs16" 提供了关于此安装包的核心信息,表明它与 Node.js 相关,并且具体指的是 v16 版本。这些标签有助于进行搜索和分类,从而方便用户找到他们所需要的特定版本。压缩包文件 "node-v16.18.0-x64.msi" 代表实际的安装文件,其中 "v16.18.0" 指示了 Node.js 的具体版本号,"x64" 再次强调了其适用于 64 位系统,而 ".msi" 后缀表明这是一...
源码链接: https://pan.quark.cn/s/3af847fbbec7 在计算机科学与编程领域中,十六进制(Hexadecimal)以及二进制(Binary)是两种关键性的数值表示方法。十六进制属于一种基于16的计数系统,它运用0至9的数字以及字母A至F(分别象征10至15的数值)来呈现数值,与此同时,二进制则是一种基于2的计数系统,仅采用0和1两个符号。掌握这两种进制之间的相互转换对于深入理解计算机内部运作机制具有决定性意义,因为计算机在底层数据的存储与处理环节通常都是以二进制的形式来进行的。将十六进制转换成二进制的过程可以通过以下几个环节得以完成: 1. **单个十六进制符号的转换**:每一个十六进制符号对应着4位二进制序列。具体而言: - 十六进制中的`0`在二进制表达为`0000` - 十六进制中的`1`在二进制表达为`0001` - 十六进制中的`2`在二进制表达为`0010` - 依此类推 - 十六进制中的`9`在二进制表达为`1001` - 十六进制中的`A`或`a`在二进制表达为`1010` - 十六进制中的`B`或`b`在二进制表达为`1011` - 十六进制中的`C`或`c`在二进制表达为`1100` - 十六进制中的`D`或`d`在二进制表达为`1101` - 十六进制中的`E`或`e`在二进制表达为`1110` - 十六进制中的`F`或`f`在二进制表达为`1111` 2. **多位十六进制符号的转换**:针对一个由多个十六进制符号组成的数值,我们可以逐个符号进行转换,并将得到的二进制序列依次拼接。例如,十六进制数`3F`转换成二进制形式为`00111111`。 3. **编程实现方法**:在编程实践过程中,众多编程语言提...
下载代码方式:https://pan.quark.cn/s/a4b39357ea24 **Vue.js 框架全面解析** Vue.js 是一种轻量级且高性能的前端JavaScript框架,因其便捷性、适应性和可扩展性而备受开发者青睐。在“nodejs+vue”的在线购物平台中,Vue.js 主要承担构建用户界面的任务,并提供数据绑定、组件化、路由管理等关键功能。 1. **数据绑定**:Vue.js 的核心优势之一是双向数据绑定,它借助 `v-model` 指令将视图与数据模型建立联系,确保视图层的变动能即时同步到数据模型,同时数据模型的变化也能实时反映在视图上。在在线购物平台中,这一特性可用于商品列表的动态展示和购物车状态的即时调整。 2. **组件化**:Vue.js 提供了功能强大的组件体系,允许开发者将用户界面拆分为独立且可复用的模块。例如,在在线购物平台中,商品展示模块、购物车功能、支付流程等均可封装为组件,从而提升代码的复用性和可维护性。 3. **指令与过滤器**:Vue.js 中的指令如 `v-if`、`v-for` 和 `v-bind` 用于控制元素的渲染方式及行为,过滤器则能对数据进行格式化处理,例如货币显示、时间格式转换等。在在线购物平台中,这些功能有助于更有效地展示商品信息并优化用户交互体验。 4. **计算属性与侦听器**:计算属性能够监测多个数据源并输出计算结果,而侦听器则能在数据变动时执行指定操作。在在线购物平台中,计算属性可用于自动计算购物车总金额,侦听器则可响应库存变动并实时更新商品状态。 5. **Vue Router 路由管理**:在单页应用(SPA)环境中,Vue Router 是不可或缺的组件,它负责管理页面间的导航和...
打开链接下载源码: https://pan.quark.cn/s/a4b39357ea24 我的世界开发者中文指南 MCBBS关站致使大量教程失效,恳请各位读者协助指南联系相关作者及时迁移教程。 点击右上方的“Watch”按钮以实时获取中文指南的更新情况,点击右上方“Star”按钮以支持中文指南的编撰。 欢迎各位在此提交各类我的世界开发相关教程、资料、文档、类库。 欢迎加入我的世界开发讨论Q群:345538010 发布定制或承接定制请加入我的世界定制交流Q群:1047988033 目录 提问的方法 常用网站与资源 Java基础 Forge模组 NeoForge模组 Bukkit/Spigot插件 Fabric模组 BungeeCord插件 Sponge插件 数据包 Java版启动器 基岩版服务端 基岩版Addons 基岩版模组 网易基岩版 着色器包 过时资源 版权声明 提问的方法 当你遇到使用搜索引擎、查阅相关文档、进行Debug(如果没有做过上述操作的话,请立刻去做)也无法解决的问题的时候,你可能会向他人求助。 当你提问时,请确保你准确提供了以下信息: 准确描述你的需求和实际问题情况。 准确描述你所在的平台的信息。 例如: - Java 版本 - 所用开发工具及其版本(如IntelliJ IDEA、Eclipse) - 所用自动化构建工具及其版本(如Maven、Gradle) - Minecraft 版本 - Bukkit/Spigot/Forge/Sponge/Fabric 任一所在平台及其版本 - 依赖的类库、模组或插件及其版本 提供你的源代码或SSCCE(最小化、完整、可验证的问题示例),将源代码包括项目描述文件完整上传至源码托管平台(如码云、)。 提供你的完整日...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值