[Objective-C 面试简要笔记]
Obj-C:
1.消息机制
[shape draw] 向该对象发送消息,该对象查找并运行此函数
差不多就是shape.draw();
2.中缀语法
[textThing setStringValue:@“Hello” color:[UIColor RedColor]];
3.代码重构:
减少重复代码,写成函数或者类
4.类的复合
汽车类由轮子类和车架类复合而成(伪多继承实现方式)
11.selector响应选择器
[car respondsToSelector:@selector(doxxx:)]
12.Category(类别)和类扩展
类别缺点:1.不能新加变量 2.重名会覆盖
Things为已有类
类别:(无法添加成员变量!)
@interface Things(Plus){
}
进行类扩展如下:(可以添加成员变量!)
@interface Things(){
}
13.协议和delegate委托(代理)
协议:
//协议定义
@protocol UpdateAlertDelegate <NSObject>
- (void)updateAlert;
@end
委托:协议基础上增加
@interface TimerControl : NSObject
//遵循协议的一个代理变量定义
@property (nonatomic, weak) id<UpdateAlertDelegate> delegate;
- (void) startTheTimer;
@end
14.block代码块:函数指针
创建:
int (^multiply_block)(int number)=^(int number){
return (number*number);
}
调用:
int result=multiply_block(5);
创建block变量:
typedef double (^MKSampleMultiply2BlockRef)(double c,double d);
MKSampleMultiply2BlockRef multiply2={ return c *d ; };
调用:
multiply2(4,5);
GCD多线程
15.调度队列:
1.连续队列
dispatch_queue_t my_serial_queue= dispatch_queue_create(“myQueue”,NULL);
2.并发队列
= dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY,0);
3.主队列
= dispatch_get_current_queue(void);
4.获取当前队列
= dispatch_get_current_queue();
16.程序调度
dispatch_block_t myBlock=^{ NSLog(@“A cute block!”) }
Block异步:dispatch_async(_serial_queue,^{ NSLog(@“TASK1 ”); });
Block异步:dispatch_async(_serial_queue,myBlock);
异步函数:dispatch_async_f(_serial_queue,(_bridge void*)[NSNumber numberWithInt:3],(dispatch_function_t)myDispatchFunction);
队列暂停:
dispatch_suspend(_serial_queue);
队列重新开始
dispatch_resume(_serial_queue);
_bridge关键字
告诉ARC交给系统管理内存
17 操作队列 NSOperationQueue
1.创建代码块操作
NSBlockOperation *blockOperation=[NSBockOperation blockOperationWithBlock:^{
}];
2.[blockOperation addExecutionBlock:^{
}];
队列操作
1.当前队列
NSOperationQueue *currentQueue=[NSOperationQueue currentQueue];
2.主队列
[NSOperationQueue mainQueue];
3.队列添加代码块
[theQueue addOperation:blockOperation];
[theQueue addOperation:^{
nslog(@“aaa”);
}];
[Objective-C 面试简要笔记]的更多相关文章
- Java基础技术JVM面试【笔记】
Java基础技术JVM面试[笔记] JVM JVM 对 java 类的使用总体上可以分为两部分:一是把静态的 class 文件加载到 JVM 内存,二是在 JVM 内存中进行 Java 类的生命周期管 ...
- GEEK学习笔记— —程序猿面试宝典笔记(二)
所谓笔记,就是比較个人的东西,把个人认为有点意思的东西记录下来~~ 程序猿面试宝典笔记(一)基本概念 程序猿面试宝典笔记(二)预处理.const和sizeof 程序猿面试宝典笔记(三)auto_ptr ...
- GEEK学习笔记— —程序猿面试宝典笔记(三)
所谓笔记,就是比較个人的东西,把个人认为有点意思的东西记录下来~~ 程序猿面试宝典笔记(一)基本概念 程序猿面试宝典笔记(二)预处理.const和sizeof 程序猿面试宝典笔记(三)auto_ptr ...
- java基础技术集合面试【笔记】
java基础技术集合面试[笔记] Hashmap: 基于哈希表的 Map 接口的实现,此实现提供所有可选的映射操作,并允许使用 null 值和 null 键(除了不同步和允许使用 null 之外,Ha ...
- Java基础技术基础面试【笔记】
Java基础技术基础面试[笔记] String.StringBuilder以及StringBuffer三者之间的区别? 三者的区别可以从可变性,线程安全性,性能这三个部分进行说明 可变性 从可变性来说 ...
- Linux device tree 简要笔记
第一.DTS简介 在嵌入式设备上,可能有不同的主板---它们之间差异表现在主板资源不尽相同,比如I2C.SPI.GPIO等接口定义有差别,或者是Timer不同,等等.于是这就产生了BSP的一个 ...
- PHP面试专用笔记精简版
[PHP笔记] 1.require 遇到即包含文件,require_once 只包含一次.require 遇到错误会终止,一般放在程序的最前面:include遇到错误会继续执行,一般放在流程控制语句中 ...
- 斯坦福大学CS231n简要笔记和课后作业
笔记目录: 1. CS231n--图像分类(KNN实现) 2. 待更新... 3. 4.
- CSS权威指南之css声明,伪类,文本处理--(简要笔记一)
1.css层叠的含义 后面的会覆盖前面的样式 2.每个元素生成一个框,也称盒. 3.替换元素和非替换元素. img如果不指定src的外部路径,该元素就没有意义.他由文档本身之外的一个图像文件来替换 ...
随机推荐
- myeclipse中发送邮件出现Exception in thread "main" java.lang.NoClassDefFoundError: com/sun/mail/util/LineInputStream
出现这个问题的原因是jar包版本不统一,解决方法如下: 我在项目导入了jar包 与myeclipse自带jar冲突了 删除Java EE 5 Libraries/javaee.jar/mail里的包有 ...
- C/C++实践笔记 003
数据结构与算法程序=数据结构+算法语言是一种工具语言工具(c,c++)--程序设计方法(面向过程.面向对象)——数据结构(二叉树.队列.栈.红黑树.链表……)——算法(快速排序算法.冒泡排序算法.选择 ...
- 让计算机崩溃的python代码,求共同分析
在现在的异常机制处理的比较完善的编码系统里面,让计算机完全崩溃无法操作的代码还是不多的.今天就无意运行到这段python代码,运行完,计算机直接崩溃,任务管理器都无法调用,任何键都用不了,只能强行电源 ...
- matlab 画图中线型及颜色设置
matlab受到控制界广泛接受的一个重要原因是因为它提供了方便的绘图 功能.本章主要介绍2维图形对象的生成函数及图形控制函数的使用方 法,还将 简单地介绍一些图形的修饰与标注函数及操作和控制MATLA ...
- WEB 文件上传
关键:<input name="file" type="file"/> 然后,在外面<form>层中必须写上:enctype=" ...
- 网上找到的一个jquery版网页换肤特效
这个跟我之前在锋利的JQuery那本书里看到的那个一模一样. <!DOCTYPE html> <html> <head> <meta name="& ...
- java中关于try、catch、finally中的细节分析
来源于:http://www.cnblogs.com/aigongsi/archive/2012/04/19/2457735.html 对所有的例子进行总结 1 try.catch.finally语句 ...
- linux安装软件的学习
Yum(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及CentOS中的Shell前端软件包管理器.基于RPM包管理,能够从指定的服务器自动下载 ...
- tttttabs
<div id="fil-page" class="fil-page"> <div class="fil-container&quo ...
- html-css控制背景图全屏拉伸不重复显示
在HTML中,当我们设置背景图,只能采用是否重叠.居中.重叠方向这几个选项 CSS3中设置 body { background:#3d71b8 url(../back_main.png); backg ...