IOS笔试题目一

?

Object-C有多继承吗?没有的话用什么代替?

OC是单继承,没有多继承

有时可以用分类和协议来代替多继承

Object-C有私有方法吗?私有变量呢?

OC没有类似@private的修饰词来修饰方法,只要写在.h文件中,就是公共方法

可以直接在.m文件中(比如类扩展)声明和实现方法,对编译器来说是私有的

关键字const什么含义?

const int a;

int const a;

const int *a;

int const *a;

int * const a;

int const * const a;

1> 前两个的作用是一样:a 是一个常整型数

2> 第三、四个意味着 a 是一个指向常整型数的指针(整型数是不可修改的,但指针可以)

3> 第五个的意思:a 是一个指向整型数的常指针(指针指向的整型数是可以修改的,但指针是不可修改的)

4> 最后一个意味着:a 是一个指向常整型数的常指针(指针指向的整型数是不可修改的,同时指针也是不可修改的)

static的作用?

static修饰的函数是一个内部函数,只能在本文件中调用,其他文件不能调用

static修饰的全部变量是一个内部变量,只能在本文件中使用,其他文件不能使用

static修饰的局部变量只会初始化一次,并且在程序退出时才会回收内存

线程和进程的区别?

一个应用程序对应一个进程,一个进程帮助程序占据一块存储空间

要想在进程中执行任务,就必须开启线程,一条线程就代表一个任务

一个进程中允许开启多条线程,也就是同时执行多个任务

堆和栈的区别?

堆空间的内存是动态分配的,一般存放对象,并且需要手动释放内存

栈空间的内存由系统自动分配,一般存放局部变量等,不需要手动管理内存

为什么很多内置的类,如TableView的delegate的属性是assign不是retain?

tableView的代理一般都是它所属的控制器,控制器会对它内部的view做一次retain操作

假设tableView也对代理(控制器)做一次retain操作,那么就出现循环retain问题

定义属性时,什么情况使用copy、assign、retain?

copy:NSString、Block等类型

assign:基本数据类型

retain:OC对象类型

对象是什么时候被释放的?

每个对象都有一个引用计数器,每个新对象的计数器是1,当对象的计数器减为0时,就会被销毁

tableView的重用机制?

这里只是简述:将离开屏幕的cell放到缓存池,重新拿来显示到屏幕的其他位置(其他自己详细描述)

ViewController 的loadView、viewDidLoad、viewDidUnload分别是什么时候调用的,在自定义ViewCointroller时在这几个函数中应该做什么工作?

loadView

当第一次使用控制器的view时,会调用loadView方法创建view

一般在这里自定义view

viewDidLoad

当控制器的view创建完毕时会调用,也就是在loadView后调用

一般在这里添加子控件、初始化数据

viewDidUnload

当控制器的view因为内存警告被销毁时调用

一般在这里回收跟界面相关的资源(界面都会销毁了,跟界面相关的资源肯定不要了)

ViewController的didReceiveMemoryWarning是在什么时候调用的?默认的操作是什么?

当应用程序接收到系统的内容警告时,就有可能调用控制器的didRece…Warning方法

它的默认做法是:

当控制器的view不在窗口上显示时,就会直接销毁,并且调用viewDidUnload方法

怎么理解MVC,在Cocoa中MVC是怎么实现的?

M:Model,模型,封装数据

V:View,视图界面,负责展示数据

C:Controller,控制器,负责提供数据(Model)给界面(View)

self.跟self->什么区别?

self.是调用get方法或者set放

self是当前本身,是一个指向当前对象的指针

self->是直接访问成员变量

id、nil代表什么?

id类型的指针可以指向任何OC对象

nil代表空值(空指针的值)

如何对iOS设备进行性能测试?

Timer Profile

时间: 2024-08-05 03:20:16

IOS笔试题目一的相关文章

一些iOS笔试题目

1.什么是arc?(arc是为了解决什么问题诞生的?) 首先解释ARC: automatic reference counting自动引用计数. ARC几个要点: 在对象被创建时 retain count +1,在对象被release时 retain count -1.当retain count 为0 时,销毁对象. 程序中加入autoreleasepool的对象会由系统自动加上autorelease方法,如果该对象引用计数为0,则销毁. 那么ARC是为了解决什么问题诞生的呢?这个得追溯到MRC

ios笔试题目四

