DocC的简单使用

在写3GShare中,由于刚开始使用MVC模式来写东西,对很多东西都不是很熟,经常写着写着就忘了自己在写什么,所以学了一下DocC来加快开发进度

什么是DocC

简单来说,DocC就是更高级的注释,虽然DocC 是专门为 Swift 代码写文档的工具,但是在OC中也是可以使用的,它可以将基于 Markdown 的文本转换为丰富的 Swift 框架和包文档

最重要的是,DocC 语法非常简单却很强大。不需要创建额外的文件或使用其他软件,一切都可以直接在 Xcode 中完成。

基础用法

最最简单的用法,把平时用的双斜杠注释换成三斜杠

完成了!

@interface loginAndRegisterModel : NSObject
/// 存储用户数据
@property (nonatomic, strong) NSMutableArray* usersInfo;
@end

写完这些注释后,你就可以在Xcode中按住 Option 键然后点击变量名,就能看到你写的文档了

CleanShot_2025-07-25_at_23.21.152x

当然方法也是同样的道理

/// 为第一个cell的滑动照片墙提供照片数组
- (NSArray*) providesImages;

CleanShot_2025-07-25_at_23.24.342x

添加更详细的说明

如果你想在解释说明中添加更多实现的细节,可以在第一段描述后空一行,然后继续写。这些内容会显示在帮助对话框的讨论部分

/// 保存按下按钮的状态
///
/// 把按钮的tag值存在对应节的数组中,方便之后查询
- (void)saveBtnPress:(NSInteger)tag andIndexPath:(NSIndexPath*)indexPath;

CleanShot_2025-07-26_at_15.32.022x

进阶用法:参数和返回值

描述参数

使用 - Parameters: 关键字可以描述函数的参数。注意破折号和冒号都是必需的,它们用作分隔符

但是在OC中似乎没有办法正常编译进去,这里使用swift演示一下

extension Array {/// 根据月份的日期返回一个随机元素,/// 该日期用于计算随机索引。////// stableRandom 函数在整个日期内始终返回相同的元素。/// 但是一旦日期发生变化,它的值就会改变。////// - Parameters:///     - date: 用于随机化算法的日期。func stableRandom(using date: Date = .now) throws -> Element {// 实现代码...}
}

image

描述返回值和错误

返回值和错误在oc中可以正常描述,语法与参数一样

/// 检测注册信息是否可用
///  - Returns:
///  0:注册成功
///  1:邮箱有重复
///  2:用户名有重复
///  - Throws: 返回nil
- (NSInteger) isValidRegister:(user*) users;

CleanShot_2025-07-26_at_16.04.222x

DocC 的实际应用场景

合作开发

在合作开发中,对每个方法做好DocC能大大提高开发效率,可以让每个人方便的知道你的方法是干什么的,会返回什么结果,可能会出现什么样的错误

自己回顾代码

由于笔者刚开始使用MVC模式来写项目,常常会在三个甚至六个不同的文件里来回穿梭,在学了DocC后,就方便了许多,回头看自己写的DocC 文档可以让我快速的回忆起方法的作用

写在最后

当然,这里的介绍只是我觉得常用的部分,Apple在DocC方面有详细的教程,DocC的作用也远不止这些,感兴趣的同学可以移步Apple Developer

https://developer.apple.com/cn/videos/play/wwdc2021/10166

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/pingmian/90540.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/90540.shtml
英文地址,请注明出处:http://en.pswp.cn/pingmian/90540.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深入理解C语言快速排序与自省排序(Introsort)

排序算法是计算机科学中最基础也是最重要的知识之一。快速排序(Quicksort)因其平均时间复杂度为 O(n log n) 而广受欢迎,但在最坏情况下会退化到 O(n)。为了克服这一缺点,自省排序(Introsort) 应运而生&…

C#编程基础:运算符与结构详解

目录 一.关系运算符 常见关系运算符 二.逻辑运算符 常见逻辑运算符 1. 逻辑与(&& 或 and) 2. 逻辑或(|| 或 or) 3. 逻辑非(! 或 not) 运算符优先级 三.if语句 1.c#程序的三大结构 1.顺序…

嵌入式学习-土堆目标检测(3)-day27

再学一个labelme在labelstudio环境中再pip install labelme安装好后直接输入 labelme之后点击保存,选择保存文件地址还有一个就是将labelme的格式转化为yolo格式还是在labelstudio这个环境里面安装pip install labelme2yolo

Qt OpenGL 集成:开发 3D 图形应用

Qt 提供了完善的 OpenGL 集成方案,使开发者能够在 Qt 应用中高效开发 3D 图形应用。通过 Qt 的 OpenGL 模块,可简化 OpenGL 上下文管理、窗口渲染和跨平台适配,同时结合现代 OpenGL 特性(如着色器、顶点缓冲、纹理等)实…

【NLP舆情分析】基于python微博舆情分析可视化系统(flask+pandas+echarts) 视频教程 - 热词评论查询功能实现

大家好,我是java1234_小锋老师,最近写了一套【NLP舆情分析】基于python微博舆情分析可视化系统(flaskpandasecharts)视频教程,持续更新中,计划月底更新完,感谢支持。今天讲解热词评论查询功能实现 视频在线地址&#…

使用 Google Earth 的 DEM — 教程。

数字高程模型 (DEM)描绘了已知高程点之间的表面高程。本教程将向您展示如何使用 Google Earth 的高程数据生成 DEM。在当今世界,DEM 主要用于 GIS 应用。 当然,我们可以从美国地质调查局 (USGS) 网站下载数字高程模型 (DEM)。但如果我们想知道某个地点的…

