欢迎来到个人简历网!永久域名:gerenjianli.cn (个人简历全拼+cn)
当前位置:首页 > 范文大全 > 工作总结>IOS 开发学习总结 objectivec面向对象之――类和对象(下)

IOS 开发学习总结 objectivec面向对象之――类和对象(下)

2023-02-13 08:10:34 收藏本文 下载本文

“疯了但也正常”通过精心收集,向本站投稿了4篇IOS 开发学习总结 objectivec面向对象之――类和对象(下),下面小编为大家带来整理后的IOS 开发学习总结 objectivec面向对象之――类和对象(下),希望能帮助大家!

IOS 开发学习总结 objectivec面向对象之――类和对象(下)

篇1:IOS 开发学习总结 objectivec面向对象之――类和对象(下)

局部变量和成员变量重名的情况下,局部变量会隐藏成员变量,

为了在方法中强行引用成员变量,可以使用 self 关键字进行区分。

示例代码:

FKWolf.h文件

#import@interface FKWolf : NSObject{ NSString* _name; int _age;}// 定义一个setName:ageAge方法- (void) setName: (NSString*) _name andAge: (int) _age;// 定义一个info方法- (void) info;@end

FKWolf.m 文件

#import FKWolf.h@implementation FKWolf// 定义一个setName:ageAge方法- (void) setName: (NSString*) _name andAge: (int) _age{ // 当局部变量隐藏成员变量时, // 可用self代表调用该方法的对象,这样即可为调用该方法的成员变量赋值了。 self->_name = _name; self->_age = _age;}// 定义一个info方法- (void) info{ NSLog(@我的名字是%@, 年龄是%d岁 , _name , _age);}@endint main(int argc , char * argv[]) { @autoreleasepool{ FKWolf* w = [[FKWolf alloc] init]; [w setName: @灰太狼 andAge:8]; [w info]; }}

篇2:IOS 开发学习总结 objectivec面向对象之――类和对象(下)

当 self 作为对象的默认引用使用时,程序可以像访问普通指针变量一样访问这个 self引用,甚至可以把 self 当成普通方法的返回值。

示例程序:

ReturnSel.m文件

#import@interface ReturnSelf : NSObject{ @public int _age;}- (ReturnSelf*) grow;@end@implementation ReturnSelf- (ReturnSelf*) grow{ _age++; // return self,返回调用该方法的对象 return self;}@endint main(int argc , char * argv[]){ @autoreleasepool{ ReturnSelf* rt = [[ReturnSelf alloc] init]; //可以连续调用同一个方法 [[[rt grow] grow] grow]; NSLog(@rt的_age成员变量的值是:%d , rt->_age); }}

说明:使用 self 作为方法的返回值可以使代码更加简洁,但可能造成实际意义的模糊。

id 类型

id 类型可以代表所有对象的类型。任意类的对象都可赋值给 id 类型的变量。

通过 id 类型的变量来调用方法时,objective-c 将会执行动态绑定。动态绑定:objective-c 将会跟踪对象所属的类,会在运行时判断该对象所属的类,并在运行时确定需要动态调用的方法,而不是在编译时确定要调用的方法。

示例程序:

#import#import FKPerson.hint main(int argc , char * argv[]) { @autoreleasepool{ // 定义id类型的变量,并将FKPerson对象赋给该变量 id p = [[FKPerson alloc] init]; // 使用p变量来调用say:方法。 // 程序将在运行时执行动态绑定,因此实际执行FKPerson对象的say:方法 [p say: @你好,疯狂iOS讲义]; }}

篇3:IOS 开发学习总结objectivec面向对象之――方法

objective-c 的方法不能独立存在,所有的方法都必须定义在类里,方法在逻辑上,要么属于类,要么属于对象。

方法的所属性

不难发现,方法在语法上和功能上,方法与函数很相似。其实,方法是由传统的函数发展而来的。

objective-c 调用函数时的传参机制和调用方法时的传参机制是一样的,都是值传递,都是传入参数的副本。

方法与传统的函数的显著不同:

在结构化编程语言里,函数是一等公民。整个程序是由一个一个函数组成;

