day2:实例变量可见度、方法、setter、getter

2024-04-08 05:08

本文主要是介绍day2:实例变量可见度、方法、setter、getter,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


/*在OC中没有调用方法一说  它的正确表述叫给对象发消息  OC里面的方法调用是个什么机制:消息发送机制方法的实现是通过什么来实现的,是通过函数指针来实现的*/
/*总结:1、实例变量的可见度public  作用域在所有protected  默认的(作用域在本类和子类)private   作用域只在本类2、方法的声明(包括五部分)*OC中声明方法:包括五个部分:2.1、第一部分:+ -表示方法类型标示符,+表示方法是类方法,只能用类的名字来进行调用;-表示是一个对象方法(实例方法),只能用类的对象(实例)来进行调用。2.2、第二部分:返回值类型用()括起来;void表示方法没有返回值,如果方法有返   回值括号中就声明与返回值相同的类型。2.3、第三部分:冒号前面的符号,表示的是参数的修饰词,功能是对参数进行解释,表述参数的功能;参数的修饰词可以省略不写(第一个冒号前的不能省略)参数的修饰词会出现在我们调用的地方2.4、第四部分:冒号后面的数据类型是参数的类型2.5、第五部分:参数类型后面是参数的名字,不同参数之间要有空格隔开,参数名不会出现在调用的地方2.6、方法名:去掉方法标示,去掉返回值,去掉参数,剩下修饰符和冒号就是一个方法的方法名。如:-(void)setName:(NSString *)name :(NSUInteger)age;的方法名为:setName::-(void)setName:(NSString *)name andAge:(NSUInteger)age;的方法名为:setName: andAge:2.7、类里面不能出现同名的方法,如果一个加号一个减号他们的方法名相同,这样是可以的,其他一律不允许方法名相同3、init(重写初始化方法、自定义初始化方法)-(id)init{   //重写父类的初始化方法_name=@"zhangsan";return self;}//实现自定义的初始化方法-(id)initWithName:(NSString *)name{   //自定义初始化方法_name=name;return self; //返回的是self}id和instancetype的比较:3.1、相同点:这两个类型都表示泛型类型,表示的是对象类型;3.2、不同点:id在编译期不确定它的类型,instacetype在编译期就已经知道它的类型了id s=[[Person alloc]init]  只有到了运行期才把id判定为Person类型3.3、id既可以作为返回值类型使用,也可以作为参数类型使用;instancetype只能作为返回值类型使用,不能作为参数类型使用3.4 OC是一个强类型语言,所有变量必须确定它的类型,建议使用instancetype类型,因为在编译器就检查了,而id在运行期才检查,如果运行期出现问题是很致命的。(PHP是一个弱类型的语言)4、setter和gettersetter 设置器  操作变量 为变量赋值  (setter方法没有返回值)setter 的书写格式如下:- (void)setAge:(int)age; 即set+ ⾸字母大写的实例变量名(忽略下划线)。getter 访问器  读取变量值的方法   (getter方法有返回值)getter 的书写格式如下:- (int)age;即返回值类型与变量类型⼀致,方法名与实例变量名相同(忽略下划线)OC2.0之前没有属性这种方法,11年之前用这种方法操作成员变量,之后就很少用了5、三种导入头文件的方式#import导入和#include导入的区别:#include 导入会导致重复编译的错误,include导入多少次就重复编译多少次,用import导入文件不会出现重复编译的错误,不管导入几次,只执行一次,解决了include导入重复编译的错误#import 只解决了重复编译问题,并没有解决循环交叉编译错误,@class Women;只声明一个类存在,但是不对这个类进行编译,解决交叉编译错误    */

lessonOC02day:

Person.h

#import <Foundation/Foundation.h>@interface Person : NSObject{@privateNSString *_name;NSString *_sex;//NSUInteger 在OC中重命名的类型,在64位系统上是对unsigned long重命名,在32位系统上是对unsigned int重命名@private//私有的实例变量,它的作用域只能在本类里访问(子类也不能访问,子类虽然继承父类的所有东西,只是不能使用私有的东西)//受保护的实例变量(有protected修饰)可在本类和子类中访问。有@public修饰的可在所有文件里访问NSUInteger _age;
}
//声明姓名的设置器
//-(void)setName:(NSString *)name;
//声明姓名的获取器
//-(NSString*)name;-(void)printName;
//声明有参数的方法:(参数类型)参数名字
-(void)setName:(NSString *)name;
//声明有多个参数的方法:
/*OC中声明方法:包括五个部分:1、第一部分:+ -表示方法类型标示符,+表示方法是类方法,只能用类的名字来进行调用;-表示是一个对象方法(实例方法),只能用类的对象(实例)来进行调用。2、第二部分:返回值类型用()括起来;void表示方法没有返回值,如果方法有返回值括号中就声明与返回值相同的类型。3、第三部分:冒号前面的符号,表示的是参数的修饰词,功能是对参数进行解释,表述参数的功能;参数的修饰词可以省略不写(第一个冒号前的不能省略)参数的修饰词会出现在我们调用的地方4、第四部分:冒号后面的数据类型是参数的类型5、第五部分:参数类型后面是参数的名字,不同参数之间要有空格隔开,参数名不会出现在调用的地方6、方法名:去掉方法标示,去掉返回值,去掉参数,剩下修饰符和冒号就是一个方法的方法名。如:-(void)setName:(NSString *)name :(NSUInteger)age;的方法名为:setName::-(void)setName:(NSString *)name andAge:(NSUInteger)age;的方法名为:setName: andAge:7、类里面不能出现同名的方法,如果一个加号一个减号他们的方法名相同,这样是可以的,其他一律不允许方法名相同*/
//下面这个方法的方法名为:setName::
-(void)setName:(NSString *)name :(NSUInteger)age;
//下面这个方法的方法名为:setName: andAge:
-(void)setName:(NSString *)name andAge:(NSUInteger)age;//自定义初始化方法,方法命名规则:init为前缀命名
-(id)initWithName:(NSString *)name;
@end@interface Student : Person
-(void)printSomthing;
@end

