第20月第29天 cocoa抽象工厂 cocoapods组件化 cocoapods升级

时间:2023-05-17 08:48:38

1.

在 Cocoa Touch 框架中,类簇是抽象工厂模式在 iOS 下的一种实现,以 NSArray 举例,将原有的 alloc+init 拆开写:

id obj1 = [NSArray alloc]; // __NSPlacehodlerArray *
id obj2 = [NSMutableArray alloc]; // __NSPlacehodlerArray *
id obj3 = [obj1 init]; // __NSArrayI *
id obj4 = [obj2 init]; // __NSArrayM *

发现 + alloc 后并非生成了我们期望的类实例,而是一个NSPlacehodlerArray 的中间对象,后面的 – init 或 – initWithXXXXX 消息都是发送给这个中间对象,再由它做工厂,生成真的对象。这里的 NSArrayI 和 __NSArrayM 分别对应 Immutable 和 Mutable(后面的 I 和 M 的意思)

于是顺着思路猜实现,__NSPlacehodlerArray 必定用某种方式存储了它是由谁 alloc 出来的这个信息,才能在 init 的时候知道要创建的是可变数组还是不可变数组。

抽象工厂将一系列的产品族统一到一起创建,增加产品族很方便,但增加产品很麻烦,需要改动太多的类的接口。 ####生成器(Builder) 将一个复杂对象的构建与它的表现分离,使得同样的构建过程可以创建不同的表现。 生成器可以将构建对象的过程分为,客户 – 指导者 – 生成器 的关系,

CharacterBuilder *characterBuilder = [[StandarCharacterBuilder alloc] init];
ChasingGame *game = [[ChasingGame alloc] init]; Character *player = [chasingGame createPlayer:characterBuilder];
Character *enemy = [chasingGame createEnemy:characterBuilder];

characterBuilder 就是生成器了,而 game 就是指导者。指导者里声明了创建不同表现的对象的方法。而方法里由生成器 characterBuilder 来构建不同的 Character 类型的对象。

  • 生成器模式将复杂的生成对象的过程交给了生成器去完成,作为客户的我们只需要根据简单的接口去生成不同表现的对象。如上述代码中的 player 以及 enemy。玩家和敌人具体的属性数值我们不需要去设置,而是交给生成器去设置。

https://github.com/al1020119/iCocosDesignPattern

http://ios.jobbole.com/85360/

https://draveness.me/2017-summary

2.git pod私有库

索引库

508  cd ~/.cocoapods/repos/

509  ls

510  history

511  ls

512  pod repo add MyRepo https://gitee.com/lianhuaren/MyRepo.git

代码库

502  cd Desktop/mycode/

503  ls

504  mkdir QinzTool

505  cd QinzTool/

506  pod lib create QinzTool

507  pwd

508  ls

上传模板文件

509  cd QinzTool/

510  ls

511  git remote add origin https://gitee.com/lianhuaren/Tool.git

512  git push -u origin master

513  git pull

514  git push -u origin master

515  git pull

516  git branch --set-upstream-to=origin/master master

518  git pull

519  git pull

521  git pull origin master --allow-unrelated-histories

522  git push -u origin master

523  git push -u origin master -f

524  history

将组件的代码上传

526  git add .

527  git commit -m "first"

528  git push -u origin master

529  pwd

530  pod lib lint --private

531  git tag 0.1.0

532  git push --tags

533  pod repo push MyRepo QinzTool.podspec

source 'https://github.com/CocoaPods/Specs.git'
source 'https://gitee.com/lianhuaren/MyRepo' platform :ios, '8.0' target 'pods01' do
use_frameworks! pod 'QinzTool', '~> 0.1.0'
pod 'AFNetworking' #公有库 end

https://blog.csdn.net/m0_37402140/article/details/72801372

https://blog.csdn.net/shiren1118/article/details/7761203

https://www.jianshu.com/p/c1a215b9ddbe

more:

1)

没用sourcetree,不会git remote add, 导致失败

也并不是在~/.cocoapods/repos/HCocaPodsSpecsManager调用pod lib create HStarTools

如果在~/.cocoapods/repos/HCocaPodsSpecsManager调用命令,这样HCocaPodsSpecsManager有.git,HStarTools又有.git

最后导致调用pod repo push HCocaPodsSpecsManager HStarTools.podspec出错。

The repo `HCocaPodsSpecsManager` at `..` is not clean

https://www.jianshu.com/p/67a1d8385c80

2)

如果不用pod lib create QinzTool,开始出现问题。

- ERROR | [iOS] file patterns: The `source_files` pattern did not match any file.

https://www.jianshu.com/p/0c640821b36f

3)

下面我们把 pod push 到远端:

git push --set-upstream origin master

下一步,我们创建一个私有的 Spec 仓库,这里面存放的是我们需要的 Pod 的索引,我在 Coding 上创建了一个 MySpec 仓库,我们先把它加到 CocoaPods 当中:

pod repo add MySpec git@git.coding.net:skyline75489/MySpec.git

这里面现在还是空的,下面我们把 XXBaseHeaders push 到仓库中,相当于发布出去:

pod repo push MySpec XXBaseHeaders.podspec --allow-warnings

https://skyline75489.github.io/post/2016-3-19_ios_modularization_practice.html

3.

sudo gem install cocoapods

https://gems.ruby-china.com/

https://blog.csdn.net/potato512/article/details/62235282