Objective-C编码风格规范

基本规则

  • 所有的花括号都放到下一行. 
  • 不使用TAB, 使用空格. 
  • 二元操作符之间需要有空格, 一元操作符之间没有空格. 

类声明

  • 示例代码:
    @interface WBUser : NSObject
  • {
  •     NSNumber *userID;                   // 用户UID.
  •     NSString *screenName;               // 微博昵称.
  •     NSString *name;                     // 友好显示名称, 如Bill Gates, 名称中间的空格正常显示(此特性暂不支持).
  •     NSString *desc;                     // 个人描述.
  •     Gender gender;                      // 性别, m--男, f--女, n--未知.
  •     int onlineStatus;                   // 在线状态.
  •     NSString *remark;                   // 备注信息, 在查询用户关系时提供此字段.
  • }
  • WBUser : NSObject之间需要有空格. 
  • NSNumber *userID;NSNumber*之间有空格, *userID之间没有空格, userID;之间也没有空格. 
  • 注释为了保持美观, 应统一缩进到一个位置上. 

属性

  • 示例代码:
    @property (nonatomic, retain) NSNumber *userID;
  • @property (nonatomic, retain) NSString *screenName;
  • @property (nonatomic, retain) NSString *name;
  • @property (nonatomic, retain) NSString *desc;
  • @property (nonatomic, assign) Gender gender;
  • @property (nonatomic, assign) int onlineStatus;
  • @property (nonatomic, retain) NSString *remark;
  • @synthesize userID;
  • @synthesize screenName;
  • @synthesize name;
  • @synthesize desc;
  • @synthesize gender;
  • @synthesize onlineStatus;
  • @synthesize remark;
  • @property (nonatomic, retain) NSNumber *userID;@property(之间有空格, nonatomic,retain之间有空格, )NSNumber之间有空格. 
  • @synthesize userID;@synthesizeuserID;之间有空格. 

方法声明

  • 示例代码:
    + (NSMutableArray *)objectsWithArray:(NSArray *)array;
  • + (id)objectWithDictionary:(NSDictionary *)dict;
  • - (id)initWithDictionary:(NSDictionary *)dict;
  • - (BOOL)updateWithDictionary:(NSDictionary *)dict;
  • +-与返回类型之间需要加空格. 
  • 返回类型或参数中的的类名与*之间需要加空格. 
  • :与参数之间不加空格. 

方法实现

  • 示例代码:
    + (NSMutableArray *)objectsWithArray:(NSArray *)array
  • {
  • }
  • - (void)imagePickerController:(UIImagePickerController *)picker 
  •         didFinishPickingImage:(UIImage *)img 
  •                   editingInfo:(NSDictionary *)editInfo
  • {
  • }
  • 写法与方法声明相同. 
  • 括号需要在下一行. 
  • 当方法名超过限定的80字符时, 需要将每个参数分行, 每个参数一行, 以:对齐. 

If语句

  • 示例代码:
    if ([genderString isEqualToString:@"m"])
  • {
  •     self.gender = kGenderMale;
  • }
  • else if ([genderString isEqualToString:@"f"])
  • {
  •     self.gender = kGenderFemale;
  • }
  • else ifelse单独在一行. 
  • ifelse if后面接空格, 再写小括号里的条件. 

循环语句

  • 示例代码:
    for (NSDictionary *dict in array)
  • {
  • }
  • for (int i = 0; i < 10; i++)
  • {
  • }
  • while (YES)
  • {
  • }
  • 注意空格的位置. 

switch语句

  • 示例代码:
    switch (self.responseDataType)
  • {
  •     case kWeiboResponseDataTypeStatuses:
  •         return [WBDataProcessor processStatuses:decodedObject];
  •         break;
  •     case kWeiboResponseDataTypeUser:
  •         return [WBDataProcessor processUser:decodedObject];
  •         break;
  •     default:
  •         break;
  • }
  • 每个case需要缩进. 
  • 必须要写default:
  • case中是否加花括号取决于是否有必要加, 如无必要可不加, 也可以加. 

使用pragma mark分割代码

  • 示例代码:
    #pragma mark - Properties
  • - (BOOL)hasReplyComment
  • {
  •     if (replyComment != nil)
  •     {
  •         return YES;
  •     }
  •     return NO;
  • }
  • #pragma mark - Equality Comparison
  • - (id)primaryKey
  • {
  •     return commentID;
  • }
  • #pragma mark - Memory Management
  • - (void)dealloc
  • {
  •     [super dealloc];
  • }
  • #pragma mark中使用英文, 每个单词首字母大写. 
  • #pragma mark是用于分离一类方法, 如某个delegate的全部方法等. 

释放变量时需置成nil

  • 示例代码:
    - (void)dealloc
  • {
  •     [loginUsername release], loginUsername = nil;
  •     [loginPassword release], loginPassword = nil;
  •     [oauthTokenKey release], oauthTokenKey = nil;
  •     [oauthTokenSecret release], oauthTokenSecret = nil;
  •     [gsid release], gsid = nil;
  •     [super dealloc];
  • }
  • dealloc中须将变量release后设置为nil
  • release与设置成nil在同一行, 并以逗号分隔. 
  • 不要忘记调用[super dealloc]

注释

  • 在开发过程中注释是为自己能看明白. 
  • 开发结束后需要将一些与外部接口的方法, 类等进行Doxygen风格注释, 以便生成文档.  
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 、4下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合;、下载 4使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合;、 4下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.m或d论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 、1资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值