在 UniApp 中实现中间凸起 TabBar 的完整指南

如何在 UniApp 中设置中间 TabBar 凸起效果 在移动应用开发中,TabBar 是常见的导航组件,而中间凸起的 TabBar 按钮则是一种流行的设计风格,常用于突出重要功能(如发布、拍照等)。UniApp 提供了 midButton 属性&#xf…

微观低代码

今日去深圳的一家工厂给客户做培训,主要培训内容为低代码产品的二开和功能演示。客户使用了20年的ERP和OA系统,目前想对接到低代码平台。客户目前想实现的主要功能是,对接OA的单点登录,把ERP的功能迁移到低代码平台上来工厂规模比…

Linux进程控制:掌握系统的核心脉络

Linux进程控制:掌握系统的核心脉络 在 Linux 系统中,进程控制是系统运行的核心机制之一。无论是日常的命令行操作,还是复杂的后台服务运行,都离不开对进程的管理和控制。本文将深入探讨 Linux 进程控制的相关知识,帮助…

4N90-ASEMI电机控制专用4N90

编辑:LL4N90-ASEMI电机控制专用4N90型号:4N90品牌:ASEMI封装:ITO-220ABRDS(on):3.60Ω批号:最新引脚数量:3封装尺寸:如图特性:N沟道MOS管工作结温:-55℃~150℃一、卓越性…

Java 笔记 lambda

✅Lambda 基本语法 (parameters) -> expression 或 (parameters) -> { statements }// 无参数 Runnable r () -> System.out.println("Hello");// 单个参数&#xff08;小括号可省略&#xff09; Consumer<String> c s -> System.out.println(s…

安全风险监测平台:被动应对向主动预防的转变

一、智能识别预警系统安全风险监测平台通过部署多维度感知网络&#xff0c;实现对各类安全隐患的智能识别与实时预警。系统采用深度学习算法&#xff0c;对人员行为、设备状态、环境参数等进行全天候监测分析&#xff0c;建立动态风险评估模型。当检测到异常情况时&#xff0c;…

图片查重从设计到实现(2)Milvus安装准备etcd介绍、应用场景及Docker安装配置

etcd作用、应用场景及Docker安装配置 在分布式向量数据库 Milvus 的架构中&#xff0c;etcd 扮演着至关重要的角色。Milvus 用于存储和管理海量向量数据&#xff0c;支持高效的相似性搜索等操作&#xff0c;而其分布式集群的正常运行高度依赖元数据的一致性和可靠性&#xff0c…

零弹窗干扰的贪吃蛇游戏,下载即玩

软件介绍 在寻找贪吃蛇游戏的过程中&#xff0c;我发现了一款PC端版本&#xff0c;无需登录即可直接使用&#xff0c;完全符合我的需求。 使用优势 这款软件最大的亮点在于完全免费&#xff0c;没有任何广告和弹窗干扰&#xff0c;支持完全离线运行&#xff0c;让用户能够专注…

excel2013VBA开发access mdb数据库系统的一点经验分享

最近&#xff0c;自己从网盘里重新下载了过去保存的vba开发资料&#xff0c;就顺手研究起了如何能通过excel203结合access 2013 mdb数据库系统开发个VBA小系统。过简单一说说了&#xff01;接说干货经验分享吧&#xff0c;1、俺先在mdb数据库中建了一个有自动编号字段的数据表&…

我们能否承担微服务带来的复杂性和运维成本?

坦率地说&#xff0c;并非所有团队都应该&#xff0c;承担微服务带来的复杂性和运维成本。在做出决定前&#xff0c;我们必须进行自我评估。 以下是评估是否能承担微服务成本需要考虑的关键方面&#xff1a; 一、 复杂性带来的挑战 (Complexity Challenges):分布式系统固有复杂…

HCIP--MGRE实验

一、实验拓扑二、配置思路1、建立拓扑&#xff0c;配置IP&#xff0c;配置缺省路由是公网通畅2、路由器R1-R5,R2-R5,R3-R5之间都是串线链接&#xff0c;由于华为路由器默认的串线协议为PPP&#xff0c;因此根据实验要求&#xff0c;R1-R5,R2-R5之间直接进行单向认证&#xff0c…

数字孪生映射探索驱动的具身导航!MorphoNavi:面向对象映射的空地机器人导航

作者&#xff1a; Sausar Karaf, Mikhail Martynov, Oleg Sautenkov, Zhanibek Darush, Dzmitry Tsetserukou单位&#xff1a;俄罗斯斯科尔科沃科学技术研究院智能空间机器人实验室论文标题&#xff1a;MorphoNavi: Aerial-Ground Robot Navigation with Object Oriented Mappi…

统计与大数据分析与数学金融课程解析

CDA数据分析师证书含金量高&#xff0c;适应了未来数字化经济和AI发展趋势&#xff0c;难度不高&#xff0c;行业认可度高&#xff0c;对于找工作很有帮助。一、课程体系对比矩阵维度统计与大数据分析数学金融交叉领域数学基础概率论(90%)随机过程(85%)线性代数(100%)核心工具P…

整蛊小程序:关机程序(C语言)

整蛊小程序&#xff1a;关机程序&#xff08;C语言) 跟着潼心走&#xff0c;轻松拿捏C语言&#xff0c;困惑通通走&#xff0c;一去不回头~欢迎开始今天的学习内容&#xff0c;你的支持就是博主最大的动力。 目录 整蛊小程序&#xff1a;关机程序&#xff08;C语言) 程序内容…