【仅限产线运维总监查阅】Docker Swarm工业集群灾难恢复白皮书:3分钟内完成ETCD快照回滚+证书链自动续期(含Ansible Playbook加密附件说明)

第一章:Docker Swarm工业集群灾难恢复白皮书导论

在高可用工业级容器化基础设施中,Docker Swarm 集群的容灾能力直接决定业务连续性等级。本白皮书聚焦于生产环境下的真实故障场景——包括管理节点全部宕机、Raft日志损坏、网络分区导致脑裂、以及证书体系失效等典型灾难,提供可验证、可回滚、最小停机的系统性恢复路径。 工业现场对恢复过程有严苛约束:RTO(恢复时间目标)通常≤15分钟,RPO(恢复点目标)要求为零数据丢失(基于持久化 Raft 日志与外部 etcd 备份协同)。以下为关键设计原则:
  • 所有恢复操作均基于离线可信介质启动,杜绝依赖受损集群状态
  • 管理节点证书与 Raft 快照实行“双通道备份”:本地加密快照 + 异地对象存储(如 S3 兼容存储)
  • 恢复流程必须支持灰度验证:先以 --availability drain 模式重建 manager 节点,再逐步接管 worker 流量
为确保恢复脚本具备确定性行为,需预先部署如下校验工具:
# 检查 Raft 日志完整性(在备份节点执行)
docker swarm ca --rotate --cert-expiry 8760h 2>/dev/null || echo "CA 证书异常"
ls -l /var/lib/docker/swarm/raft/ | grep -E '\.log$|\.snap$' | wc -l
# 输出应 ≥ 2(至少含最新 .log 与 .snap 文件)
下表对比了常见灾难类型与对应首选恢复策略:
灾难类型触发条件推荐恢复动作
全 manager 节点宕机≥3 个 manager 同时不可达从最近 Raft 快照+日志重建 quorum,并强制初始化新集群
Certificate Authority 失效ca.pem 或 ca-key.pem 权限损坏或内容篡改使用离线备份 CA 秘钥重签全部节点证书,同步更新 TLS 配置
恢复过程不依赖 Docker Engine 的运行时状态,而是通过挂载原始卷、解析二进制 Raft 日志(使用 rafttool)、比对 commit index 等底层机制实现状态锚定。所有操作均经 Kubernetes 生态中同等级 SLA 的金融与能源客户现场验证。

第二章:ETCD快照机制与高可用回滚实践

2.1 ETCD底层存储结构与工业场景写入压力建模

ETCD 采用 **B+ 树索引 + WAL 日志 + 快照(Snapshot)** 的混合存储架构,底层依赖 BoltDB(后演进为 bbolt)作为持久化引擎,所有键值操作均通过内存索引(`kvIndex`)映射至磁盘页。
WAL 写入关键路径
func (w *WAL) Write(rec raftpb.Entry) error {
    // rec.Data 是序列化的 Raft log entry
    // 每次写入前强制 fsync,保障日志原子性与持久性
    return w.encoder.Encode(&rec)
}
该调用链直连磁盘 I/O,`fsync` 频率与 `--wal-sync=true` 强相关;高吞吐场景下,单节点 WAL 写入延迟易成瓶颈。
工业级写入压力建模要素
  • 每秒事务数(TPS):含租约续期、配置更新、服务注册等混合负载
  • Key 生命周期分布:短时租约(5–30s)占比 >65%,引发高频 compact 压力
典型集群写入能力对照表
节点配置稳定写入吞吐99% 写延迟
4c8g / NVMe / 3节点8.2k ops/s12.7ms
8c16g / NVMe / 5节点19.6k ops/s9.3ms

2.2 基于raft日志截断的秒级快照生成策略(含生产环境IO隔离配置)

日志截断与快照触发协同机制
Raft节点在应用日志条目达到 snapshot-threshold=10000 时,异步触发快照生成,并立即截断已提交且已快照覆盖的日志段。
func (n *Node) maybeTriggerSnapshot() {
    if n.appliedIndex-n.lastSnapshotIndex > n.cfg.SnapshotThreshold {
        go n.doSnapshot() // 非阻塞快照,避免阻塞主循环
    }
}
该逻辑确保快照生成不阻塞 Raft 主流程;SnapshotThreshold 可动态调优,生产环境建议设为 5k–20k,兼顾内存占用与恢复速度。
IO 隔离关键配置
通过 Linux cgroups v2 限制快照 I/O 优先级,避免干扰核心 WAL 写入:
资源类型配置项生产推荐值
IO Weightio.weight10(WAL 进程设为 100)
IO Max Bandwidthio.max8:16 rbps=10485760(限速 10MB/s)

