swift,自定义协议.doc

  1. 1、本文档共25页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
swift,自定义协议 篇一:Swift 小技巧 -- 自定义调试信息打印 Swift 小技巧 -- 自定义调试信息打印 什么是调试信息打印 一般在调试项目的时候我们需要往控制台打印一些信息, 以便来查看相应的代码执行情况, 在 OC 中默认是使用 NSLog 打印, Swift 中默认使用 print打印. (C语言中使用的是printf, 和 Swift 很像). 为什么要自定义调试信息的打印? 这个是因为, 如果我们使用默认的打印方式, 那么无论你是在Debug的开发阶段, 还是在Release的发布阶段, 打印信息会一直打印, 这在 APP 上架时是不允许的. 而 我们自定义太拼信息打印的目的, 就是要达到调试时打印, 发布时就不再打印. 如何自定义调试打印 OC 中的方法就不赘述了, 之前已经写过. Swift 有些不同, 因为OC 中的自定 Log, 一般是定义在.pch 的宏定义文件中, 但是 Swift 中已经没有宏定义文件了. 那么就不能自定义了吗? 其实不是的, 因为 Swift 只要在一个文件中声明了一个公开的方法, 其他文件都是可以访问到的. 所以, 你可以把自定义 Log 的方法放到任何一个文件中, 但为了方便管理和使用, 我建议还是可以把这一类公共使用的方法放到一个统一的文件中. 下面是我用的自定义方法: importUIKit funcXFLoglt;T(message : T, file : String = __FILE__, lineNumber : Int = __LINE__) { #ifDEBUG let fileName = (file asNSString).lastPathComponent print([\(fileName):line:\(lineNumber)]- \(message)) #endif } 使用方式: XFLog(message) 括号内可以直接放变量名. 也可以直接打印整形数. 如果需要打印一个没有定义的字符串, 需要加 . 例如想打印一句 我是测试语句, 需要写成 XFLog(我是测试语句) 使用注意 应该有看到我在里面加了个 #if DEBUG #endif 意思是先判断是调试模式还是 release 发布模式. 但这样写之后并不能使用的, 也就是不会执行打印, 还需要在项目配置中修改一下设置, 如下图 第3步那里是展开, 第4步在 Debug 后面点击加号, 第5步在出现的方框里填入 -D DEBUG. -D 后面是一个标识, 用来区分是什么模式, 你也可以叫其他名字, 但我觉得叫 DEBUG 比较通俗易懂. 这个标识是和上面我自定义调试打印信息里的判断相对应的. 这个时候再运行就能看到打印结果了 [ViewController.swift:line:21]- 我是测试语句 结果显示出测试语句所在的文件名, 所在文件中的行数, 以及你要打印的信息. 补充 ? XFLog 就是方法明, 这里你也可以叫其他名字, 我是用惯了 OC 的 log, 所以自定义的名字和 OC 中常用的一样. ? lt;T 这个是和后面的message : T 对应的. 是用来接收你要打印的内容. 当然, 你也可以在打印信息里加上方法名之类的, 无非就是再加个参数. 但个人觉得没必要了, 已经知道打印信息所在的文件和行号, 就够了. 篇二:Swift的核心是面向协议 不要用子类 Swift的核心是面向协议 Swift的核心 我们可以通过等式的传递性来理解swift: Swift的核心是面向协议的编程。 面向协议的编程的核心是抽象(abstraction)和简化(simplicity)。 所以swift的核心就是抽象和简化。 你可能对我的标题感到诧异。我并不是说子类没有价值,尤其在使用单一继承(single inheritance)的情况下,类和子类当然是强有力的工具。然而我想说的是,iOS日常开发的问题是对类和继承的过度使用。作为面向对象的编程者(object-oriented programmer,后面统一替换为OOP编程者;object-oriented programming后面统一简写为OOP)我们总是会自然的倾向于使用引用类型和类去解决问题,但是我个人还是认为应该反过来,倾向于用值类型代替引用类型。我们还是要去写模块化的,可伸缩的并且可重用的代码,这一点不会变。swift中强大的值类型就可以帮我们实现此目的,且不需要对引用类型有过强的依赖。我认为不仅面向协议的编程(protocol oriented programming,后统一替换为POP)可以帮我们实现这点,另外2种编程类型也可以,且都具有抽象和

您可能关注的文档

文档评论(0)

精品文档 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档