斯坦福iOS7公开课4-6笔记及演示Demo
1.变量类型别滥用id,如果不仔细容易在程序执行时引发错误,因为在编译阶段编译器只是检测变量对象所属类型,尤其是类型为id时代表任何类型都可以通过检查,但不会检测变量对象调用的方法,这样当对象所属类不包含所写的调用方法时,编译通过,但在程序运行时才会报错。

2.简单介绍了框架自带的集合、字体等。
3.通过使用NSAttributedString可以让屏幕显示的字体样式更丰富,设置各种样式等,详细参见附件的演示Demo:http://files.cnblogs.com/colinhou/Attributor.zip
4.对于苹果目前推荐的故事板Storyboard,介绍了其生命周期,并介绍了一些注意事项。
(1)viewDidLoad,这一过程中,故事板会做好初始化操作,我们设置的各种输出(IBOutlet)也已经初始化完毕,对于整个app需要且仅需要做一次初始化的操作,应该在这里执行,因为viewDidLoad在整个生命周期只在程序开始时执行一次。但是需要注意,此时view并没有显示在屏幕上,也就是view的大小等信息都还是不确定的,所以不适合做与设置改变view大小尺寸的操作。
(2)viewWillAppear,这一过程中,view的几何信息已经确定,准备好要显示了,如果还需要改变大小、动画等,也可以在这执行。同时一些初始化操作也应当在这里执行,例如每次切换回来要更新数据等等,比如使用微信,每次重新从其他地方切换过来的时候,顶部都会有一个圆圈在转,表示正在获取最新数据。
(3)viewWillDisappear,表示view马上要从屏幕消失,这时需要停止动画等操作,避免占用资源,同时如果也需要保存数据或状态,这样下次再切换回来的时候(viewWillAppear),方便继续之前的操作或状态。
(4)viewDidAppear、viewDidDisappear在view已经出现或消失时触发,
didReceiveMemoryWarning在系统内存不足时触发,
viewWill/DidLayoutSubviews用于屏幕旋转做相应设置,后续会详细介绍。
5.广播机制NSNotificationCenter,如果收听了某一事件,当满足一定条件时,可以做出响应,触发指定操作,有点类似于flex的消息机制,监听或取消监听某一消息。
addObserver表示收听对象、观察者,即谁监听这一事件,selector表示响应方法,name即广播名字,表示被收听的事件,object表示这是谁的广播、谁的事件,如果为nil则表示不管是谁,只要这一广播、事件发生了,都会收听到,并作出相应操作。


同时在停止收听广播的时候,一定要取消收听,这是因为NSNotificationCenter使用了不安全引用指针“unsafe retained pointer”,如果没有取消收听,当收听对象不存在了,通知NSNotificationCenter发送通知时就会引起程序崩溃,这里本来应该使用weak类型的指针,这样指针就能够自动变为nil,但是为了兼容iOS5(weak类型指针iOS6开始使用),目前还是使用的“unsafe retained pointer”。
另外,取消收听时建议使用指明具体信息的方式,避免造成无法使用其他广播。

6.介绍了使用UINavigationController管理多个View的方式,详细见附件的Demo:http://files.cnblogs.com/colinhou/Attributor.zip
另外,如果想跳过其它view,直接对特定View进行简单功能测试验证时,可以在Interface Builder中把起始箭头移至目标View,在代码中写好测试方法,启动调试后就能直接进入目标View验证功能了。

Demo效果截图:

