• iOS开发常用的第三方框架


    1. AFNetworking

    在众多iOS开源项目中,AFNetworking可以称得上是最受开发者欢迎的库项目。AFNetworking是一个轻量级的iOS、Mac OS X网络通信类库,现在是GitHub上第三大Objective-C库。它建立在NSURLConnection、NSOperation等类库的基础 上,让很多网络通信功能的实现变得十分简单,因此,许多iOS应用开发都会使用到它。

    使用功能:

    • 支持HTTP请求和基于REST的网络服务(包括GET、POST、PUT、DELETE等);
    • 支持ARC;
    • 要求iOS 5.0及以上版本;
    • 有一些插件扩展已有的功能,还有一个功能齐全的API;
    • 从URL中获取JSON特别简单。
    1>实现原理
    AFN的直接操作对象AFHTTPClient不同于ASI,是一个实现了NSCoding和NSCopying协议的NSObject子类。 AFHTTPClient是一个封装了一系列操作方法的“工具类”,处理请求的操作类是一系列单独的,基于NSOperation封装 的,AFURLConnectionOperation的子类。AFN的示例代码中通过一个静态方法,使用dispatch_once()的方式创建 AFHTTPClient的共享实例,这也是官方建议的使用方法。在创建AFHTTPClient的初始化方法中,创建了OperationQueue并 设置一系列参数默认值。在getPath:parameters:success:failure方法中创建NSURLRequest,以 NSURLRequest对象实例作为参数,创建一个NSOperation,并加入在初始化发方中创建的NSOperationQueue。以上操作都 是在主线程中完成的。在NSOperation的start方法中,以此前创建的NSURLRequest对象为参数创建NSURLConnection 并开启连结。
     
    2> 传递指针 如何使一个方法返回多个返回值
     

    详情请参考:AFNetworking官网

    2.GPUImage

    GPUImage是一个基于GPU图像和视频处理的开源iOS框架。

    主要功能如下:

    • 提供各种各样的图像处理滤镜,并且支持照相机和摄像机的实时滤镜;
    • GPUImage顾名思义,是基于GPU的图像加速,因此图像处理速度非常快,并且能够自定义图像滤镜;
    • 支持ARC。

    详情请参考:GPUImage官网

    3.SVProgressHUD

    作用:

    1>实现多种HUD效果。多用于程序正在执行耗时较长命令,需要用户等待。

    2>除了显示等待的HUD,还可以显示命令执行成功或者失败的HUD。

    3>SVProgressHUD和MBProgressHUD效果差不多,不过不需要使用协议,同时也不需要声明实例。

    直接通过类方法进行调用即可

    4>SVProgressHUD 使用起来很方便,但可定制差一些,看它的接口貌似只能添加一个全屏的HUD,不能把它添加到某个视图上面去.

    示例代码:

     1 #import "SVProgressHUD.h"
     2 
     3 //登录按钮的点击事件
     4 -(void)login {
     5     [SVProgressHUD showWithStatus:@"正在登陆..." maskType:SVProgressHUDMaskTypeBlack];
     6     dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
     7         
     8         //第三方框架
     9         [SVProgressHUD dismiss];
    10         //判断用户名和密码
    11         if ([self.userTextField.text  isEqualToString:@"1"] && [self.passwordTextField.text isEqualToString:@"1"]) {
    12             //密码正确,跳转
    13             [self performSegueWithIdentifier:@"login2contact" sender:nil];
    14         }
    15         else {
    16             //密码错误
    17             [SVProgressHUD showErrorWithStatus:@"密码错误..."];
    18         }
    19     });
    20 }

    详情见SVProgressHUD官网

    4.SDWebImage:

    1> SDWebimage的缓存机制
      1. UIImageView+WebCache: setImageWithURL:placeholderImage:options: 先显示 placeholderImage ,同时由SDWebImageManager 根据 URL 来在本地查找图片。
      2. SDWebImageManager: downloadWithURL:delegate:options:userInfo: SDWebImageManager是将UIImageView+WebCache同SDImageCache链接起来的类, SDImageCache: queryDiskCacheForKey:delegate:userInfo:用来从缓存根据CacheKey查找图片是否已经在缓存中
      3. 如果内存中已经有图片缓存, SDWebImageManager会回调SDImageCacheDelegate : imageCache:didFindImage:forKey:userInfo:
      4. 而 UIImageView+WebCache 则回调SDWebImageManagerDelegate:  webImageManager:didFinishWithImage:来显示图片。
      5. 如果内存中没有图片缓存,那么生成 NSInvocationOperation 添加到队列,从硬盘查找图片是否已被下载缓存。
      6. 根据 URLKey 在硬盘缓存目录下尝试读取图片文件。这一步是在 NSOperation 进行的操作,所以回主线程进行结果回调 
        notifyDelegate:
      7. 如果上一操作从硬盘读取到了图片,将图片添加到内存缓存中(如果空闲内存过小,会先清空内存缓存)。SDImageCacheDelegate 回调 imageCache:didFindImage:forKey:userInfo:进而回调展示图片。
      8. 如果从硬盘缓存目录读取不到图片,说明所有缓存都不存在该图片,需要下载图片,回调 
        imageCache:didNotFindImageForKey:userInfo:
      9. 共享或重新生成一个下载器 SDWebImageDownloader 开始下载图片。
      10. 图片下载由 NSURLConnection 来做,实现相关 delegate 来判断图片下载中、下载完成和下载失败。
      11. connection:didReceiveData: 中利用 ImageIO 做了按图片下载进度加载效果。
      12. connectionDidFinishLoading: 数据下载完成后交给 SDWebImageDecoder 做图片解码处理。
      13. 图片解码处理在一个 NSOperationQueue 完成,不会拖慢主线程 UI。如果有需要对下载的图片进行二次处理,最好也在这里完成,效率会好很多。
      14. 在主线程 notifyDelegateOnMainThreadWithInfo: 宣告解码完成,imageDecoder:didFinishDecodingImage:userInfo: 回调给 SDWebImageDownloader。
      15. imageDownloader:didFinishWithImage: 回调给 SDWebImageManager 告知图片下载完成。
      16. 通知所有的 downloadDelegates 下载完成,回调给需要的地方展示图片。
      17. 将图片保存到 SDImageCache 中,内存缓存和硬盘缓存同时保存。
      18. 写文件到硬盘在单独 NSInvocationOperation 中完成,避免拖慢主线程。
      19.  如果是在iOS上运行,SDImageCache 在初始化的时候会注册notification 到 UIApplicationDidReceiveMemoryWarningNotification 以及  UIApplicationWillTerminateNotification,在内存警告的时候清理内存图片缓存,应用结束的时候清理过期图片。
      20. SDWebImagePrefetcher 可以预先下载图片,方便后续使用。

    一、SDWebImage常见面试题

    1.问题: 1> 图片文件缓存的时间有多长
    答案: 一周

    2.SDWebImage的内存缓存是用什么实现的
    答案: NSCache

    3.SDWebImage的最大并发数是多少
    答案:6

    4.SBWebImage 支持动图嘛??
    答案:GIF

    5.SDWebImage是如何区别不同格式的图像
    答案:根据图像数据第一个字节来判断
    PNG: 压缩比没有JPG高,但是无损压缩,解压性能高,苹果推荐的图像格式
    CIF 序列帧动画,特点.只支持256中颜色,是最流行的时候载1998-1999 有专利的

    6 SDWebImage 缓存图片的名称是怎么确定的
    md5 在终端输入md5 -s 输入你的图片地址,即可寻找
    如果单纯使用 文件名保存, 重名几率高
    使用MD5的散列函数,对完整的URL进行MD5,结果是一个32个字符长度的字符串

    7. SBWebimage的内存警告是如何处理的
    利用通知中心观察

    二、主要用于网络异步下载图片框架

    SDWebImage库的作用: 

    通过对UIImageView的类别扩展来实现异步加载替换图片的工作。

    主要用到的对象:
    1>、UIImageView (WebCache)类别,入口封装,实现读取图片完成后的回调
    2>、SDWebImageManager,对图片进行管理的中转站,记录那些图片正在读取。
         向下层读取Cache(调用SDImageCache),或者向网络读取对象(调用SDWebImageDownloader) 。
         实现SDImageCache和SDWebImageDownloader的回调。
    3>、SDImageCache,根据URL的MD5摘要对图片进行存储和读取(实现存在内存中或者存在硬盘上两种实现)
         实现图片和内存清理工作。
    4>、SDWebImageDownloader,根据URL向网络读取数据(实现部分读取和全部读取后再通知回调两种方式)

    详情见SDWebImage官网

    5.GDataXML

    XML解析器

    这是一套Google开发的DOM方式XML解析类库,支持读取和修改XML文档,支持XPath方式查询。

    GDataXML 是 iOS 下的一款轻量级 XML 解析器,只包含两个文件

    GDataXMLNode.h GDataXMLNode.m

    使用方法:
         1>、获取GDataXMLNode.h/m文件,将GDataXMLNode.h/m文件添加到工程中
         2>、向工程中增加“libxml2.dylib”库
         3>、在工程的“Build Settings”页中找到“Header Search Path”项,添加/usr/include/libxml2"到路径中
         4>、添加“GDataXMLNode.h”文件到头文件中,如工程能编译通过,则说明GDataXMLNode添加成功
    详情见GDataXML官网或见GDataXML博客地址
     
    6.Security(网络安全框架)
    包含管理证书、公钥私钥以及信任策略的接口。请查看Security框架参考
    链接地址:Security(网络安全框架)
     
    7.SSKeychain(钥匙串访问框架)
    用于账号密码的存取
    SSKeyChains对苹果安全框架API进行了简单封装,支持对存储在钥匙串中密码、账户进行访问,包括读取、删除和设置。SSKeyChain的作者是大名鼎鼎的SSToolkit的作者samsoffes。
    项目地址:SSKeyChains
     
    8.Reachability(判断网络是否连接)
    判断设备网络连接情况。相对于苹果官方的Reachability,这是一个更加高级、更加好用的Reachability,支持ARC、支持block、使用GCD方式来通知网络的变化
    项目地址:Reachability
     
    9.SnapKit:
    SnapKit是能让开发者在iOS和OS X上更简单地进行Auto Layout的DSL。
    使用的代码示例:
    import SnapKit
    
    class MyViewController: UIViewController {
    
        lazy var box = UIView()
    
        override func viewDidLoad() {
            super.viewDidLoad()
    
            self.view.addSubview(box)
            box.snp_makeConstraints { (make) -> Void in
               make.width.height.equalTo(50)
               make.center.equalTo(self.view)
            }
        }
    
    }

    SnapKit是Masonry的Swift版,项目发布至今大约1年的时间,已经在github上有两千多个star

    项目下载地址:SnapKit
     
    10.Masonry
    Masonry是一个轻量级的布局框架 拥有自己的描述语法 采用更优雅的链式语法封装自动布局 简洁明了 并具有高可读性 而且同时支持 iOS 和 Max OS X。
     
  • 相关阅读:
    为什么使用内部类?怎样使用内部类? 2016年12月15号
    java内部类 2016年12月13号
    接口与抽象类的区别与联系 2016年12月13日
    多态的向上转型和向下转型 2016.12.8
    构造器的调用顺序 2016.12.8
    static final 和final的区别 2016.12.07
    根据进程号查询占用资源多的线程
    Intellij idea启动项目提示"ClassNotFoundException"
    IntelliJ IDEA setup JDK无效
    (转)面试合集
  • 原文地址:https://www.cnblogs.com/zhufengshibei/p/4985084.html
Copyright © 2020-2023  润新知