Person.m

//  OC在编译的时候只编译.m文件,不编译.h文件#import "Person.h"@implementation Person
/*id和instancetype的比较:1、相同点:这两个类型都表示泛型类型,表示的是对象类型;2、不同点:id在编译期不确定它的类型,instacetype在编译期就已经知道它的类型了id s=[[Person alloc]init]  只有到了运行期才把id判定为Person类型3、id既可以作为返回值类型使用,也可以作为参数类型使用;instancetype只能作为返回值类型使用,不能作为参数类型使用*/
-(id)init{   //重写父类的初始化方法_name=@"zhangsan";return self;
}
//实现自定义的初始化方法
-(id)initWithName:(NSString *)name{   //自定义初始化方法_name=name;return self; //返回的是self
}-(void)printName{NSLog(@"name=%@",_name);
}
-(void)setName:(NSString *)name{
//    _name=@"张三";_name=name;
}
-(void)setName:(NSString *)name :(NSUInteger)age{_name=name;_age=age;NSLog(@"name=%@ age=%lu",_name,_age);
}
-(void)setName:(NSString *)name andAge:(NSUInteger)age{_name=name;_age=age;NSLog(@"name=%@  age=%lu",_name,_age);
}
@end@implementation Student
-(void)printSomthing{
//    self -> _name=@"李四";}
@end

AudiCar.h

#import <Foundation/Foundation.h>@interface AudiCar : NSObject{NSString *_color;//颜色NSString *_size;//型号float _price;//价格
}
//声明设置颜色的方法
//setter书写格式:以set为前缀,加上实例变量名去掉下划线_,首字母改成大写。
-(void)setColor:(NSString *)color;
//声明获取颜色的方法
//getter格式:实例变量名去掉下划线,如-(int)age;
//在COCO框架中,以get为前缀的方法必须有参数和返回值,
-(NSString *)Color;
-(NSString *)getColor;//声明设置型号的方法
-(void)setSize:(NSString *)size;
//声明获取型号的方法
-(NSString *)getSize;//声明一个对所有成员变量赋值的方法
-(void)setColor:(NSString *)colorandSize:(NSString *)sizeandPrice:(float)price;
-(float)getPrice;@end

AudiCar.m

#import "AudiCar.h"@implementation AudiCar
//实现设置颜色的方法
-(void)setColor:(NSString *)color{_color=color;
}
//实现获取颜色的方法
-(NSString *)getColor{return _color;
}//声明设置型号的方法
-(void)setSize:(NSString *)size{_size=size;
}
//声明获取型号的方法
-(NSString *)getSize{return _size;
}-(void)setColor:(NSString *)colorandSize:(NSString *)sizeandPrice:(float)price{_color=color;_size=size;_price=price;
}
-(float)getPrice{return _price;
}
@end

Man.h

#import <Foundation/Foundation.h>
//#import "Women.h"
@class Women;//声明一个类存在,但是不对这个类进行编译,解决交叉编译错误@interface Man : NSObject{Women *_women;
}@end

Woman.h

#import <Foundation/Foundation.h>
//#import "Man.h"  //交叉编译错误
@class Man;@interface Women : NSObject{Man *_man;
}@end

main.h