面向对象的语言里,类是一等公民。因此在 OC 里方法不能独立存在,必须属于类或者对象。

由于 objective-c 里的方法不能独立存在,也不能像函数那样独立执行,执行方法时必须使用类或者对象作为调用者。

由上,objective-c 中方法的所属性主要体现在下面的3个方面:

1. 方法不能独立定义,只能在类体里定义。

2. 方法在逻辑上,要么属于类,要么属于对象。

3. objective-c 里的方法不能独立存在,也不能像函数那样独立执行,执行方法时必须使用类或者对象作为调用者。

形参个数可变的方法

如果在定义方法时,在最后一个形参名后增加逗号和三点(,…),就表明该形参可以接受多个参数值。

为了在程序中获取个数可变的形参。需使用如下关键字:

- va_list:这是个用于定义指向可变参数列表的指针变量。

- va_start:这是个函数。指定开始处理可变形参的列表,并让指针变量指向可变形参列表的第一个参数。

- va_end:结束处理可变形参,释放指针变量。

- va_arg:该函数返回指针当前指向的参数的值,并将指针移动到指向下一个参数。

如下示例程序:

头文件:VarArgs.h

#import@interface VarArgs : NSObject// 定义形参个数可变的方法- (void)test:(NSString *) name, ...;@end

实现文件:VarArgs.m

#import VarArgs.h@implementation VarArgs- (void)test:(NSString *) name, ...{ // 使用va_list定义一个argList指针变量,该指针变量指向可变参数列表 va_list argList; // 如果为第一个name参数存在,才需要处理后面的参数 if (name) { // 由于name参数并不在可变参数列表中,因此先处理name参数 NSLog(@%@ , name); // 让argList指向第一个可变参数列表的第一个参数,开始提取可变参数列表的参数 va_start(argList, name); // va_arg用于提取argList指针当前指向的参数,并将指针移动到指向下一个参数 // arg变量用于保存当前获取的参数,如果该参数不为nil,进入循环体 NSString* arg = va_arg(argList, id); while (arg) {// 打印出每一个参数.NSLog(@%@,arg);// 再次提取下一个参数,并将指针移动到指向下一个参数arg = va_arg(argList, id); } // 释放argList指针,结束提取 va_end(argList); }}@endint main(int argc , char * argv[]){ @autoreleasepool{ VarArgs* va = [[VarArgs alloc] init]; [va test:@疯狂iOS讲义 , @疯狂Android讲义, @疯狂Ajax讲义 , nil]; }}

本质上说,这个可变参数也是个类似数组的结构,

最后要指出的是,个数可变的形参只能处于形参列表的最后。即:一个方法中最多只能有一个长度可变的形参。

篇4:IOS 开发学习总结 objectivec面向对象之――成员变量,模拟类变量,单例模式

OC 中变量根据定义位置的不同,可以分为3大类:成员变量,局部变量和全局变量,

之前提到过方法是由函数演化而来的,所以不管是方法中定义的变量,还是函数中定义的变量,都是局部变量。

成员变量及其运行机制

成员变量:指的是在类接口部分或类实现部分定义的变量。

说明:objective-c 的成员变量都是实例变量,并不支持真正的类变量。

实例变量从该类的实例被创建开始起存在,直到系统完全销毁这个实例,实例变量的作用域与对应实例的生存范围相同。实例变量可以理解为实例成员变量,它作为实例的一个成员,与实例共存亡。

只要实例存在,程序就可以访问该实例的实例变量,在程序中访问实例变量的语法:实例->实例变量;

示例程序:

