Snail—OC学习之类及对象

对象是对客观事物的抽象,类是对对象的抽象。类是一种抽象的数据类型

面向对象的编程语言都是有类及对象的

类是由属性及方法组成。

OC中的所有官方类及自定义的类都是NSObject的直接或者间接子类

下面看看类的编写规范

首先,COMMAND+N 新建一个类 Dog类

看到会生成两个文件.h和.m

.h是对属性及方法的声明,.m是对方法实现.

Dog.h文件中编写如下

#import <Foundation/Foundation.h>

@interface Dog : NSObject{
    //名字的变量 类型是字符串
    NSString *_name;
    //性别暂时用int值代替 1代表公 0代表母
    int _sex;

}

// 前面是+号,即此函数是Dog类的方法 可以直接用Dog类名来调用
// 无需创建对象就可以调用,简化代码
//另一个作用就是用来创建单例,即在整个生命周期,无论创建多少次都是同一个对象
+ (instancetype)sharedDog;

// 前面是-号的叫做对象方法
//默认的无参构造函数  如果不写 也是会存在的默认构造函数
- (instancetype)init;
//带一个参数的构造函数
- (instancetype)initWithName:(NSString *)name;
//带两个参数的构造函数
- (instancetype)initWithName:(NSString *)name AndSex:(int)sex;

//对象变量name、sex的get及set方法
- (void)setName:(NSString *)name;
- (NSString *)name;
- (void)setSex:(int)sex;
- (int)sex;

// 狗的一个行为
// bark(叫) 返回值为void空,无参
- (void)bark;

//lookHome(看家)无参
- (void)lookHome;

@end

Dog.m代码编写如下

#import "Dog.h"

@implementation Dog

// 由此可见,利用Dog类名来调用这个方法时 无论创建多少次对象都是同一个dog
+ (instancetype)sharedDog{
    static Dog * dog;
    if (dog != nil) {
        dog = [[Dog alloc] init];
    }
    return dog;
}

//init开头的方法都是初始化构造函数 一种编码规范
// init是没有参数的默认写法
- (instancetype)init{
    if (self = [super init]) {
    }
    return self;
}

//这是具有一个参数的初始化构造函数
- (instancetype)initWithName:(NSString *)name{
    if (self = [super init]) {
        _name = name;
    }
    return self;
}

//具有两个参数的构造函数
- (instancetype)initWithName:(NSString *)name AndSex:(int)sex{
    if (self = [super init]) {
        _name = name;
        _sex = sex;
    }
    return self;
}

- (void)setName:(NSString *)name{
    _name = name;
}

- (void)setSex:(int)sex{
    _sex = sex;
}

- (int)sex{
    return _sex;
}

- (NSString *)name{
    return _name;
}

//叫得方法 实现
- (void)bark{
    //在类的方法中可以访问成员变量,也可以赋值
    _name = @"刀刀";
    NSLog(@"%@在叫!",_name);
}

- (void)lookHome{
    _sex = 1;
    NSLog(@"刀刀狗是个%d的",_sex);
}

@end

main函数引入头文件后创建几个对象

#import <Foundation/Foundation.h>
#import "Dog.h"

int main(int argc, const char * argv[])
{

    @autoreleasepool {

        Dog * dog1 = [Dog sharedDog];
        [dog1 setName:@"刀刀"];
        [dog1 setSex:1];
        //%p可以打印出对象的地址 0x100106800
        NSLog(@"%p",dog1);
        Dog * dog2 = [Dog sharedDog];
        //0x100106800  dog2的地址和dog1的地址一样 即是同一个对象
        NSLog(@"%p",dog2);

        //当我们在main函数即相对于Dog类来说的外界函数 我们无法调用self.name的 我们通过set/get来对变量进行赋值或者获取

        // alloc 是在堆空间开辟一块空间 然后init初始化对象
        Dog * dog3 = [[Dog alloc] init];
        //下面赋值可以这样写 dog3.name = @"汪星人";
        //原理就是此语句调用的下面这个方法 调用了 -(void)setName:(NSString *)name;
        [dog3 setName:@"汪星人"];
        //下面dog3.name 的作用跟 [dog name]一样
        //其实前者这样写的原理就是调用了后者 调用了(NSString *)name方法
        NSString * name = dog3.name;
        NSLog(@"%@",name);
        //dog3调用直接的bark(叫)的方法
        [dog3 bark];

        //有参的初始化方法
        Dog * dog4 = [[Dog alloc] initWithName:@"大黄" AndSex:8];
        NSLog(@"我是%@",dog4.name);

    }
    return 0;
}