#import <Foundation/Foundation.h>
#import "Person.h"
#import "Man.h"  //如果在Women.h里导入会出现循环交叉编译错误
#import "Women.h" //如果在men.h里导入会出现循环交叉编译错误//#include "AudiCar.h"  //重复编译错误
//#include "AudiCar.h"  //重复编译错误#import "AudiCar.h"
#import "AudiCar.h"int main(int argc, const char * argv[]) {@autoreleasepool {
/*// insert code here...NSLog(@"Hello, World!");Person *person=[[Person alloc]init];//输出张三[person setName:@"张三"];[person printName];//设置名字为王五,年龄30;[person setName:@"王五" :30];//设置名字为赵六,年龄为40;[person setName:(NSString *)@"赵六" andAge:(NSUInteger)40];[person printName];*///创建Person对象  并做初始化赋值Person *person2=[[Person alloc]initWithName:@"张三"];Person *person3=[[Person alloc]initWithName:@"李四"];Person *person4=[[Person alloc]initWithName:@"王五"];[person2 printName];[person3 printName];[person4 printName];//创建audiCar对象AudiCar *audiCar=[[AudiCar alloc]init];[audiCar setColor:@"red"];NSString *color = [audiCar getColor];NSLog(@"color = %@",color);[audiCar setSize:@"A8"];NSString *size=[audiCar getSize];NSLog(@"size = %@",size);//使用对所有成员变量赋值的方法[audiCar setColor:@"write" andSize:@"A9" andPrice:30.5];float price=[audiCar getPrice];NSLog(@"color=%@ size=%@ price=%.2f",color,size,price);}return 0;
}



这篇关于day2:实例变量可见度、方法、setter、getter的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/884648

相关文章

变量与命名

引言         在前两个课时中,我们已经了解了 Python 程序的基本结构,学习了如何正确地使用缩进来组织代码,并且知道了注释的重要性。现在我们将进一步深入到 Python 编程的核心——变量与命名。变量是我们存储数据的主要方式,而合理的命名则有助于提高代码的可读性和可维护性。 变量的概念与使用         在 Python 中,变量是一种用来存储数据值的标识符。创建变量很简单,

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

浅谈主机加固,六种有效的主机加固方法

在数字化时代,数据的价值不言而喻,但随之而来的安全威胁也日益严峻。从勒索病毒到内部泄露,企业的数据安全面临着前所未有的挑战。为了应对这些挑战,一种全新的主机加固解决方案应运而生。 MCK主机加固解决方案,采用先进的安全容器中间件技术,构建起一套内核级的纵深立体防护体系。这一体系突破了传统安全防护的局限,即使在管理员权限被恶意利用的情况下,也能确保服务器的安全稳定运行。 普适主机加固措施:

webm怎么转换成mp4?这几种方法超多人在用!

webm怎么转换成mp4?WebM作为一种新兴的视频编码格式,近年来逐渐进入大众视野,其背后承载着诸多优势,但同时也伴随着不容忽视的局限性,首要挑战在于其兼容性边界,尽管WebM已广泛适应于众多网站与软件平台,但在特定应用环境或老旧设备上,其兼容难题依旧凸显,为用户体验带来不便,再者,WebM格式的非普适性也体现在编辑流程上,由于它并非行业内的通用标准,编辑过程中可能会遭遇格式不兼容的障碍,导致操

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

【北交大信息所AI-Max2】使用方法

BJTU信息所集群AI_MAX2使用方法 使用的前提是预约到相应的算力卡,拥有登录权限的账号密码,一般为导师组共用一个。 有浏览器、ssh工具就可以。 1.新建集群Terminal 浏览器登陆10.126.62.75 (如果是1集群把75改成66) 交互式开发 执行器选Terminal 密码随便设一个(需记住) 工作空间:私有数据、全部文件 加速器选GeForce_RTX_2080_Ti

C++操作符重载实例(独立函数)

C++操作符重载实例,我们把坐标值CVector的加法进行重载,计算c3=c1+c2时,也就是计算x3=x1+x2,y3=y1+y2,今天我们以独立函数的方式重载操作符+(加号),以下是C++代码: c1802.cpp源代码: D:\YcjWork\CppTour>vim c1802.cpp #include <iostream>using namespace std;/*** 以独立函数

【VUE】跨域问题的概念,以及解决方法。

目录 1.跨域概念 2.解决方法 2.1 配置网络请求代理 2.2 使用@CrossOrigin 注解 2.3 通过配置文件实现跨域 2.4 添加 CorsWebFilter 来解决跨域问题 1.跨域概念 跨域问题是由于浏览器实施了同源策略,该策略要求请求的域名、协议和端口必须与提供资源的服务相同。如果不相同,则需要服务器显式地允许这种跨域请求。一般在springbo

AI(文生语音)-TTS 技术线路探索学习:从拼接式参数化方法到Tacotron端到端输出

AI(文生语音)-TTS 技术线路探索学习:从拼接式参数化方法到Tacotron端到端输出 在数字化时代,文本到语音(Text-to-Speech, TTS)技术已成为人机交互的关键桥梁,无论是为视障人士提供辅助阅读,还是为智能助手注入声音的灵魂,TTS 技术都扮演着至关重要的角色。从最初的拼接式方法到参数化技术,再到现今的深度学习解决方案,TTS 技术经历了一段长足的进步。这篇文章将带您穿越时