XCode中的的一些便捷用法

我也不知道该怎么总结这些内容,就用这个名字吧,我以为挺有用的。 转自: http://blog.csdn.net/genios/article/details/7821133 感谢博主的整理 @synthesize by default(属性自动绑定)在xcode4.4之前,当咱们想为类添加一个新的属性,通常都要对应写实例变量和相应的synthesis,可是在Xcode 4.4以后,synthesis如今会对应property自动生成。默认行为下,对于属性foo,当开发者没有写相应的synthesis的时候,编译器会自动在实现文件中为开发者补全synthesis,就好像你写了@synthesis foo = _foo。  

总结一下,新的属性绑定规则以下:ios

●  除非开发者在实现文件中提供getter或setter,不然将自动生成数组

● 除非开发者同时提供getter和setter,不然将自动生成实例变量xcode

●  只要写了synthesis,不管有没有跟实例变量名,都将生成实例变量.net

           ●  如开发者写了@synthesize foo;那么实例变量名就是foocode

●  dynamic优先级高于synthesisorm

           ● 对于写了@dynamic的实现,全部的对应的synthesis都将不生效blog

@literals(简写)ip

在xcode4.4之前ci

NSNumberelement

全部的[NSNumber numberWith…:]方法均可以简写了:

●  [NSNumber numberWithChar:‘X’]简写为 @‘X’;

●  [NSNumber numberWithInt:12345] 简写为 @12345

●  [NSNumber numberWithUnsignedLong:12345ul] 简写为 @12345ul

● [NSNumber numberWithLongLong:12345ll] 简写为 @12345ll

●  [NSNumber numberWithFloat:123.45f] 简写为 @123.45f

●  [NSNumber numberWithDouble:123.45] 简写为 @123.45

●  [NSNumber numberWithBool:YES] 简写为 @YES

NSDictionary

●  [NSDictionary dictionary] 简写为 @{}

●  [NSDictionary dictionaryWithObject:o1forKey:k1] 简写为 @{ k1 : o1 }

●  [NSDictionarydictionaryWithObjectsAndKeys:o1, k1, o2, k2, o3, k3, nil] 简写为 @{ k1 : o1, k2 : o2, k3 : o3 }

当写下@{ k1 : o1, k2 : o2, k3 : o3 }时,实际的代码会是

// compiler generates:

id objects[] = { o1, o2, o3 };

id keys[] = { k1, k2, k3 };

NSUInteger count = sizeof(objects) / sizeof(id);

dict = [NSDictionary dictionaryWithObjects:objects forKeys:keyscount:count];

NSArray

部分NSArray方法获得了简化:

● [NSArray array] 简写为 @[]

●  [NSArray arrayWithObject:a] 简写为 @[ a ]

●  [NSArray arrayWithObjects:a, b, c, nil] 简写为 @[ a, b, c ]

好比对于@[ a, b, c ],实际编译时的代码是

// compiler generates:

id objects[] = { a, b, c };

NSUInteger count = sizeof(objects)/ sizeof(id);

array = [NSArray arrayWithObjects:objectscount:count];

Mutable版本和静态版本 上面所生成的版本都是不可变的,想获得可变版本的话,能够对其发送-mutableCopy消息以生成一份可变的拷贝。好比

NSMutableArray *mutablePlanets = [@[ @"Mercury", @"Venus", @"Earth", @"Mars", @"Jupiter", @"Saturn", @"Uranus", @"Neptune" ] mutableCopy];

 

另外,对于标记为static的数组,不能使用简写为其赋值(其实原来的传统写法也不行)。

若是直接赋值就会提示出错

@implementation MyClass   static NSArray *  thePlanets = @[                                            error:array literals not constant @"Mercury", @"Venus", @"Earth", @"Mars", @"Jupiter", @"Saturn", @"Uranus", @"Neptune" ];  

解决方法是在类方法+ (void)initialize中对static进行赋值。

