博客
关于我
Effective OC 笔记 1了解Objective-C 语言的起源
阅读量:508 次
发布时间:2019-03-07

本文共 1533 字,大约阅读时间需要 5 分钟。

Objective-C与C++、java等面向对象语言类似,不过很多方面有差别。

该语言是“消息型”语言,而非“函数调用”。两者区别:

//Messaging(Objective-C)Object *obj = [Object new];[obj performWith:parameter1 and:parameter2];//Function calling (C++)Object *obj = nw Object;obj->perform(parameter1,parameter2);
关键区别在于:使用消息结构的语言,其运行时执行的代码由运行环境来决定;

而函数调用的语言,则由编译器来决定。

采用消息结构的语言,不论是否多态,总是会在运行时才会去查找所要执行的方法。实际上,编译器甚至不关心接收消息的对象是何种类型。接收消息的对象问题也要在运行时处理,其处理过程叫“动态绑定”。

OC对象

Objective-C是C的超集,所以C语言的所有功能在编写Objective-C代码时依然适用。

Objective-C语言中的指针是用来指示对象的。想要声明一个变量,令其指代某个对象,可用如下语法:

NSString *someString = @"hello";

声明了一个名为someString的变量,其类型是NSString*,也就是说,此变量指向NSString的指针。

也可以这样写NSString* someString = @"hello";

所有Objective-C语言对象都必须这样声明,因为对象所占内存总是分配在“堆空间”中,而绝不会分配在栈上。

NSString *someString = @"hello";NSString *anotherString = someString;

如上图:someString 变量指向分配在堆中的某块内存,其中含有一个NSString对象。在创建一个变量anotherString,令其指向同一地址,并不拷贝对象,只是这两个变量会同时指向此对象。

在堆上只有一个NSString实例,然而有两个变量指向此实例,两个变量都是NSString*型,这说明当前“栈帧”里分配了两块内存,这两块内存里的值都一样,就是NSString实例的内存地址。

分配在堆中的内存必须直接管理,而分配在栈上用于保存变量的内存则会在其栈帧弹出时自动清理。

不含*变量

Objective-C代码中有时会遇到定义里不含*的变量。这些变量保存的不是Objective-C对象。比如CoreGraphices框架中的CGRect就是个例子:

CGRect frame;frame.origin.x = 0.0f;frame.origin.y = 10.0f;frame.size.width = 20.0f;frame.size.height = 45.0f;
CGRect是C结构体,许多地方都会使用这种结构体,因为如果改用Objective-C对象来做,性能会受影响。与创建结构题相比,创建对象还需要额外开销,例如分配及释放堆内存等。如果只需要int float double char等非对象类型,通常使用结构题就可以了。

总结

1 Objective-C为C语言添加了面向对象特性,是其超集。Objective-C使用动态绑定的消息结构,也即是说,在运行时才会检查对象类型。接收一条消息之后,究竟应执行何种代码,由运行期环境而非编译器来决定。

2 理解C语言核心概念有助于写好Objective-C程序。尤其要掌握内存模型与指针。

本文由原创,欢迎转载分享。请尊重作者劳动,转载时保留该声明和作者博客链接,谢谢!

你可能感兴趣的文章
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 参数--lock-tables浅析
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump 导出数据库中每张表的前n条
查看>>
mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
查看>>
Mysqldump参数大全(参数来源于mysql5.5.19源码)
查看>>
mysqldump备份时忽略某些表
查看>>
mysqldump实现数据备份及灾难恢复
查看>>
mysqldump数据库备份无法进行操作只能查询 --single-transaction
查看>>
mysqldump的一些用法
查看>>
mysqli
查看>>
MySQLIntegrityConstraintViolationException异常处理
查看>>
mysqlreport分析工具详解
查看>>
MySQLSyntaxErrorException: Unknown error 1146和SQLSyntaxErrorException: Unknown error 1146
查看>>
Mysql_Postgresql中_geometry数据操作_st_astext_GeomFromEWKT函数_在java中转换geometry的16进制数据---PostgreSQL工作笔记007
查看>>
mysql_real_connect 参数注意
查看>>
mysql_secure_installation初始化数据库报Access denied
查看>>
MySQL_西安11月销售昨日未上架的产品_20161212
查看>>
Mysql——深入浅出InnoDB底层原理
查看>>
MySQL“被动”性能优化汇总
查看>>