oc-27-@property的参数
//01加强-10 @property .4前 ) @property + 手动实现
) @property int age; + @synthesize age;//get和set方法的声明和实现都帮我们做了
) @property int age + @synthesizes age = _b;
@property .4增强 .h @property int age;
) 生成_age
) 生成_age的get和set方法的声明
) 实现_age的get和set方法 // 基本数据类型
int _age;
// set方法的写法
-(void)setAge:(int) age
{
_age = age;
} // 用assign修饰后,仍旧会生成以上标准的set方法
@property (assign) int age; // oc对象类型
@property (retain) Car *car ;
// 用retain修饰后,生成如下内存管理代码
-(void)setCar:(int) car
{
if(_car ! = car)
{
[_car release];
_car = [car retain];
}
} .内存管理相关参数
retain : release旧值,retain新值(用于OC对象)
assign : 直接赋值,不做任何内存管理(默认,用于非OC对象类型)
copy : release旧值,copy新值(一般用于NSString *) //使用@property增强型 生成get和set方法
@property(nonatomic,retain)Car *car;
//.m文件中实际上生成的是
- (void)setCar:(Car *)cat
{
if(_car != car)
{
[_car release];
_car = [car retain];
}
} .@property 参数(二)
、是否要生成set方法(若为只读属性,则不生成)
readonly:只读,只会生成get的声明和实现
readwrite:默认的,同时生成set和get的声明和实现
.多线程管理(苹果在一定程度上屏蔽了多线程操作)
nonatomic:高性能,一般使用这个
atomic:低性能,默认
atomic是Objc使用的一种线程保护技术,基本上来讲,是防止在写未完成的时候被另外一个线程读取,造成数据错误。而这种机制是耗费系统资源的,所以在iPhone这种小型设备上,如果没有使用多线程间的通讯编程,那么nonatomic是一个非常好的选择。
.set和get方法的名称
修改set和get方法的名称,主要用于布尔类型。因为返回布尔类型的方法名一般以is开头,修改 名称一般用在布尔类型中的getter。
控制set方法和get方法的名称
setter : 设置set方法的名称,一定有个冒号:
getter : 设置get方法的名称
@property(nonatomic,assign, setter=abc:,getter=haha)int age
Gamer.h #import <Foundation/Foundation.h>
#import "House.h" @interface Gamer : NSObject
//{
// House *_house; // 房间
//}
//- (void)setHouse:(House *)house;
//- (House *)house; // @property的完整格式
// @property(参数,参数)成员变量类型 成员变量名称(去掉下划线); // retain:参数用于对象类型,能够帮我们生成set方法的内存管理代码.
// assign:参数,用于基本数据类型,不做内存管理代码. // atomic:对线程加锁,性能低,安全性高(默认).
// nonatomic:不对线程加锁,性能高,安全性低.手机端,建议使用nonatomic // readonly:只能操作,只给外界提供get方法,不提供set方法.
// readwirte:可读可写. // setter:改set方法的名字
// getter:改get方法的名字 @property (nonatomic,retain)House *house;//对象类型用retain
// 外界可以读写.如果,只让外界读取,不能写入时,
@property (atomic,assign,readonly)int age;//基本类型用assign
// 判断玩家是否是vip
//BOOL res = game.isVip;
//BOOL res1 = [game isVip];
@property(nonatomic,assign,getter=isVip,setter=noVip:)BOOL vip;
@end Gamer.m #import "Gamer.h" @implementation Gamer
- (void)dealloc
{
NSLog(@"玩家被释放");
// 当玩家自己被回收时,对房间进行一次release操作.
[_house release];
[super dealloc];
}
//@property已经做了内存管理,下面就不要内存管理了。
//- (void)setAge:(int)age
//{
// _age = age;
//}
//- (void)setHouse:(House *)house
//{
// if (_house != house) {
// //当玩家换房间时,需要对旧房间做一次release操作
// [_house release];
// // 玩家要进入房间,玩家就要对房间进行一次retain操作.
// _house = [house retain];
// }
//
//}
//- (House *)house
//{
// return _house;
//}
@end House.h #import <Foundation/Foundation.h> @interface House : NSObject
@property int no;
@end House.m #import "House.h" @implementation House
- (void)dealloc
{
NSLog(@"%d房间被释放了",_no); [super dealloc];
}
@end main.m #import <Foundation/Foundation.h>
#import "Gamer.h" int main(int argc, const char * argv[]) {
@autoreleasepool {
Gamer *game = [[Gamer alloc] init]; BOOL res = game.isVip;
BOOL res1 = [game isVip];
[game noVip:YES];
}
return ;
}
void demo1(){
Gamer *g = [[Gamer alloc] init];
g.age = ;
NSLog(@"%d",g.age); House *h = [[House alloc] init]; g.house = h; [g release];
[h release];
}
void demo()
{
// 创建1个玩家
Gamer *gamer = [[Gamer alloc] init]; // 玩家1 // 创建1个房间
House *house1 = [[House alloc] init]; // 房间1 1
house1.no = ; // 创建第二个房间
House *house2 = [[House alloc] init]; // 房间2 1
house2.no = ; // 玩家进入房间
gamer.house = house1; // 房间 2 gamer.house = house2; // 2号房间 2 [house1 release]; // 房间 1 // 房间1被释放
[house2 release]; // 房间2 1 // gamer.house = house1; // 操作僵尸对象
// gamer.house = house2; [gamer release]; }
oc-27-@property的参数的更多相关文章
- Objective-C 【@property 的参数问题】
------------------------------------------- @property参数 总的来说,这是一种编译器的特性(在生成@property的时候为@property添加相 ...
- strong,weak, retain, assign的区别@property的参数
strong,weak, retain, assign的区别@property的参数 先说经验 使用场合 copy:NSString,block, weak:UI控件,代理 strong:一般对象.自 ...
- OC语言@property @synthesize和id
OC语言@property @synthesize和id 一.@property @synthesize关键字 注意:这两个关键字是编译器特性,让xcode可以自动生成getter和setter的声明 ...
- OC中@property属性关键字的使用(assign/weak/strong/copy)
OC中@property属性关键字的使用(assign/weak/strong/copy) 一.assign 用于 ‘基本数据类型’.‘枚举’.‘结构体’ 等非OC对象类型 eg:int.bool等 ...
- OC之property和自动释放池
property实例 property参数 自动释放池 一.property实例 1.前边的例子我们看到,我们在一个类中如果用到另外一个类的实例作为自己的成员变量时,通常需要在setter方法中,先r ...
- 李洪强iOS开发之OC语言@property @synthesize和id
OC语言@property @synthesize和id 一.@property @synthesize关键字 注意:这两个关键字是编译器特性,让xcode可以自动生成getter和setter的声明 ...
- js课程 2-7 带默认参数的函数怎么写
js课程 2-7 带默认参数的函数怎么写(注意参数顺序) 一.总结 一句话总结:默认参数一定要放在最后面,而且还有注意你调用参数的时候给参数的顺序习惯.直接加个等于号就可以是默认参数.function ...
- OC基础--Property
编译器指令: 用来告诉编译器要做什么 @property: @property是编译器的指令 告诉编译器在@interface中自动生成setter和getter的声明 @synthesize: @s ...
- OC中property的有关属性
property的有关属性: (1)readwrite是可读可写特征:需要生成getter方法和setter方法: (2)readonly是只读特性只会生成getter方法不会生成setter方法: ...
- [OC笔记]@property之个人理解,大神轻拍
/** * 一个简单的对象 * * @author suzhen * */ public class SimpleObjcet { /** * 声明一个age字段 */ private Object ...
随机推荐
- 150个JS特效脚本
收集了其它一些不太方便归类的JS特效,共150个,供君查阅. 1. simplyScroll simplyScroll这个jQuery插件能够让任意一组元素产生滚动动画效果,可以是自动.手动滚动,水平 ...
- Hadoop学习笔记3---安装并运行Hadoop
本文环境是在Ubuntu10.04环境下运行的. 在Linux上安装Hadoop之前,首先安装两个程序: 1.JDK1.6(或更高版本).Hadoop是用Java编写的程序,Hadoop编译及MapR ...
- 设置TabBarItem选中时的图片及文字颜色
TabBarItem选中时,默认文字和图片都变为蓝色.使用以下代码可以进行修改. MainViewController *mainVC = [[MainViewController alloc] in ...
- 第一百九十二天 how can I 坚持
早上去中关村森林公园跑了会步,下午看了部电影<夏洛特烦恼>,感觉电影跟我看的那部小说差不多,还是挺不错的. 睡觉.
- 提升c++builder 代码输入流畅度的配置
提高c++builder 代码输入流畅度 1.输入指针的函数名后,识别函数参数移动光标到括弧内,此功能太慢,有明显延迟,建议关闭.关闭以后,输入函数名不会自动添加(),需要自己手动输入括弧了,不过速度 ...
- 【MySql】性能优化之分析命令
一 当发现程序运行比较慢的时候,首先排除物力资源问题之后,就将注意力转向mysq数据库: 1.首先确定运行慢的sql语句: mysql> show full processlist; 2.确认低 ...
- MFC如何添加系统消息处理函数?
http://zhidao.baidu.com/question/318026804.html 在MFC程序中,我们并不经常直接调用Windows API,而是从MFC类创建对象并调用属于这些对象的成 ...
- 完成端口iocp——在螺丝壳里做道场
WINDOWS 2000以后的操作系统才支持IOCP.WINSOCK2.0才支持IOCP. 首先要有一个WINSOCK2.PAS的WINSOCK2.0接口调用声明单元. WINSOCK的版本号: WI ...
- 程序设计第三次作业--C++计算器初始部分
面向对象程序设计作业3--C++计算器初始部分 Github 链接:https://github.com/luojingzhao/object-oriented/tree/master/calcula ...
- HDU 5489 Removed Interval (LIS变形)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5489 给你n个数,要删去其中连续的L个,问你删去之后的LIS最大是多少? 我们先预处理出以i下标为开头 ...