@implementation MyClass   static NSArray *thePlanets; + (void)initialize{ if (self == [MyClass class]) { thePlanets = @[ @"Mercury", @"Venus", @"Earth", @"Mars", @"Jupiter", @"Saturn", @"Uranus", @"Neptune" ]; } }  

下标

Array

    Song *oldSong = [_songs objectAtIndex:idx]; [_songs replaceObjectAtIndex:idx withObject:newSong]; 能够简写为   Song *oldSong = _songs[idx]; _songs[idx] = newSong;   Dictionary   id oldObject = [_storage objectForKey:key]; [_storage setObject:newobject forKey:key]; 能够简写为   id oldObject = _storage[key]; _storage[key] = newObject;   并且你不单单能使用它所提供的下标访问。你也能够对自定义的类使用下标访问。   对于咱们自定义的类,只须要实现一下的方法就能使用下标访问。   Array - (elementType)objectAtIndexedSubscript:(indexType)idx; - (void)setObject:(elementType)object atIndexedSubscript:(indexType)idx; Dictionary - (elementType)objectForKeyedSubscript:(keyType)key; - (void)setObject:(elementType)object forKeyedSubscript:(keyType)key;     Segues xcode 4.5的storyboard提供了更方便的segue方法。 当你要实现按cell中的箭头实现segue时。以往都要用代码来实现。xcode4.5中提供了直接在storyboard中连接的方法       Unwind Segues   有了Unwind segues,你能够很容易就实现segue到你制定的一个View上。   你要在制定目标的controller中实现如下两个方法。   -(BOOL)canPerformUnwindSegueAction:(SEL)action fromViewController:(UIViewController *)fromViewController withSender:(id)sender { return YES; } (默认YES)   - (IBAction)done:(UIStoryboardSegue *)segue { // React to the impending segue // Pull state back, etc. }     CollectionView   下面这幅图就是用Collection Views实现的一个照片墙显示。 相似于瀑布流的展现方法。     为何要使用Collection Views呢?         ■         能够高度定制内容的展示       ■         管理数据最佳的作法     ■ 即便是处理大量数据,也很是的高效   对于CollectionView主要要实现的方法有三个   UICollectionViewDataSource ●section的数量 -numberOfSectionsInCollection: ●某个section里有多少个item -collectionView:numberOfItemsInSection: ●对于某个位置应该显示什么样的cell -collectionView:cellForItemAtIndexPath:   embed segue 在以往的xcode中,若是咱们想要添加一个子视图,咱们须要用代码实现。   UIViewController *child = [[self storyboard] instantiateViewControllerWithIdentifier:@"ContentScene"]; [self addChildViewController:child]; [[self view] addSubview:[child view]]; [[child view] setFrame:frame]; 如今在storyboard多了container view这个控件,可让你不用代码实现添加一个子视图。 你能够在 - (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender 中实现参数的传递。 方法顺序 若是有如下代码: @interface SongPlayer : NSObject - (void)playSong:(Song *)song; @end @implementation SongPlayer - (void)playSong:(Song *)song { NSError *error; [self startAudio:&error]; ... } - (void)startAudio:(NSError **)error { ... } @end 在早一些的编译环境中,上面的代码会在[self startAudio:&error]处出现一个实例方法未找到的警告。因为编译顺序,编译器没法得知在-playSong:方法以后还有一个-startAudio:,所以给出警告。 在新编译器里,若是在同一实现文件中,不管方法写在哪里,编译器均可以在对方法实现进行编译前知道全部方法的名称,从而避免了警告。   枚举改进   从Xcode4.4开始,有更好的枚举的写法了:   typedef enum NSNumberFormatterStyle : NSUInteger { NSNumberFormatterNoStyle, NSNumberFormatterDecimalStyle, NSNumberFormatterCurrencyStyle, NSNumberFormatterPercentStyle, NSNumberFormatterScientificStyle, NSNumberFormatterSpellOutStyle } NSNumberFormatterStyle;
相关文章
相关标签/搜索