#import@interface FKPerson : NSObject{ @public // 定义2个实例变量 NSString* _name; int _age;}@end@implementation FKPerson@endint main(int argc , char * argv[]) { @autoreleasepool{ // 创建Person对象 FKPerson* p = [[FKPerson alloc] init]; // 通过指针变量来访问Person对象_name、_age实例变量 NSLog(@p变量的_name实例变量的值是:%@,p对象的_age成员变量的值是:%d, p->_name , p->_age); // 直接为p的name实例变量赋值 p->_name = @孙悟空; // 直接为p的age实例变量赋值 p->_age = 500; // 再次通过指针变量来访问Person对象_name、_age实例变量 NSLog(@p变量的_name实例变量的值是:%@,p对象的_age成员变量的值是:%d, p->_name , p->_age); // 创建第一个FKPerson对象 FKPerson* p1 = [[FKPerson alloc] init]; // 创建第二个FKPerson对象 FKPerson* p2 = [[FKPerson alloc] init]; // 分别为两个FKPerson对象的name成员变量赋值 p1->_name = @张三; p2->_name = @孙悟空; }}

总结说明:成员变量无需显式初始化,只要为一个类定义了实例变量,系统会为实例变量执行默认初始化。基本类型的实例变量默认被初始化为0;指针类型的成员变量默认被初始化为 nil.

从内存存储的角度看,objective-c 的对象与C 的结构体相似。

这里用上面的代码中定义的类创建2个实例。结合示意图来说明 OC 中实例变量的初始化和内存中的运行机制。

// 创建第一个FKPerson对象FKPerson* p1 = [[FKPerson alloc] init];

// 创建第二个FKPerson对象FKPerson* p2 = [[FKPerson alloc] init];

// 分别为两个FKPerson对象的name成员变量赋值 p1->_name = @张三; p2->_name = @孙悟空;

模拟类变量

通过内部局部变量来模拟类变量,

**注意:**static关键字不能修饰成员变量,只能修饰局部变量,全局变量和函数。

为了模拟类变量,可以在类实现部分定义个 static 修饰的全局变量,并提供一个类方法来暴露该全局变量。

示例代码:

头文件:FKUser.h

#import@interface FKUser : NSObject+ (NSString*) nation;+ (void) setNation: (NSString*) newNation;@end

实现文件:FKUser.m

#import FKUser.hstatic NSString* nation = nil;@implementation FKUser+ (NSString*) nation{ // 返回nation全局变量 return nation;}+ (void) setNation: (NSString*) newNation{ // 对nation全局变量赋值 if(![nation isEqualToString: newNation]) { nation = newNation; }}@endint main(int argc , char * argv[]) { @autoreleasepool{ // 为FKUser的类变量赋值 [FKUser setNation:@中国]; // 访问FKUser的类变量 NSLog(@FKUser的nation类变量为:%@, [FKUser nation]); }}

单例模式

如果一个类始终只能创建一个实例,则这个类称为单例类。

单例类可以通过 static 全局变量来实现,程序考虑定义一个 static全局变量,该变量用于保存已经创建的 singleton 对象——每次程序需要获取该实例的时候,先判断该 static 全局变量是不是为 nil, 如果为 nil,则初始化一个实例并赋值给 static 全局变量。

示例程序:

FKSingleton.h

#import@interface FKSingleton : NSObject+ (id) instance;@end

FKSingleton.m

#import FKSingleton.hstatic id instance = nil;@implementation FKSingleton+ (id) instance{ // 如果instance为nil if(!instance) { // 创建一个Singleton实例,并将该实例赋给instance全局变量 instance = [[super alloc] init]; } return instance;}@endint main(int argc , char * argv[]) { @autoreleasepool{ // 判断两次获取的实例是否相等,程序将会返回1(代表真) NSLog(@%d , [FKSingleton instance] == [FKSingleton instance]); }}

【IOS 开发学习总结 objectivec面向对象之――类和对象(下)】相关文章:

1.Flash ActionScript2.0面向对象游戏开发

2.面向对象软件工程开发探讨的论文

3.Lua面向对象编程学习笔记

4.初始化类对象

5.面向对象的个人数据中心规划和实施论文

6.ios学习之个人总结

7.和对象分手的qq签名

8.ios个人总结学习

9.人力资源管理技术的对象和层次

10.和相亲对象微信开场白怎么说

下载word文档
《IOS 开发学习总结 objectivec面向对象之――类和对象(下).doc》
将本文的Word文档下载到电脑,方便收藏和打印
推荐度: 评级1星 评级2星 评级3星 评级4星 评级5星
点击下载文档

文档为doc格式

  • 返回顶部