一个小例子介绍Obj-C的函数命名方式

移动开发 iOS
代码永远会有BUG,在这方面没有最好只有更好。高效是程序员必须作到的事情,无错是程序员一生的追求。复用、分而治之、折衷是代码哲学的基本思想。模块化与面向对象是实现高效无错代码的方法。高效无错代码需要思想与实践的不断反复。本文介绍了一个小例子,阐述Objective-C的函数命名方式。

对于以前做C#或者JAVA开发的朋友而言,初次接触iOS开发,Obj-C的函数命名方式可能会感觉非常不习惯。

尤其是打开AppDelegate.m,映入眼帘的代码竟然是:

  1. - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions 
  2.     // Override point for customization after application launch. 
  3.     return YES; 

不知道会不会有朋友和我当初同样的感觉——天啊,这也太长了!!!

其实,在Obj-C中,上面这个函数的函数名应该是:

  1. - (BOOL)application:didFinishLaunchingWithOptions: 

括号后面跟随的application和launchOptions是在函数内使用的参数。

我们可以将这个函数解读为“应用程序:完成启动使用选项:”。

其中“应用程序”冒号后面的参数顾名思义就是应用程序自身。

而“完成启动使用选项”冒号后面的参数顾名思义就是启动的选项。

这里我用了两个“顾名思义”,对就是顾名思义!在Obj-C的函数命名的方式有点类似于自然语言,相信大家会像我一样,随着对iOS开发的逐渐深入,会越来越适应甚至喜欢这种命名方式的。

下面再举一个例子,如果我们在java中定义一个加法的函数,大概会用如下方式:

  1. /** 
  2.  * 计算a+b的结果 
  3.  * @param a 
  4.  * @param b 
  5.  * @return 返回a+b的和 
  6.  */ 
  7. public int add(int a, int b) { 
  8.     return a + b; 

在java中定义函数时,通常我们会习惯编写一个简单的注释,如此一来我们可以在程序的其他位置,利用eclipse的智能提示看到这些参数分别代表什么意思,还可以使用Javadoc工具生成程序文档。这是非常方便而且有意义的!

而在Obj-C中我们会如何做呢?首先定义一个函数,代码如下:

  1. - (NSInteger)addA:(NSInteger)a withB:(NSInteger)b { 
  2.     return a + b; 

而在调用该函数时,Xcode的提示会大概如下所示:

  1. [self addA:(NSInteger) withB:(NSInteger)]; 

此时,我们可以把这句话解读成“加A和B”,有没有觉得更容易理解一些啊?应该会的,呵呵。

在Obj-C中,如果养成良好的函数命名习惯。相信随着时间的推移,你会发现,需要写的注释会越来越少。尽管在Xcode中没有类似于 eclipse的智能提示,但是这并不会妨碍我们一目了然地看明白每个函数都是做什么的,以及它们都需要什么参数,乃至各个参数都分别应该是什么类型的。

一起来享受快乐的iOS开发之旅吧~~~

责任编辑:闫佳明 来源: cnblogs
点赞
收藏

51CTO技术栈公众号