下面,来介绍一个知识点,即property属性修饰

改写一下Dog类

首先,Dog.h中 改写成下面这样

#import <Foundation/Foundation.h>

@interface Dog : NSObject{

}

@property NSString * name;
@property int sex;

// 前面是+号,即此函数是Dog类的方法 可以直接用Dog类名来调用
// 无需创建对象就可以调用,简化代码
//另一个作用就是用来创建单例,即在整个生命周期,无论创建多少次都是同一个对象
+ (instancetype)sharedDog;

// 前面是-号的叫做对象方法
//默认的无参构造函数  如果不写 也是会存在的默认构造函数
- (instancetype)init;
//带一个参数的构造函数
- (instancetype)initWithName:(NSString *)name;
//带两个参数的构造函数
- (instancetype)initWithName:(NSString *)name AndSex:(int)sex;

// 狗的一个行为
// bark(叫) 返回值为void空,无参
- (void)bark;

//lookHome(看家)无参
- (void)lookHome;

@end

Dog.m文件中

#import "Dog.h"

@implementation Dog

// 由此可见,利用Dog类名来调用这个方法时 无论创建多少次对象都是同一个dog
+ (instancetype)sharedDog{
    static Dog * dog;
    if (dog == nil) {
        dog = [[Dog alloc] init];
    }
    return dog;
}

//init开头的方法都是初始化构造函数 一种编码规范
// init是没有参数的默认写法
- (instancetype)init{
    if (self = [super init]) {
    }
    return self;
}

//这是具有一个参数的初始化构造函数
- (instancetype)initWithName:(NSString *)name{
    if (self = [super init]) {
        name = name;
    }
    return self;
}

//具有两个参数的构造函数
- (instancetype)initWithName:(NSString *)name AndSex:(int)sex{
    if (self = [super init]) {
        self.name = name;
        self.sex = sex;
    }
    return self;
}

//叫得方法 实现
- (void)bark{
    //在类的方法中可以访问成员变量,也可以赋值
    self.name = @"刀刀";
    NSLog(@"%@在叫!",_name);
}

- (void)lookHome{
    self.sex = 1;
    NSLog(@"刀刀狗是个%d的",_sex);
}

@end

可以看出来 变量、及变量的get/set方法代码删除后, 利用property来修饰的属性 再执行main.m文件时 没有报错 即property自动为我们生成了set/get方法

这就是一个自定义的类。此类是直接继承于NSObject父类的(@interface Dog : NSObject),下一篇会说继承

一个标准的自定义类就是这样来写,具体遇到问题遇到什么需求可以适当的做些改变

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-12-07 15:10:58

Snail—OC学习之类及对象的相关文章

OC学习6——面相对象的三大特性

我们在学习Java的时候都知道,类有三大特性:继承,封装,多态,这也是面向对象的三大特征.OC学习篇之---类的三大特性(封装,继承,多态) 1.封装(Encapsulation)是指将对象的状态信息隐藏在对象内部,不允许外部程序直接访问对象内部信息,而是通过该类所提供的方法来实现对内部信息的操作和访问(该隐藏的隐藏,该暴露的暴露).封装的主要目的是: 隐藏类的实现细节 让使用者只能通过预先定义好的方法来访问数据,从而可以在该方法中加入控制逻辑,限制对成员变量的不合理访问 可进行数据检查,从而有