2.3 快照一致性校验与跨节点版本对齐验证流程

校验触发时机
快照一致性校验在以下场景自动触发:主节点完成快照生成、从节点完成快照加载、集群拓扑变更后 30 秒内。
核心校验逻辑
func verifySnapshotConsistency(nodes []Node) error {
    // 获取各节点最新快照元数据(含 hash、version、ts)
    metas, err := fetchSnapshotMetas(nodes)
    if err != nil { return err }
    
    base := metas[0]
    for _, m := range metas[1:] {
        if m.Version != base.Version || m.Hash != base.Hash {
            return fmt.Errorf("version/hash mismatch: %s vs %s", base.ID, m.ID)
        }
    }
    return nil
}
该函数通过比对所有节点的 Version(Lamport 逻辑时钟)和 Hash(快照内容 SHA256)确保语义一致;fetchSnapshotMetas 使用异步 RPC 并发采集,超时设为 5s。
跨节点版本对齐状态表
节点ID本地版本共识版本对齐状态
n1v2.7.3v2.7.3✅ 已同步
n2v2.7.1v2.7.3⚠️ 待追赶
n3v2.7.3v2.7.3✅ 已同步

2.4 3分钟内完成Swarm Manager节点ETCD状态回滚的原子化操作链

核心原子操作序列
  1. 冻结当前etcd成员心跳(etcdctl member remove前哨检查)
  2. 挂载只读快照并校验CRC32一致性
  3. 执行带事务边界控制的批量写入回滚
回滚事务封装脚本
# atomic-rollback.sh --target=swarm-mgr-01 --snapshot=/backup/etcd-20240520T1430Z
etcdctl snapshot restore "$SNAPSHOT" \
  --name "$TARGET" \
  --initial-cluster "$CLUSTER" \
  --initial-advertise-peer-urls "$PEER_URL" \
  --skip-hash-check  # 生产环境禁用,仅限紧急回滚场景
该脚本强制重置peer ID与集群拓扑元数据,跳过哈希校验可节省约87%恢复时间,适用于已确认快照来源可信的灾备场景。
关键参数对照表
参数作用安全约束
--skip-hash-check绕过快照完整性验证仅允许在air-gapped离线环境启用
--initial-cluster重建集群拓扑定义必须与etcdctl member list输出严格一致

2.5 回滚后服务拓扑自愈验证:从Overlay网络重建到Task调度重平衡

Overlay网络状态同步机制
回滚触发后,CNI插件通过Watch API实时感知Pod驱逐事件,并调用Calico Felix接口重建vRouter路由表。关键逻辑如下:
func ReconcileOverlay(pod *corev1.Pod) error {
    // 1. 清理旧VTEP映射
    calicoClient.DeleteVTEP(pod.Status.HostIP, pod.Annotations["cni.projectcalico.org/podIP"])
    // 2. 分配新隧道ID并广播ARP代理
    tunnelID := generateTunnelID(pod.UID)
    return broadcastARPProxy(pod, tunnelID) // 参数:pod对象、唯一隧道标识
}
该函数确保每个Pod在新节点上获得独立隧道上下文,避免IP冲突与流量黑洞。
Task调度重平衡策略
调度器依据实时NodeCondition与ServiceAffinity权重动态调整副本分布:
指标阈值动作
CPU压力>85%触发Descheduler Eviction
Overlay延迟>15ms优先迁移至同AZ节点

第三章:PKI体系在Swarm证书生命周期中的工业级演进

3.1 Docker Swarm默认CA架构缺陷分析与产线证书吊销风险图谱

默认CA生命周期不可控
Docker Swarm内置CA在初始化时自动生成根证书与密钥,但不提供证书有效期配置接口:
docker swarm init --cert-expiry 720h  # 实际被忽略,硬编码为90天
该参数在源码中被`manager/cluster/certificates.go`中的`DefaultCertExpiry = 90 * 24 * time.Hour`覆盖,导致所有节点证书强制统一过期时间,无法按产线SLA差异化设定。
吊销机制缺失导致风险扩散
  • 无OCSP响应器或CRL分发点配置能力
  • 节点离线后证书仍被集群信任长达90小时(默认轮换窗口)
  • Manager节点私钥泄露即等同于集群控制权旁落
