微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

objective-c – 我不应该只定义#define NSFM [NSFileManager defaultManager]而不是每次都写出来吗?

一个内置的快捷方式NSApp,有什么理由我不应该为NSFileManager添加一个

#define NSFM [NSFileManager defaultManager]

我认为省略这将使我的代码更清洁,我看不到保持它的任何好处.(我计划从现在开始在我的所有项目中执行此操作,因此它不会模糊不清.)

NSFileManager *fm = [NSFileManager defaultManager]

解决方法

你为什么不只使用局部变量?

NSFileManager *fm = [NSFileManager defaultManager];
// use fm...

或者更好的是,将文件管理器注入方法参数:

- (void)myMethod {
  //using [NSFileManager defaultManager]
}

- (void)myMethodWithFileManager:(NSFileManager*)fm {
 //usin fm
}

由于defaultManager是一个单例(实际上是全局的),因此它使测试变得非常困难.注入依赖项可以节省您在方法中键入(如您所愿)并使单元测试更容易 – 您可以注入测试double而不是defaultManager.

最后,Cocoa和Objective-C通常倾向于使用简短代码支持显式代码.哲学基本上是使用更详细的名称使代码更容易阅读(从而维护).这种理念一直延伸到Objective-C的选择器样式,并带有交错的命名参数.除非您真的无法处理额外的输入(并且Xcode的代码完成对您不起作用),否则请坚持使用现有名称.在罗马的时候……

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