OC学习01-类和对象

面向对象编程 基本: 概念:对象 类 封装 多态 主要语言有 C++,Java,OC 面向过程与面向对象的区别 面向过程 面向对象 特点 分析步骤,实现函数 分析问题找出参与并得出对象及其作用 侧重 实现功能 对象的设计(具体指功能) 例子 C语言 OC,C++,java 基本代码: // OC打印 NSLog(@"Lanou"); // NSInteger 整型,CGFloat 浮点型,NSString 字符串 NSInteger i = 100; NSLog(@"i =

Snail—OC学习之数组NSArray

NSArray是OC中的数组,是用来存储对象的.可以是重复的.有序的 新建一个Dog的类,在main.m中引入Dog的头文件 #import <Foundation/Foundation.h> #import "Dog.h" int main(int argc, const char * argv[]) { @autoreleasepool { Dog * dog = [[Dog alloc] init]; //数组的创建方式 //空数组创建 NSArray * arrry

Snail—OC学习之选择器SEL

选择器:是一种变量的类型,用于存储方法,类似于C语言的函数指针 作用:用于UI控件的点击事件 新建一个Dog的类 在Dog.m中写两个方法 <span style="font-size:14px;">#import "Dog.h" @implementation Dog - (void)bark{ NSLog(@"狗在叫"); } - (void)barkToPeople:(NSString *)name{ NSLog(@"

OC学习之类与对象

1.面向过程与面向对象. 1). 完成需求1 将大象放进冰箱. a. 把冰箱门打开. b. 把大象放进去. c. 把冰箱门关上. 这是面向过程的思路. 找1个冰箱,要求这个冰箱可以自己开门,自己把大象放进去,自己关门. 解决同1个问题的两种思路. 1). 解决这个问题的每1个步骤,都是我自己亲自去实现. 像这样的解决问题的思路,我们叫做面向过程的解决思路. 2). 自己不要去亲自做,而是找1个专门做这个事情的人来帮我做.像这样的解决问题的思路,我们叫做面向对象的解决思路. 面向过程与面向对象是解

Snail—OC学习之文件操作(非读写)

#import <Foundation/Foundation.h> //宏定义一个文件夹的路径信息 #define path @"/Users/XXX/Desktop/Snail" //宏定义一个文件的路径 #define filePath @"/Users/XXX/Desktop/Snail/Snail3/Snail.txt" int main(int argc, const char * argv[]) { @autoreleasepool { //

Snail—OC学习之继承

继承在字面意思就是继承财产等等.就是儿子继承父亲的财产也好.各种东西.当然儿子也可以有父亲没有的其他东西.父亲也可以不让儿子继承一些东西 上面是说的现实生活中得例子. 所谓继承,是指一个对象直接使用另一对象的属性和方法.面向对象的变成语言都有继承 OC所有的官方类或者自定义类的直接父类及间接父类都是NSObjetc类 版权声明:本文为博主原创文章,未经博主允许不得转载.

OC学习篇之---对象的拷贝

在前一篇文章中我们说到了如何解决对象的循环引用问题:http://blog.csdn.net/jiangwei0910410003/article/details/41926369,这一篇文章我们就来介绍一下OC中的对象拷贝概念,这个对于面向对象语言中都会有这种的问题,只是不同的语言有不同的解决方式:C++中有拷贝构造函数,Java中需要实现Cloneable接口,在clone方法中进行操作.但是不过OC更偏向于Java这种方式,OC中如果一个对象需要被拷贝,他需要实现协议: <NSCopyin

Snail—OC学习之NSNumber

在以后的学习或者以后做项目的时候 会希望把基本数据类型,例如:int.float等等数值 也存到数组或者字典中 因为数组.字典只能存储对象 所以,NSNumber类可以对基本数据进行封装成一个对象 进行存储 #import <Foundation/Foundation.h> int main(int argc, const char * argv[]) { @autoreleasepool { NSNumber * intNumber = [NSNumber numberWithInt:11]