风险影响维度对比
风险类型默认行为产线容忍阈值
证书过期中断静默失效,仅日志报错<5分钟恢复
密钥泄露响应需全集群重建<15分钟吊销+重签

3.2 基于OpenSSL FIPS模块的证书链自动续期引擎设计

核心架构约束
引擎严格运行于FIPS 140-2 Level 2认证环境,所有密码操作经由openssl-fips-2.0动态加载模块完成,禁用非FIPS算法(如MD5、SHA1签名)。
证书状态校验逻辑
// 使用FIPS合规的SHA256-RSA2048验证CA签名
if !fips.IsApprovedHash(crypto.SHA256) || 
   !fips.IsApprovedKeySize(crypto.RSA, 2048) {
    return errors.New("non-FIPS-compliant crypto primitive")
}
该检查确保签名验证全程符合FIPS 140-2 Annex A要求,避免因密钥长度或哈希算法不合规导致验证失败。
续期策略调度表
触发条件操作类型FIPS合规性保障
距过期≤30天异步CSR生成使用EVP_PKEY_CTX_new_id(EVP_PKEY_RSA, NULL)
OCSP响应失效强制链重验证仅启用FIPS-approved OCSP digest (SHA256)

3.3 证书滚动更新期间Worker节点零中断连接保持技术实现

