iOS开发设计模式那点事Word文档下载推荐.docx
- 文档编号:20455825
- 上传时间:2023-01-23
- 格式:DOCX
- 页数:4
- 大小:19.82KB
iOS开发设计模式那点事Word文档下载推荐.docx
《iOS开发设计模式那点事Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《iOS开发设计模式那点事Word文档下载推荐.docx(4页珍藏版)》请在冰豆网上搜索。
+(StudentDAO*)sharedStudentDAO;
-(int)create:
(Student*)student;
-(int)remove:
-(int)modify:
-(NSMutaleArray)findAll;
@end.m文件:
//StudentDAO.m#import&
quot;
StudentDAO.h&
#import&
Student.h&
@implementationStudentDAOstaticStudentDAO*student;
student2.name=&
Ricardo_LI&
;
student2.studentNum=&
201200301102&
studentDao=[[selfalloc]init];
studentDao._StudentsInfo=[[NSMutaleArrayalloc]init];
[studentDao._StudentsInfoaddObject:
student1];
student2];
});
returnstudentDao;
}//插入的方法-(int)create:
(Student*)stu{[self._StudentsInfoaddObject:
stu];
return0;
}//删除的方法-(int)remove:
(Student*)stu{for(Student*sinself._StudentsInfo){if([stu.studentNumisEqual:
s.studentNum]){[self._StudentsInforemoveObject:
s]break;
}}}-(int)modify......//省略不写-(NSMutaleArray)findAll......//省略不写上述例子不难理解,其中用到的Student类我这里就不给出了,只是一个含有姓名和学号属性的实体类。
观察者模式概念:
一个对象状态改变,通知正在对他进行观察的对象,这些对象根据各自要求做出相应的改变图例:
如图所示:
操作对象向被观察者对象投送消息,使得被观察者的状态得以改变,在此之前已经有观察者向被观察对象注册,订阅它的广播,现在被观察对象将自己状态发生改变的消息广播出来,观察者接收到消息各自做出应变。
OK,我们先来看看在苹果的CocoaTouch框架中有谁使用了观察者模式:
通知(notification)机制原理图如下:
如图所示,在通知机制中对某个通知感兴趣的所有对象都可以成为接受者。
首先,这些对象需要向通知中心(NSNotificationCenter)发出addObserver:
selector:
name:
object:
消息进行注册,在投送对象投送通知送给通知中心时,通知中心就会把通知广播给注册过的接受者。
所有的接受者不知道通知是谁投送的,不去关心它的细节。
投送对象和接受者是一对多的关系。
接受者如果对通知不再关注,会给通知中心发送removeObserver:
Object:
消息解除注册,以后不再接受通知。
(ps:
这段话内容摘抄自关东升先生的文章)OK,我们试着去使用一下通知机制:
新建一个SingleviewProject,对项目中的文件做以下修改:
AppDelegate.m-(void)applicationDidEnterBackground:
(UIApplication*)application{[[NSNotificationCenterdefaultCenter]postNotificationName:
@&
APPTerminate&
self];
}ViewController.m////ViewController.m//TestNotification////Createdbyliwenqianon14-10-18.//Copyright(c)2014年liwenqian.Allrightsreserved.//#import&
ViewController.h&
@interfaceViewController()@end@implementationViewController-(void)viewDidLoad{[superviewDidLoad];
//注意此处的selector有参数,要加冒号[[NSNotificationCenterdefaultCenter]addObserver:
selfselector:
@selector(doSomething:
)name:
nil];
//Doanyadditionalsetupafterloadingtheview,typicallyfromanib.}-(void)didReceiveMemoryWarning{[superdidReceiveMemoryWarning];
[[NSNotificationCenterdefaultCenter]removeObserver:
//Disposeofanyresourcesthatcanberecreated.}#pragmamark-处理通知-(void)doSomething:
(NSNotification*)notification{NSLog(@&
收到通知&
);
}@end如上所示,对模版项目的两个文件的方法或整个文件做出修改,Command+R运行你的APP,再按下Home键(Command+H),会发现打印出一行收到通知的文字,如下:
在APP退到后台时,发出广播,而viewController因为时观察者,收到广播,执行doSomething方法,打印出收到广播的文字。
KVO(Key-Value-Observing)机制原理图如下:
该机制下观察者的注册是在被观察者的内部进行的,不同于通知机制(由观察者自己注册),需要被观察者和观察者同时实现一个协议:
NSKeyValueObserving,被观察者通过addObserver:
forKeypath:
options:
context方法注册观察者,以及要被观察的属性。
新建一个singleviewproject,同时新建一个继承自NSObject的TestWatche类:
文件结构如下图:
对文件进行如下修改:
AppDelegate.h////AppDelegate.h//TestNotification////Createdbyliwenqianon14-10-18.//Copyright(c)2014年liwenqian.Allrightsreserved.//#import&
lt;
UIKit/UIKit.h&
gt;
CoreData/CoreData.h&
TestWatche.h&
@interfaceAppDelegate:
UIResponder&
UIApplicationDelegate&
@property(strong,nonatomic)UIWindow*window;
@property(readonly,strong,nonatomic)NSManagedObjectContext*managedObjectContext;
@property(readonly,strong,nonatomic)NSManagedObjectModel*managedObjectModel;
@property(readonly,strong,nonatomic)NSPersistentStoreCoordinator*persistentStoreCoordinator;
@property(strong,nonatomic)NSString*state;
@property(strong,nonatomic)TestWatche*watcher;
-(void)saveContext;
-(NSURL*)applicationDocumentsDirectory;
@endAppDelegate.m对如下方法做出修改-(BOOL)application:
(UIApplication*)applicationdidFinishLaunchingWithOptions:
(NSDictionary*)launchOptions{//Overridepointforcustomizationafterapplicationlaunch.self.watcher=[TestWatchealloc];
[selfaddObserver:
self.watcherforKeyPath:
state&
NSKeyValueObservingOptionOld|NSKeyValueObservingOptionNewcontext:
passcontent&
];
self.state=@&
launch&
returnYES;
}-(void)applicationDidEnterBackground:
(UIApplication*)application{self.state=@&
backgroud&
}TestWatche.m(由于继承自NSObject,而NSObject已实现了NSKeyValueObserving协议,所以不需要做声明)////TestWatche.m//TestNotification////Createdbyliwenqianon14-10-18.//Copyright(c)2014年liwenqian.Allrightsreserved.//#import&
@implementationTestWatche-(void)observeValueForKeyPath:
(NSString*)keyPathofObject:
(id)objectchange:
(NSDictionary*)changecontext:
(void*)context{NSLog(@&
statechange:
%@&
change);
}@endOK,Command+BCommand+RCommand+H看看你的应用输出了什么,如果你的操作无误的话,会显示如下内容:
委托模式个人认为委托模式大多数人解释的复杂了,其实就像是java中的接口,类可以实现或不实现协议(接口)中的方法。
通过此种方式,达到最大的解耦目的,方便项目的扩展。
不过你需要设置应用的委托对象,以确定协议中的方法为谁服务。
拿最常用的UITableViewDelegateUITableViewDataSource来举例:
实现一个页面有一个UItableView,UItableView的每一栏(cell)的数据由我们指定,那么我们该如何做呢?
苹果也自然想到了这一点,于是定义了一个接口,这个接口有许多的方法,只需要我们把要服务的对象传进去,就可以使用这些方法了,这个接口就是委托和协议。
而UITableViewDelegate和UITableViewDataSource就是专为UITableView而写的委托和协议。
用法如下:
ViewController.h////ViewController.h//RecipeBookMe////Createdbyliwenqianon14-9-10.//Copyright(c)2014年liwenqian.Allrightsreserved.//#import&
@interfaceViewController:
UIViewController&
UITableViewDelegate,UITableViewDataSource&
@property(nonatomic,strong)IBOutletUITableView*mytableView;
@endViewController.m////ViewController.m//RecipeBookMe////Createdbyliwenqianon14-9-10.//Copyright(c)2014年liwenqian.Allrightsreserved.//#import&
DetailViewController.h&
Recipe.h&
RecipeTableCellTableViewCell.h&
@interfaceViewController()@end@implementationViewController{NSArray*recipes;
}@synthesizemytableView;
-(void)viewDidLoad{[superviewDidLoad];
//InitializetherecipesarrayRecipe*recipe1=[Recipenew];
recipe1.name=@&
EggBenedict&
recipe1.prepTime=@&
30min&
recipe1.image=@&
egg_benedict.jpg&
recipe1.ingredients=[NSArrayarrayWithObjects:
2freshEnglishmuffins&
@&
4eggs&
4rashersofbackbacon&
2eggyolks&
1tbspoflemonjuice&
125gofbutter&
saltandpepper&
nil];
Recipe*recipe2=[Recipenew];
recipe2.name=@&
MushroomRisotto&
recipe2.prepTime=@&
recipe2.image=@&
mushroom_risotto.jpg&
recipe2.ingredients=[NSArrayarrayWithObjects:
1tbspdriedporcinimushrooms&
2tbspoliveoil&
1onion,chopped&
2garliccloves&
350g/12ozarboriorice&
1.2litres/2pintshotvegetablestock&
25g/1ozbutter&
recipes=[NSArrayarrayWithObjects:
recipe1,recipe2,nil];
}-(void)didReceiveMemoryWarning{[superdidReceiveMemoryWarning];
}/*--------------------------------------------------------------------*///定义UITableview的栏目数量-(NSInteger)tableView:
(UITableView*)tableViewnumberOfRowsInSection:
(NSInteger)section{return[recipescount];
}//定义UITableviewCell的显示内容-(UITableViewCell*)tableView:
(UITableView*)tableViewcellForRowAtIndexPath:
(NSIndexPath*)indexPath{staticNSString*CoustomerTableIdentifier=@&
RecipeTableCellTableViewCell&
RecipeTableCellTableViewCell*cell=(RecipeTableCellTableViewCell*)[tableViewdequeueReusableCellWithIdentifier:
CoustomerTableIdentifier];
if(cell==nil){cell=[[RecipeTableCellTableViewCellalloc]initWithStyle:
UITableViewCellStyleDefaultreuseIdentifier:
}recipe=[recipesobjectAtIndex:
indexPath.row];
cell.nameLabel.text=recipe.name;
cell.prepTimeLabel.text=recipe.prepTime;
cell.thumbnailImageView.image=[UIImageimageNamed:
recipe.image];
returncell;
}//点击每一栏执行跳转时的处理-(void)prepareForSegue:
(UIStoryboardSegue*)seguesender:
(id)sender{if([segue.identifierisEqualToString:
showRecipeDetail&
]){NSIndexPath*indexPath=nil;
Recipe*recipe=nil;
indexPath=[self.mytableViewindexPathForSelectedRow];
recipe=[recipesobjectAtIndex:
DetailViewController*destViewController=segue.destinationViewController;
destViewController.recipe=[recipesobjectAtIndex:
}}//定义cell的高度-(CGFloat)tableView:
(UITableView*)tableViewheightForRowAtIndexPath:
(NSIndexPath*)indexPath{return71;
}/*--------------------------------------------------------------------*/@end如上所示,两条/------/注释间的方法全部来自于委托和协议。
利用委托和协议,你可以把主要精力放到逻辑业务上,将数据绑定和事件处理交给委托和协议去完成。
<
ahref="
http:
/
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- iOS 开发 设计 模式