黑马程序员——Objective-c特性

1. 继承 

Objective-c不支持多继承。 Super 关键字:调用该类的父类; 超类:父类的另一种说法。

2.自定义NSLog()输出: 
在类中添加description方法就可以自定义NSLog()如何输出对象。

#import <Foundation/Foundation.h>

@implementation Tire -(NSString *) description


   Return (@”I am a tire.”);

}

int Main()


    NSLog(@”%@”,tire[0]);

return 0;


       
3.Foundation kit: 
Cocoa是由两部分框架组成的:foundation kit [包括一些基础类]和 application kit.【包括用户接口对象和高级类】

创建字符串:

NSString *test; 
test=[NSString stringWithFormat:@"i'm %d years old!",23]; 
若在声明方法时在方法前面添加了加号,那就表示把这个方法定义为类方法【这个方法属于类对象,而不是类的实例对象。】 
NSArray类:可以存放任意类型的对象. 它有两个限制: 
1. 它只能存储objective-c的对象,但不能存储C中的基本数据类型,如int , float, enum, struct等。

2.不能存储nil(对象的零值或NULL值);【因为在创建NSArray时,要在列表结尾添加nil代表列表结束。】

创建NSArray:

NSArray *array; 
array=[NSArray arrayWithObjects:@"one",@"two",nil];

NSString, NSMutableString类; 
【NSString是不可变的,即一旦创建完成,就不能通过删除字符或添加字符的方式来改变它; 而NSMutableString是可变的。 
这两个类就像JAVA中的string与stringBuffer类的区别。】 NSArray, NSMutableArray类; NSEnumerator枚举;

NSEnumerator *emun; 
Emun=[array objectEnumerator]; Id thingie; 
While(thingie=[enumerator nextObject]){} 】 
NSDictionary:字典(关键字及其定义的集合。)【也成为散列表,关联数组】,NSMutableDictionary类; 
NSNumber:用来包装基本数据类型,如int ,char, float, bool;【将一个基本类型的数据包装成对象叫做装箱。】 
NSValue:它可以包装任何类,NSNumber是它的子类。 NSNull: 
 在cocoa中看到“CF”字样时,就表示它是苹果公司的Core Foundation 框架相关的内容。  NSAutoreleasePool:自动释放内存池。   
         
4.内存管理 
每个对象都有一个与之关联的引用计数(也叫保留计数) 
当使用alloc, new 方法或通过 copy消息(生成接收对象的一个副本)创建一个对象时,对象的引用计数值被设为1; 
 给对象发retain消息时,增加该值;  发送release消息时,减少该值; 
当一个对象的引用计数值变为0时,objective-c会自动向对象发送一条dealloc消息。销毁该对象。

你可以在自己的对象中重写该方法, 
使用retainCount消息,可以获取引用计数器的值。 -(id) retain; -(void) release; 
-(unsigned) retainCount;

自动释放池:autorelease pool; 创建: 
NSAutoreleasePool *pool; 
pool=[[NSAutoreleasePool alloc] init];

销毁: 
[pool release]; 
注意:xcode自动生成的代码,销毁pool池时,使用的是[pool drain],drain方法只是清空释放池,但不销毁pool.所以在自己编写代码时还是使用release. 
而且,drain只适用于MAC OS 10.4以上的版本,而release适用于所有版本。 
只有在向某个对象发送autorelease消息时,该对象才会添加到NSAutoreleasepool中,才会被自动释放。 
如:[car autorelease];

内存管理黄金准则:  
只有通过alloc, new和 copy方法创建的对象,才需要程序员负责向该对象发送release或autorelease消息。 
而通过其他方法获得的对象,则默认为已经被设置为自动释放,所以不需要程序员做任何操作了。 在objective-c 2.0中有垃圾回收机制, 如果要对某个项目使用垃圾回收: 
项目信息--build选项卡--查询"garb",出现“objective-c Garbage Collection”,将其值设置为“required[-fobjc-gc-only]” 
启用垃圾回收后,通常的内存管理命令全都变成了空操作指令,不执行任何操作。 开发iphone软件,不能使用垃圾回收。   
          
5.对象初始化 
两种创建新对象的方法: [类名 new] 、[[类名 alloc] init] 
这两种方法是等价的,但cocoa的惯例是使用后者。 alloc在为对象分配空间的同时,将这块内存初始化为0;

nit方法:初始化实例变量,使对象处于可用状态。[返回类型为id,  返回的值描述了被初始化的对象]

使用new创建新对象时,系统要完成两个步骤: 
1. 为对象分配内存,即对象获得一个用来存放其实例变量的内存块;

2.自动调用init方法,让该对象处于可用状态。     
      
6.objective-c 2.0的新特性【只适用于mac os x10.5及以上】 
@property :表示声明了对象的属性。【这样就不用再写属性的访问器了。】 (他有copy, retain, readwrite, readonly等属性)

@synthesize:表示“创建该属性的访问器” 点表达式     
      
7.类别(分类) 
分类(category)是一种为现有的类添加新方法的方式。

分类的声明: 
@interface NSString (NumberConvenience) //类名 (分类名)

-(NSNumber) lengthAsNumber;          //扩充方法声明

@end 
使用时使用原来的类名,就可以调用他的所有类别中的方法。

分类的局限性: 
1.不能向类中添加新的实例变量; 
2.在类别中的方法若与类中现有的方法重名,则类中的方法不可用,被类别中的新方法取代。

分类的作用: 
1.将类的实现分散到多个文件或框架中;

2. 创建对私有方法的前向引用; 
【Cocoa中没有真正的私有方法,则实现私有方法类似功能的方法为: 先在分类中声明方法;然后到现有类的实现中实现该方法。 
这样这个类中的其他方法可以使用该方法,而其他外部的类就不会知道该方法的存在了。】

3.向对象添加非正式协议。 
【创建一个NSObject的类别称为创建一个非正式协议。】

委托delegate是一种对象,另一个类的对象会要求委托对象执行它的某些操作。 受委托对象在某个时间(某个事件触发)时,会自动通知委托对象执行委托方法。

选择器:@selector():选择器只是一个方法名称,但它以objective-c运行时使用的特殊方式编码,以快速执行查询。圆括号中的内容是方法名。 
所以Car类的setEngine:方法的选择器是:@selector(setEngine: 
受委托对象如何知道其委托对象是否能处理它(受委托对象)发送给它(委托对象)的消息? 通过选择器,受委托对象先检查委托对象,询问其是否能响应该选择器。如果能,则向它发送消息。  
8.      
协议: 
正式协议是一个命名的方法列表。 
采用协议意味着必须实现该协议的所有方法。否则,编译器会发出警告。

声明协议: 
@protocal NSCopying 
-(id) copywithzone:(NSZone *) zone;

//方法列表

@end

采用协议: 
@interface Car:NSObject <NSCopying,NSCoding> //中括号中是要实现的协议列表

{

//实例变量列表

}

//方法列表

@end 
在objective-c 2.0中,有新特性:@optional, @required 
     
9.AppKit: 
创建APPKIT项目: 
File—new project—mac os—application—Cocoa application; IBOutlet与IBAction 
这两个都是APPKIT提供的#defines. IBOutlet没有任何作用,不会对它进行编译。 IBAction定义为void。 
这两个是为Interface Builder以及阅读代码的人提供的标记。

.xib文件一般称为.nib文件。 
.nib文件是包含被冻结对象的二进制文件。 而.xib文件是XML格式的nib文件。

http://www.itheima.com/

上一篇:git pull error


下一篇:java面试题系列12