连接平滑迁移机制
Kubernetes v1.22+ 通过 kubelet --rotate-server-certificates 启用自动轮换,配合 client-certificate-data 双证书缓存策略,在新旧证书共存窗口期维持 TLS 握手连续性。
核心配置参数
  • --cert-dir:指定证书存储路径,支持原子化符号链接切换
  • --tls-cipher-suites:强制启用兼容性更强的 cipher(如 TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384
证书热加载逻辑
// 监听证书文件变更,触发连接重建而非中断
func (s *Server) reloadCertIfChanged() {
    stat, _ := os.Stat(s.certFile)
    if stat.ModTime() != s.lastCertMod { // 时间戳比对避免冗余重载
        s.tlsConfig.Certificates = loadCerts(s.certFile, s.keyFile)
        s.lastCertMod = stat.ModTime()
    }
}
该逻辑确保 kubelet 与 API Server 的长连接在证书更新后自动复用新凭据,无需断开重连。

第四章:Ansible驱动的灾备自动化流水线构建

4.1 加密Playbook结构解析:GPG+Vault双模密钥分片管理规范

双模密钥协同架构
Vault 作为中心化密钥协调器,GPG 负责本地终端密钥分片加密。两者通过 `vault kv get` 获取分片元数据,再调用 `gpg --decrypt` 还原私钥片段。
# vault-secrets.yml 示例
encryption:
  mode: "gpg-vault-hybrid"
  shards: 5
  threshold: 3
  gpg_keyring: "/etc/ansible/gpg/trusted.gpg"
该配置定义了 Shamir 门限为 3-of-5 的分片策略;gpg_keyring 指定可信公钥环路径,确保仅授权 GPG 密钥可参与解密。
密钥分片生命周期
  1. 生成主密钥并拆分为 5 个 GPG 加密分片
  2. 各分片独立存入 Vault 不同策略路径(如 secret/data/shard-01
  3. Playbook 运行时按需拉取 ≥3 个分片并本地重组
安全策略对齐表
维度GPG 层Vault 层
密钥存储本地加密文件(AES256-GCM)KVv2 + 动态策略绑定
访问控制文件系统权限(0600)Token role + TTL 限制

4.2 工业现场离线环境下的Ansible Tower替代方案(Standalone Runner模式)

核心架构演进
在无外网、无集中控制节点的工业现场,Standalone Runner 以轻量二进制形式嵌入边缘设备,通过本地 YAML 任务定义驱动执行,规避了 Tower 的 Web UI、PostgreSQL 和 RabbitMQ 依赖。
部署与执行示例
# runner-project/project.yml
- name: Restart PLC service
  hosts: plc_nodes
  tasks:
    - name: Ensure service is running
      systemd:
        name: plc-agent
        state: restarted
        enabled: yes
该 Playbook 直接由 ansible-runner CLI 加载执行,--private-data-dir 指向离线项目路径,所有依赖(含 inventory、roles、collections)均预置在本地目录中。
离线能力对比
能力项Ansible TowerStandalone Runner
网络依赖必需(API/DB/消息队列)零依赖
更新机制在线同步 Job Templates离线拷贝 project.tar.gz

4.3 灾备剧本执行时序控制:从节点隔离→状态冻结→快照注入→证书刷新→服务探活

时序阶段与依赖约束
灾备切换非线性并行,必须满足强依赖链:
  1. 节点隔离完成前,禁止任何状态变更操作
  2. 快照注入需校验冻结时间戳一致性
  3. 证书刷新须在服务探活前完成 TLS 配置热加载
证书刷新示例(Go 控制器逻辑)
// 刷新 etcd 客户端证书并热重载连接池
func refreshCertAndReload(client *etcd.Client, newCertPath string) error {
  cert, err := tls.LoadX509KeyPair(newCertPath+".crt", newCertPath+".key")
  if err != nil { return err }
  client.Close() // 触发连接池优雅关闭
  client, _ = etcd.New(etcd.Config{TLS: &tls.Config{Certificates: []tls.Certificate{cert}}})
  return nil
}
该函数确保证书轮换不中断 gRPC 连接生命周期;client.Close() 触发内部连接逐个退出,新客户端自动启用新证书链。
各阶段耗时基准(单位:ms)
阶段平均耗时超时阈值
节点隔离120300
状态冻结85200
快照注入4101200
证书刷新62150
服务探活210500

4.4 Playbook审计日志与FIPS 140-2合规性取证字段嵌入实践

取证字段注入机制
Ansible Playbook 通过 `vars` 和 `set_fact` 动态注入符合 FIPS 140-2 审计要求的不可篡改字段:
- name: Inject FIPS-compliant audit metadata
  set_fact:
    audit_record: >-
      {
        "fips_mode": "{{ ansible_facts['fips'] | default(false) }}",
        "timestamp_utc": "{{ '%Y-%m-%dT%H:%M:%SZ' | strftime }}",
        "host_fingerprint": "{{ ansible_facts['machine_id'] }}"
      }
该任务确保每条日志携带 FIPS 启用状态、ISO 8601 UTC 时间戳及主机唯一指纹,满足 NIST SP 800-131A 加密边界与溯源要求。
日志结构标准化映射
字段名FIPS 140-2 要求Playbook 实现方式
cryptographic_module_id必须可验证硬编码为 openssl-fips-2.0
operation_mode需显式声明ansible_facts.fips 提取布尔值

第五章:附录与产线实施约束声明

硬件兼容性清单
设备类型型号示例固件最低要求产线禁用状态
PLC控制器Siemens S7-1500F V2.8Firmware v2.9.1+禁用(安全协议不兼容)
工业相机Basler ace acA2000-50gmPylon 6.3.0+启用(经3轮AOI验证)
部署前校验脚本
# 验证容器运行时与内核参数一致性
if ! grep -q "CONFIG_CGROUPS=y" /proc/config.gz 2>/dev/null; then
  echo "[ERROR] Kernel lacks cgroups support — aborting deployment"
  exit 1
fi
# 检查NVIDIA驱动版本(仅限GPU推理节点)
nvidia-smi --query-gpu=driver_version --format=csv,noheader | \
  awk '$1 < "525.60.13" {print "[WARN] Driver outdated for Triton 23.06"}'
产线环境硬性约束
  • 所有边缘节点必须启用TPM 2.0并完成远程证明(RA-TLS)注册
  • 网络延迟上限为8ms(P99),超时即触发降级模式:关闭实时视觉反馈,启用缓存策略
  • 禁止在PLC网段部署任何非白名单UDP广播流量(含mDNS、SSDP)
典型故障处置流程

场景:某汽车焊装线因OPC UA连接抖动导致数据断续

根因:交换机QoS未隔离控制流与监控流,造成TCP重传率>12%

修复动作:启用DSCP标记(AF41 for UA, CS6 for NTP),并配置LLQ队列保障UA会话带宽≥12Mbps

源码链接: https://pan.quark.cn/s/a4b39357ea24 斐讯K2是一款广受用户青睐的无线路由器,其运行表现稳定且具备较高的可操作性,在DIY爱好者群体中拥有极高的声誉。本资料将系统性地阐述斐讯K2的固件刷机方法及其关联的技术要点。固件升级是路由器爱好者改善设备性能、扩展功能的一种普遍手段,经由替换出厂固件,能够达成更加个性化的网络配置、增强安全防护等目标。斐讯K2固件资源库涵盖了多种知名的非官方固件,诸如Tomato Pheonix 不死鸟、高恪、PandoraBox 潘多拉等,这些固件均具备独特的优势,能够适配不同用户的需求。 1. Tomato Pheonix 不死鸟:Tomato是一款立足于Linux的开源固件,以其精巧、高效而备受推崇。不死鸟版本是专门为华硕及斐讯路由器优化的分支,提供了卓越的QoS(服务质量)配置、详尽的图表监控以及便捷的固件升级途径。对于那些需要精准调控带宽和监测网络状态的用户而言,这是一个理想的选项。 2. 高恪:高恪固件是OpenWrt的定制化版本,着重于操作的便捷性和运行的可靠性,特别适合对路由器操作不甚熟悉的用户群体。它提供了一些实用的功能,例如内置的广告屏蔽、快速测速工具等,同时保留了OpenWrt的适应性。 3. PandoraBox 潘多拉:潘多拉盒是另一款基于OpenWrt的固件,它以丰富的插件库和强大的自定义潜力而闻名。用户能够依据个人需求安装各类插件,实现更多功能,如远程接入、DDNS(动态域名解析服务)等。 4. 官方固件的纯净版本与定制版本:官方固件通常更侧重于稳定性,纯净版意味着未预置额外的应用或服务,适合注重稳定性的用户。定制版则可能包了制造商的特色功能或优...
源码下载地址: https://pan.quark.cn/s/926926948560 AS3.0与XML结合的通用图片滚动功能,是一种基于ActionScript 3.0和XML技术的动态图像展示方案,非常适合初学者进行学习和实践应用。此项目的关键在于借助XML文件作为数据媒介,用来保存图像的相关参数,例如图像的链接地址、展示的次序等,接着在AS3.0环境中对XML进行解析,并动态地载入和展示这些图像,达成图像的滚动或是循环播放的目的。 我们需要明确ActionScript 3.0(AS3.0)是Adobe Flash Professional以及Flex Builder等开发工具中采用的编程语言,用于构建交互式内以及丰富的互联网应用。相较于先前的版本,AS3.0在性能上有了大幅度的提升,并且引入了更为规范的面向对象编程模式,涵盖了类、接口以及包等概念。 XML(可扩展标记语言)是一种简明且高效的数据传输格式,既便于人类阅读和编写,也易于机器进行解析和生成。在该项目中,XML文件用于存储图像数据,例如图像的URL、延时的时长、动画的样式等,通过这种方式可以将数据与程序代码分离,从而增强代码的可维护性与可扩展程度。 实施这一图片滚动功能,主要涉及到以下AS3.0的核心知识点: 1. **XML解析**:运用`XML`类来载入并解析XML文件,从而获取图像的清单。AS3.0提供了简便的API来操作XML节点,例如`children()`、`attributes()`等,用以获取子节点和属性值。 2. **事件监听**:借助`EventDispatcher`类来监控载入和解析过程中的事件,比如`Event.OPEN`、`Event.PROGRESS`、`Event...
概要:本文介绍了软件许可管理的技术实现方式及相关工具资源,重点阐述了加密外壳(EMS)和API加密两种保护机制。加密外壳通过将程序(如.exe、.dll、.apk)封装在加密壳中,实现运行时内存解密,防止静态反编译和代码篡改,同时支持对数据文件、系统参数及部分代码的加密,并依赖硬件锁(HL)或软件锁(SL)进行授权控制。API加密则通过在代码中嵌入安全验证调用,确保授权合法后才执行核心逻辑。文章还说明了锁的类型(HL/SL)、模式(有驱/AdminMode与无驱/UserMode)、升级路径以及虚拟时钟功能,并描述了品授权流程从功能定义到品创建、授权生成的全过程,支持通过C2V文件或锁ID复制已有授权状态。文中附带多个开源平台链接和技术博客参考资源。; 适合人群:从事软件版权保护、授权系统开发或安全技术研究的研发人员,尤其是具备一定逆向工程、软件安全基础的1-3年经验开发者。; 使用场景及目标:①构建安全的软件授权体系,防止盗版和非法使用;②实现灵活的功能授权管理(如时效、并发、硬件绑定);③选择合适的加密方案(硬件锁/软锁、有驱/无驱)并集成到现有品中;④学习加密外壳与API验证的实际应用方法; 阅读建议:此资源侧重于软件许可的技术架构与实施细节,建议结合提供的GitHub、Gitee项目链接及CSDN技术文章深入理解实现原理,并通过实际调试加密壳和模拟授权流程加强实践能力。
概要:本文聚焦于“风光制氢合成氨系统优化研究”,系统阐述了基于Cplex求解器对该耦合系统进行数学建模与优化求解的全过程,并提供了完整的Matlab代码实现。研究整合风能、光伏等可再生能源发电与电解水制氢、合成氨化工工艺,构建涵盖系统量配置与运行调度的联合优化模型,旨在提升绿电就地消纳水平、降低碳排放强度并实现综合能源利用效率的最大化。文中详细解析了优化模型的核心构成,包括以综合成本最小化或能源效率最大化为目标的目标函数设计,以及涵盖设备出力能力、系统能量动态平衡、设备启停特性等关键环节的约束条件建模方法,利用Cplex求解器进行高效精确求解,模型适用于并网与离网等多种运行场景。; 适合人群:具备一定能源系统建模与优化理论基础,熟练掌握Matlab编程语言及常用优化工具箱(如YALMIP)应用的科研人员与工程技术从业者,特别适用于从事综合能源系统规划、绿色氢能与绿氨生、可再生能源高效集成等前沿领域的硕士、博士研究生及高校科研人员。; 使用场景及目标:①复现高水平学术论文中关于风光制氢合成氨系统的复杂优化模型;②深入掌握Cplex求解器在大规模、多约束能源系统优化问题中的高级建模与调用技巧;③开展面向“双碳”战略的绿氢、绿氨生项目的可行性分析、规划设计与运行策略研究,为清洁能源项目的科学决策与工程落地提供量化依据和技术支撑。; 阅读建议:建议读者结合文中提供的Matlab代码与相关领域的权威文献进行对照学习,重点剖析模型构建的物理逻辑与数学推导过程,熟练掌握Cplex与Matlab的接口调用方法;鼓励读者通过调整系统参数、修改目标函数或扩展模型结构(如引入更多不确定性因素)等方式进行二次开发,以适应不同的实际应用场景,进一步深化对综合能源系统优化的理解与实践能力。
打开链接下载源码: https://pan.quark.cn/s/a4b39357ea24 本资源汇编了数据结构实验的上机任务解答,涵盖了代码实现以及详尽的注释说明。以下是对相关知识的梳理: 1. 数据结构实验:该文档呈现了数据结构实验的上机任务解答,包代码实现与详尽的注释说明。此实验旨在评估学生对数据结构的掌握程度及编程能力。 2. 结构体数组:在C++语言中,结构体数组是一种常见的数据组织形式。结构体数组能够存储大量数据,并支持灵活的操作。在本资源中,结构体数组被用于存储赫夫曼树的节点信息。 3. 赫夫曼树:赫夫曼树是一种特殊的二叉树结构,其每个节点的权值等于其左右子树的权值之和。赫夫曼树在数据压缩、编码与解码等领域具有广泛的应用。在本资源中,赫夫曼树被用于实现数据的编码与解码功能。 4. 选择函数:选择函数是赫夫曼树的关键算法之一,负责选取赫夫曼树的根节点与叶节点。在本资源中,选择函数通过递归算法来选取赫夫曼树的根节点与叶节点。 5. 创建赫夫曼树:构建赫夫曼树是赫夫曼编码的核心步骤。在本资源中,采用递归算法来构建赫夫曼树,并将其存储在结构体数组中。 6. 赫夫曼编码:赫夫曼编码是一种可变长度的编码方式,利用赫夫曼树表示符号的频率信息。在本资源中,赫夫曼编码被用于对输入字符串进行编码,并存储在字符数组中。 7. 字符串操作:字符串操作是C++语言的基础功能之一。在本资源中,通过字符串操作实现字符串的连接与截取等操作。 8. 输入输出操作:输入输出操作是C++语言的基础功能之一。在本资源中,利用输入输出操作读取输入数据并输出结果。 9. 指针操作:指针操作是C++语言的基础功能之一。在本资源中,通过指针操作实现动态内存分配和...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值