首页
/ libextobjc 技术文档

libextobjc 技术文档

2024-12-24 23:25:05作者:齐添朝

1. 安装指南

1.1 添加到应用程序项目

要将 libextobjc 作为依赖项添加到应用程序项目中,请按照以下步骤操作:

  1. libextobjc 仓库作为子模块添加到您的项目中:
    git submodule add https://github.com/jspahrsummers/libextobjc.git
    
  2. 在 Xcode 项目中包含您需要的源文件。

1.2 添加到框架或库项目

如果您希望将 libextobjc 作为依赖项添加到框架或库项目中,建议使用子树合并(subtree merging):

  1. 添加远程仓库:
    git remote add libextobjc https://github.com/jspahrsummers/libextobjc.git
    
  2. 获取远程仓库:
    git fetch libextobjc
    
  3. 创建子树:
    git read-tree --prefix=External/ -u libextobjc/master
    git reset
    
  4. 重命名符号或根据需要进行更改,然后将要包含的文件添加到您的库中。

1.3 更新子树

要更新子树以包含上游更改,请执行以下操作:

  1. 获取最新的远程更改:
    git fetch -p libextobjc
    
  2. 合并更改:
    git merge -Xsubtree=External/ libextobjc/master
    git reset
    
  3. 添加您需要的更改。

2. 项目的使用说明

libextobjc 是一个扩展 Objective-C 编程语言动态性的库,支持其他编程语言中的额外模式(包括那些不一定是面向对象的)。该库非常模块化,大多数类和模块都可以在没有多个依赖项的情况下使用。

2.1 主要功能

  • 安全类别:使用 EXTSafeCategory 添加方法到类中,而不会覆盖任何已存在的方法。
  • 具体协议:使用 EXTConcreteProtocol 为协议中的方法提供默认实现。
  • 简单且安全的键路径:使用 EXTKeyPathCoding 在编译时自动检查键路径。
  • 编译时检查选择器:使用 EXTSelectorChecking 确保对象声明了给定的选择器。
  • 块中弱变量的更易用:使用 @weakify@unsafeify@strongify 简化块中弱变量的使用。
  • 基于作用域的资源清理:使用 @onExit 在作用域结束时自动清理手动分配的内存、文件句柄、锁等。
  • 代数数据类型:使用 EXTADT 在编译时生成完全的代数数据类型。
  • 类别属性合成:使用 EXTSynthesize 为类别合成属性。
  • 基于块的协程:使用 EXTCoroutine 实现基于块的协程。
  • EXTNil:类似于 NSNull,但行为更接近实际的 nil

2.2 实验性功能

实验性分支包含一些可能有趣但尚未被认为是稳定或适合生产使用的功能。请查看头文件以获取更多信息。

3. 项目API使用文档

3.1 EXTSafeCategory

EXTSafeCategory 允许您安全地向类中添加方法,而不会覆盖任何已存在的方法。它会自动检测冲突。

3.2 EXTConcreteProtocol

EXTConcreteProtocol 为协议中的方法提供默认实现,使得实现协议的类可以选择性地覆盖这些方法。

3.3 EXTKeyPathCoding

EXTKeyPathCoding 在编译时自动检查键路径,确保键路径的有效性。

3.4 EXTSelectorChecking

EXTSelectorChecking 在编译时检查选择器,确保对象声明了给定的选择器。

3.5 EXTScope

EXTScope 模块提供了 @weakify@unsafeify@strongify@onExit 等宏,用于简化块中弱变量的使用和作用域结束时的资源清理。

3.6 EXTADT

EXTADT 在编译时生成代数数据类型,支持复杂的模式匹配。

3.7 EXTSynthesize

EXTSynthesize 为类别合成属性,使得类别可以拥有自己的属性。

3.8 EXTCoroutine

EXTCoroutine 实现基于块的协程,允许您以同步的方式编写异步代码。

3.9 EXTNil

EXTNil 类似于 NSNull,但行为更接近实际的 nil,不会在发送未识别消息时崩溃。

4. 项目安装方式

4.1 使用子模块

对于应用程序项目,建议使用子模块方式将 libextobjc 添加到项目中。

4.2 使用子树合并

对于框架或库项目,建议使用子树合并方式将 libextobjc 添加到项目中,以便重命名符号并进行必要的调整。

4.3 更新依赖

通过获取远程更改并合并到本地子树中,可以轻松更新 libextobjc 依赖。


通过以上文档,您应该能够顺利安装和使用 libextobjc 库,并了解其主要功能和 API 的使用方法。

登录后查看全文
热门项目推荐
相关项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
27
11
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
470
3.48 K
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
10
1
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
65
19
flutter_flutterflutter_flutter
暂无简介
Dart
718
172
giteagitea
喝着茶写代码!最易用的自托管一站式代码托管平台,包含Git托管,代码审查,团队协作,软件包和CI/CD。
Go
23
0
kernelkernel
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
209
84
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.27 K
695
rainbondrainbond
无需学习 Kubernetes 的容器平台,在 Kubernetes 上构建、部署、组装和管理应用,无需 K8s 专业知识,全流程图形化管理
Go
15
1
apintoapinto
基于golang开发的网关。具有各种插件,可以自行扩展,即插即用。此外,它可以快速帮助企业管理API服务,提高API服务的稳定性和安全性。
Go
22
1