ios 结合项目谈谈设计模式

2024-06-07 11:18

本文主要是介绍ios 结合项目谈谈设计模式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ios 设计模式

在项目开发中常用的设计模式:MVC模式、代理模式、 单例模式、 KVO观察者模式和通知模式、类工厂模式等;
接下来将结合自己的项目谈谈对设计模式的理解以及应用
1.MVC 模式
即数据—视图—视图控制器(Model View Controller)
传统的MVC:Model View 是完全独立的,通过Controller进行连接。controller的作用就是桥梁作用,所有的View可以各自封装最终在controller中拼接。model 负责数据层,通过代理将数据传给controller ,然后controller 又把数据分发给View。 但这种纯粹的MVC在项目开发中并不常用,因为不便于维护,后开废弃掉了。
目前我们的项目开发也是使用接近MVC的模式:即controller可以独立调用获取数据层的接口,获取数据展示,然后展示View。一般我们设计时:所有的数据获取的类都会封装成单例MessageManger 之类的,但凡是要获取数据,接口都可以放在MessageManger的类中;在controller中获取数据,如果View 比较简单可以直接展示,如果View比较麻烦则需要自己写一个View 便于,降低代码的耦合度,提高代码的可重用性和可读性;
2.单例模式
上文刚刚谈到单例,所谓的单例就是该对象只初始化一次,以后直接调用,之后当程序结束后,该对象才会被释放。单例模式的好处就是可以创建一个整个程序都可以使用,随时都可以接受改变的全局变量;缺点是比较会消耗一定的内存。在项目中常见的用户的信息basicUserInfo 启动程序即获取用户的信息,整个程序都要用到,就可以考虑到使用单例。
3.代理模式
代理模式就是:通俗来讲就是找人代替自己做自己想做的事。

详情参见:i

os 界面三级回跳 ——代理回调 

现在在项目中经常会使用block回调代替delegate 方法 ,block更简单,delegate 明白易懂;

4.KVO与通知模式

KVO 一般是对某一数据进行观察,如果数据发生改变则执行操作

通知则是知道数据发生变化则通知监听的对象做相应的改变;

5.类工厂模式

类工厂模式是使用加方法创建一个对象,说白了就是一个创建模板。

以上的简介都是自己的愚见。如果有问题,敬请指正。谢谢!



这篇关于ios 结合项目谈谈设计模式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1039022

相关文章

用Microsoft.Extensions.Hosting 管理WPF项目.

首先引入必要的包: <ItemGroup><PackageReference Include="CommunityToolkit.Mvvm" Version="8.2.2" /><PackageReference Include="Microsoft.Extensions.Hosting" Version="8.0.0" /><PackageReference Include="Serilog

eclipse运行springboot项目,找不到主类

解决办法尝试了很多种,下载sts压缩包行不通。最后解决办法如图: help--->Eclipse Marketplace--->Popular--->找到Spring Tools 3---->Installed。

十五.各设计模式总结与对比

1.各设计模式总结与对比 1.1.课程目标 1、 简要分析GoF 23种设计模式和设计原则,做整体认知。 2、 剖析Spirng的编程思想,启发思维,为之后深入学习Spring做铺垫。 3、 了解各设计模式之间的关联,解决设计模式混淆的问题。 1.2.内容定位 1、 掌握设计模式的"道" ,而不只是"术" 2、 道可道非常道,滴水石穿非一日之功,做好长期修炼的准备。 3、 不要为了

iOS HTTPS证书不受信任解决办法

之前开发App的时候服务端使用的是自签名的证书,导致iOS开发过程中调用HTTPS接口时,证书不被信任 - (void)URLSession:(NSURLSession *)session didReceiveChallenge:(NSURLAuthenticationChallenge *)challenge completionHandler:(void (^)(NSURLSessionAu

vue项目集成CanvasEditor实现Word在线编辑器

CanvasEditor实现Word在线编辑器 官网文档:https://hufe.club/canvas-editor-docs/guide/schema.html 源码地址:https://github.com/Hufe921/canvas-editor 前提声明: 由于CanvasEditor目前不支持vue、react 等框架开箱即用版,所以需要我们去Git下载源码,拿到其中两个主

React+TS前台项目实战(十七)-- 全局常用组件Dropdown封装

文章目录 前言Dropdown组件1. 功能分析2. 代码+详细注释3. 使用方式4. 效果展示 总结 前言 今天这篇主要讲全局Dropdown组件封装,可根据UI设计师要求自定义修改。 Dropdown组件 1. 功能分析 (1)通过position属性,可以控制下拉选项的位置 (2)通过传入width属性, 可以自定义下拉选项的宽度 (3)通过传入classN

Toolbar+DrawerLayout使用详情结合网络各大神

最近也想搞下toolbar+drawerlayout的使用。结合网络上各大神的杰作,我把大部分的内容效果都完成了遍。现在记录下各个功能效果的实现以及一些细节注意点。 这图弹出两个菜单内容都是仿QQ界面的选项。左边一个是drawerlayout的弹窗。右边是toolbar的popup弹窗。 开始实现步骤详情: 1.创建toolbar布局跟drawerlayout布局 <?xml vers

移动硬盘盒:便携与交互的完美结合 PD 充电IC

在数字化时代的浪潮中,数据已成为我们生活中不可或缺的一部分。随着数据的不断增长,人们对于数据存储的需求也在不断增加。传统的存储设备如U盘、光盘等,虽然具有一定的便携性,但在容量和稳定性方面往往难以满足现代人的需求。而移动硬盘,以其大容量、高稳定性和可移动性,成为了数据存储的优选方案。然而,单纯的移动硬盘在携带和使用上仍存在诸多不便,于是,移动硬盘盒应运而生,以其独特的便携性和交互性,成为了数据存储

vue3项目将所有访问后端springboot的接口统一管理带跨域

vue3项目将所有访问后端springboot的接口统一管理带跨域 一、前言1.安装Axios2.创建Axios实例3.创建API服务文件4.在组件中使用API服务 二、跨域三、总结 一、前言 在Vue 3项目中,统一管理所有访问后端Spring Boot接口的最佳实践是创建一个专门的API服务层。这可以让你的代码更加模块化、可维护和集中管理。你可以使用Axios库作为HTT

vscode-创建vue3项目-修改暗黑主题-常见错误-element插件标签-用法涉及问题

文章目录 1.vscode创建运行编译vue3项目2.添加项目资源3.添加element-plus元素4.修改为暗黑主题4.1.在main.js主文件中引入暗黑样式4.2.添加自定义样式文件4.3.html页面html标签添加样式 5.常见错误5.1.未使用变量5.2.关闭typescript检查5.3.调试器支持5.4.允许未到达代码和未定义代码 6.element常用标签6.1.下拉列表