Effective系列-01

Effective系列-01

1. import 与向前声明(forward declaring)

1.import

当我们创建一个类时,系统会在这个类的头文件中自动替我们import需要的框架

//Person.h
#import 
//或者当创建视图、控制器相关的类时
//#import 

这是在头文件中必不可少的import,当我们认为每一个Person都需要一个Job时,则需要给我们创建的Person类添加一个实例对象

@property (nonatomic,strong) Job *job;

此时,若没有对Job类进行import,则Xcode会报错,因为无法识别Job类型的变量,为了解决上述情况,我们可以在Person的头文件中添加代码

#import "Job.h"

尽管这样可以解决上述情况,但不够优雅。当我们在.h文件中声明时,我们并不需要知道Job的全部信息,只需要知道有这个类即可。同时,这个适合声明的话,若使用者引入了Person.h文件,则也会引入Job.h文件,倘若所有的类都如此编写则会导致引入一些用不到的内容,从而增加编译时间。

2.向前声明(forward declaring)

为了解决上面使用import的问题,可以使用向前声明(forward declaring)。

@class Job;

当我们向前声明了Job后,相当于告知Xcode在处理Person.h文件时,Job是一个类。当我们在.m文件中需要使用到Job的详细信息时,再在.m文件中import。
但是当Person类需要遵循Alive协议(protocal)时,若使用向前声明则会警告

@protocol Alive;
@interface Person : NSObject //Cannot find protocol definition for 'Alive'

所以,当我们需要遵循某个协议时使用import是无法避免的,但是为了减少耦合,我们可以创建一个单独OC文件(.h)用来定义协议。
但是,当我们使用代理(delegate)时,可以不需要像上述一样声明。在与之相关的类的.m文件中声明即可,例如给Person类添加一个Delegate,我们在Person.m文件中这样写

//Person.m
#import "Person.h"

@protocol PersonDelegate 

- (void) walkingOnTheStreet;

@end

@interface Person()

@property (weak,nonatomic) id  delegate;

@end

@implementation Person

@end

而这也是apple推荐的写法,其UITableViewDelegate、UICollectionViewDelegate等都是采用这种写法。

2.多使用字面量语法

所谓字面量语法就是在创建对象时,不调用方法创建对象。例如

    NSNumber *number1=@1;
    NSNumber *[email protected];
    NSNumber *[email protected];

使用字面量语法可以简洁明了地创建对象,同时通过在整数、浮点数前加@符号可以便携地将其转换为NSNumber类型(NSString也可通过在字符串前加@创建),供我们使用。倘若我们调用方法时,上述代码需要写成如下所示,十分繁琐效果却与上述一样。

    NSNumber *number1=[NSNumber numberWithInt:1];
    NSNumber *number2=[NSNumber numberWithFloat:2.2];
    NSNumber *number3=[NSNumber numberWithFloat:1.3];

除此之外,还有NSArray、NSDictionary等。下面为NSArray的两种创建方法

    NSArray *array1=[NSArray arrayWithObjects:object1,object2,object3,nil];
    NSArray *array2=@[object1,object2,object3];

创建array1时,由于arrayWithObjects方法的特殊性,在创建时object为nil则停止,因此倘若object2为nil的话,array1中则只有object1。而使用字面量语法创建的array2,若在@[]中的object有一个为nil则会报错。此外,使用objectAtIndex方法获取数组中的值时也可以直接使用下标替代。
对于NSDictionary,使用dictionaryWithObjectsAndKeys:方法时,value在key的前面,不够清晰。相比之下使用字面量语法key与value则十分清晰。

    NSDictionary *dic1=[NSDictionary dictionaryWithObjectsAndKeys:@"value",@"key",@123,@"number",nil];
    NSDictionary *dic2=@{
        @"key":@"value",
        @"number":@123
    };

因为之前春招找到了工作,最近毕业论文也基本完成,因此学习了一下Effective Objective-C 2.0,增强一下自己写OC代码的能力,来为工作做一下准备。本系列肯定都是由书中相关的知识点实践后总结而来,更多的是作为笔记的形式。

你可能感兴趣的:(Effective系列-01)