#import 跟#include.@class有什么区别?#import<> 跟 #import”"又什么区别? #import和#include都能完整地包含某个文件的内容,#import能防止同一个文件被包含多次 @class仅仅是声明一个类名,并不会包含类的完整声明;@class还能解决循环包含的问题 #import <> 用来包含系统自带的文件,#import “”用来包含自定义的文件 属性readwrite,readonly,assign,retain,cop

2017 校招网上笔试题目

2017 校招网上笔试题目 做了一下某大厂的笔试的题目 1. 一个表, visit(cookie_id, area1, area2, date) 给出各种查询策略中, 哪一种最好,每一条SQL语句大同小异, 几乎看不出区别, 还有6,7个选项,同时字数很长.一般的SQL语句好像有根据查询的嵌套顺序来比较差异的,但是这道题反而没有.反正蒙了一个.没有数字可算,心里没有底,应该证明了SQL语法可能会很大地影响查询效率. 2. 给了几个条件,判断你的名次.又是球赛的问题,考查你的推理能力. 3. en

算法学习 并查集(笔试题目:找同伙)

题目背景太长,记得不清楚,暂参考<啊哈算法>一书,根据笔试题目大意改编如下: 警察正要捉获某地区的犯罪团伙,由于强盗人数过大,想查清楚有几个团伙非常困难. 根据上级指示,需要首先尽快抓获强盗A所在的团伙,这需要掌握 1 所在团伙的人数.先有资料如下: 强盗1 和 强盗2 是同伙 强盗3 和 强盗4 是同伙 强盗2 和 强盗5 是同伙 强盗3 和 强盗2 是同伙 注意,强盗的同伙的同伙也是同伙,问  强盗1 的同伙(不包括1自己)有多少人? 该题形式化表示如下: 每个测试实例首先包括2个整数:N

可能碰到的iOS笔试面试题(4)--C语言

可能碰到的iOS笔试面试题(4)--C语言 可能碰到的iOS笔试面试题(4)--C语言 C语言,开发的基础功底,iOS很多高级应用都要和C语言打交道,所以,C语言在iOS开发中的重要性,你懂的.里面的一些问题可能并不是C语言问题,但是属于计算机的一些原理性的知识点,所以我就不再另外写一篇文章了,直接写在这里. 当你写下面的代码时会发生什么事? least = MIN(*p++, b); 结果是:((p++) <= (b) ? (p++) : (*p++)) 这个表达式会产生副作用,指针p会作三次

几道经典的SQL笔试题目

几道经典的SQL笔试题目(有答案) (1)表名:购物信息 购物人      商品名称     数量 A            甲          2 B            乙          4 C            丙          1 A            丁          2 B            丙          5 …… (其他用户实验的记录大家可自行插入) 给出所有购入商品为两种或两种以上的购物人记录 答:select * from 购物信息 wher

分享两道笔试题目

前几天,给成都的某家公司投了个简历,给发了两道笔试题目,与大家分享一下.附上自己的解题过程,写得不好的地方,还请博友多多指教. 一 .  设计程序输出销售及收费清单 一个电商平台对在其平台之上销售的除了书籍.食品以及药物以外的商品收取 10% 的费用.而对于进口的商品则额外收取 5% 的附加费用.对于平台抽取的费用计算时,舍入的规则是:对于 n% 抽取率,价格为 p的商品, np/100 的值就近舍入到 0.05(如: 7.125 -> 7.15, 6.66 -> 6.70 ). 卖家卖出一些

猜数字游戏(笔试题目)

在CSDN上看到一个笔试题目..收藏一下 机试就一个题目:写一个猜数字游戏,电脑随机生成一个数字(比如 1-100 之间)让玩家猜,如果没猜中,就告诉玩家猜的数字是大了还是小了,直到猜中为止,最后告诉玩家猜了多少次.整个游戏用最简单的控制台输入输出就行 package com.sun.demo; import java.util.Random; import java.util.Scanner; public class Test01 { public static void main(Stri

GameLoft笔试题目 [Online Network Programmer Test]

gameloft 笔试题目是英文的,前面全部是理论的,最后两道是编程题目. 1 2 3 4 5 最后两道编程题目 其实还算简单: #include <stdio.h> #include <string.h> #include <iostream> std::string itoa(int number){ char nstr[15]; sprintf(nstr,"%d",number); return std::string(nstr); } usi