斯坦福iOS7公开课4-6笔记及演示Demo的更多相关文章
- 斯坦福iOS7公开课1-3笔记及纸牌Demo
1.MVC Model:模型 描述程序是什么,例如数据库操作之类的行文以及纸牌Demo里纸牌玩法都是写在Model这一层,通过Notification和KVO(后续文章会介绍)两种方式与Control ...
- 斯坦福iOS7公开课11笔记及演示Demo&访问HTTPS链接下载数据
这一节主要介绍UITableView以及iPad,Demo为从Flicker下载图片并显示,但是实际过程中发现需要FQ并使用HTTPS连接,所以这次用了两个Demo,一个是课程中的Demo,另一个是简 ...
- 斯坦福iOS7公开课10笔记及演示Demo
这一节主要介绍了多线程中的串行队列以及滚动视图UIScrollView. 1 .多线程 这一节只是简单介绍了多线程的串行队列,即把任务加入线程队列后按顺序逐步执行. (1)目前iOS多线程提供的方法主 ...
- 斯坦福iOS7公开课7-9笔记及演示Demo
这一部分主要介绍了iOS的绘图.手势.协议.block.力学特效动画(包括重力.碰撞.吸附等)以及自动布局的内容. 1.绘图.手势 (1)调用一个自定义的UIView时,可以使用awakeFromNi ...
- 【我们都爱Paul Hegarty】斯坦福IOS8公开课个人笔记1 IOS8概述
首先感谢网易公开课和SwiftV课堂的朋友们辛苦翻译,这个系列是我学习斯坦福IOS8公开课的个人心得体会和笔记,希望能给大家带来启发. 首先我们要知道IOS系统中的结构情况,从贴近硬件的底层到贴近用户 ...
- 斯坦福ML公开课笔记15—隐含语义索引、神秘值分解、独立成分分析
斯坦福ML公开课笔记15 我们在上一篇笔记中讲到了PCA(主成分分析). PCA是一种直接的降维方法.通过求解特征值与特征向量,并选取特征值较大的一些特征向量来达到降维的效果. 本文继续PCA的话题, ...
- [置顶] 生成学习算法、高斯判别分析、朴素贝叶斯、Laplace平滑——斯坦福ML公开课笔记5
转载请注明:http://blog.csdn.net/xinzhangyanxiang/article/details/9285001 该系列笔记1-5pdf下载请猛击这里. 本篇博客为斯坦福ML公开 ...
- [置顶] NB多项式事件模型、神经网络、SVM之函数/几何间隔——斯坦福ML公开课笔记6
转载请注明:http://blog.csdn.net/xinzhangyanxiang/article/details/9722701 本篇笔记针对斯坦福ML公开课的第6个视频,主要内容包括朴素贝叶斯 ...
- 斯坦福大学公开课:iOS 7应用开发 笔记
2015-07-06 第一讲 课务.iOS概述 -------------------------------------------------- 开始学习斯坦福大学公开课:iOS 7应用开发留 ...
随机推荐
- CentOS 6.4 快速安装Nginx笔记
CentOS 6.4 快速安装Nginx笔记 本系列文章由ex_net(张建波)编写,转载请注明出处. http://blog.csdn.net/ex_net/article/details/9860 ...
- Go Go
Go Go *:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: 0 !important ...
- 数据可视化(5)--jqplot经典实例
本来想把实例也写到上篇博客里,最后发现太长了,拆成两篇博客了. 实例来源于官方文档:http://www.jqplot.com/tests/ 这篇博客主要是翻译了官方文档关于经典实例的解说,并在相应代 ...
- SQL Server里的自旋锁介绍
在上一篇文章里我讨论了SQL Server里的闩锁.在文章的最后我给你简单介绍了下自旋锁(Spinlock).基于那个基础,今天我会继续讨论SQL Server中的自旋锁,还有给你展示下如何对它们进行 ...
- IOS中对象的归档
ios提供了两个类 NSKeyedArichiver NSKeyedUnarchiver对自定义对象进行归档 和解档操作 归档常见方法 - (void)encodeObject:(id)objv fo ...
- Spring基础—— Bean 的作用域
一.在 Spring Config 文件中,在 <bean> 元素的 scope 属性里设置 Bean 的作用域.默认为 singleton ,单例的. 二.在不引入 spring-web ...
- Enterprise Library - Data Access Application Block 6.0.1304
Enterprise Library - Data Access Application Block 6.0.1304 企业库,数据访问应用程序块 6.0.1304 企业库的数据访问应用程序块的任务简 ...
- Linq专题之Lambda表达式
这一节我们讲的Lambda表达式跟匿名函数有关.Lambda表达式就是一个匿名函数,它可以包含表达式和语句,并且可以创建委托和表达式树. Lambda表达式的组成: 输入参数.Lambda运算符(=& ...
- MVC WebApi跨域ajax接受post数据笔记
后端api代码示例: [HttpPost] public string callbackUrl([FromBody]SZRCallBackModel cbm) { try { if (cbm == n ...
- sql联合查询去除重复计算总和
1.首先来个联合查询 SELECT 字段1, 字段2, 字段3, 字段4 FROM 表1 INNER JOIN 表2 ON 表1.字段x = 表2.字段x x:代表随意的一个,只要在联合查询的两张表都 ...