美文网首页iOS-Objective-C
OC基础教程(面向对象-2)

OC基础教程(面向对象-2)

作者: 追沐 | 来源:发表于2017-08-08 15:32 被阅读1次

    一、@interface部分

    @interface部分用于定义类的公共接口(API)。

    @interface Person : NSObject

    在创建一个对象的时候OC编译器需要一些关于该类的信息,尤其是对象的数据成员及其提供的功能。使用@interface指令把这些信息传递给编译器。

    在OC语言中只要只要看到@符号,就可以把它看成是对C语言的扩展,@interface Person就是告诉编译器:“这是类Person的接口”

    #import <Foundation/Foundation.h>
    
    @interface Person : NSObject
    
    @end
    

    @interface后面的NSObject告诉编译器,Person类是继承自NSObject类的,即Person类继承NSObject类定义的所有行为。

    实例变量

    @interface Person : NSObject后面的花括号{ }告诉编译器,括号里是我们为Person类定义的实例变量。

    #import <Foundation/Foundation.h>
    
    @interface Person : NSObject
    {
        NSString *_name;
    }
    
    @end
    

    如上定义了实例变量_name。

    这样定义实例变量(1)是局部的(2)不能用点语法调用。
    局部变量就不用说了,只能本类里面使用,因为不能使用点语法,在其他类也没法调用。
    为什么不能使用点语法呢?点语法的实质是调用的set或get方法,这样声明的实例变量是没有set和get方法的,所以不能用点语言,只能在类里面用_name。

    如果我们写了实例变量的set、get方法,则实例变量就能使用点语法了,那在类的外面也就能调用了,这时候这样申明+set、get方法就不是局部变量了,如下:

    Person.h

    #import <Foundation/Foundation.h>
    
    @interface Person : NSObject
    {
        NSString *_name;
    }
    
    - (void)setName:(NSString *)name;
    - (NSString *)name;
    
    @end
    

    Person.m

    #import "Person.h"
    
    @implementation Person
    
    - (void)setName:(NSString *)name {
        _name = name;
    }
    - (NSString *)name {
        return _name;
    }
    
    @end
    
    方法声明

    方法声明里有方法的名称、方法返回值、返回值类型和参数、参数类型等

    #import <Foundation/Foundation.h>
    
    @interface Person : NSObject
    
    - (void)run;
    
    @end
    
    • “-”短线表明这是OC方法的声明,这是区分函数原型与方法声明的一种方式,函数原型中没有先行短线,如下:
    void run(float kilometer){
        
        printf("%f",kilometer);
    }
    

    这个函数返回值是void,即无返回值,传入参数kilometer,然后打印。

    • OC中命名方法的名称及其参数都是合在一起使用的,这就是中缀符语法技术,或者叫“中缀语法”。
    - (void)singWithSong:(NSString *)song;
    

    方法名的描述是sing,唱歌,前面的song是参数描述,最后的song是参数名。

    中缀语法使得代码的可读性更强,参数的用途更容易理解。

    其实整个方法的名称是singWithSong:,后面的冒号是名称的一部分,它是告诉编译器和其他阅读人员后面出现的是参数。

    参数的类型是在圆括号里指定的。

    @end

    @interface 开始一个类的声明,@end该类的声明结束。

    二、@implementation部分

    #import "Person.h"
    
    @implementation Person
    
    @end
    

    @implementtation是一个编译器指令,表明将要对该类提供实现代。

    类名出现在@implementtation之后,该行的结尾处没有“;”,因为OC编译器指令后不用 “ ;”。

    在@implementtation里定义的那些头文件里没有的方法,只能在当前类的实现文件中使用的私有方法。

    @end实现文件结束编译器指令。

    有时候我们会看到在@implementtation上面自己加上@interface @end,如下:

    #import "Person.h"
    
    @interface  Person ()
    {
        
    }
    
    @end
    
    
    @implementation Person
    
    @end
    

    这里的@interface和在头文件里的有点像,但是还不全像,对比看一下:

    #import <Foundation/Foundation.h>
    
    @interface Person : NSObject
    
    @end
    

    头文件中
    @interface 类名 : 父类名

    @end

    实现文件中
    @interface 类名 ()

    @end

    两者写法不同有不同的含义,实质上在实现文件中这样的写法就是我们通常所说的“扩展”,其实它就是一个扩展,实现文件中扩展的属性只能在该类实现文件中使用。

    相关文章

      网友评论

        本文标题:OC基础教程(面向对象-2)

        本文链接:https://www.haomeiwen.com/subject/tkktrxtx.html