ios面试_ios面试题 - CSDN
精华内容
参与话题
  • 疫情基本控制,同时面试也渐渐开始了,以下iOS面试题仅供参考,毕竟面试是不可控的,但懂得越多,自然机会越大! ####字节一面内容: 1、 自我介绍 2、 介绍一下简历中的一个项目 3、 面向对象的三个要素 4、 多态?...

    序言

    疫情基本控制,同时面试也渐渐开始了,以下iOS面试题仅供参考,毕竟面试是不可控的,但懂得越多,自然机会越大!

    字节一面内容:
    1、 自我介绍

    2、 介绍一下简历中的一个项目

    3、 面向对象的三个要素

    4、 多态?

    5、 Java,python,OC运行效率孰高?

    6、 Property,其中copy如何?

    7、 Property(nonatomatic, copy) NSMutableArray有什么问题

    8、 Copy和MutableCopy的区别

    9、 解释下类别,原理

    10、解释下封装,重载;

    11、 OC存在多重继承吗?

    12、了解表视图吗,解释一下复用原理

    13、说明一下表视图的滑动卡顿的优化方法

    14、viewDidLoad和viewDidAppear的调用时机(一次和多次的区别);

    15、页面间的传值方式有哪些(公有属性,公有方法和协议,block传值,通知,extern全局变量传值,
    NSUserDefault简单数据存储传值);

    16、通知和delegate的区别?

    17、 通知的发送和接收是否在同一线程?

    18、HTTP和HTTPS区别?

    19、OC中多线程一般有几个方案?

    20、了解NSURLConnection和Session吗?

    21、说一下NSURLSession具体的实现原理

    22、http的头部的几个码。;

    23、编程题:实现一个二叉树的倒置。

    字节二面内容:

    1、老虎吃羊问题。(博弈论,老虎要吃羊,假设所有老虎是理智的,即首先为了生存,其次为了饱腹,老虎吃了羊后会变成羊,同样会被其他老虎吃掉。现在,N只老虎和1只羊,请问N为多少时,老虎们会吃羊。动态规划问题,奇数吃,偶数不吃。)

    2、青蛙跳格子,斐波拉契数列;青蛙跳格子,斐波拉契数列;

    3、熟悉使用什么框架?

    4、如果让你自己实现SDWebImage的二级存储机制,你如果实现?

    5、@autorelease{ NSString s;}和NSString s;有什么区别?

    6、说一下你对autorelease的理解。

    7、说一下对于http的理解?

    8、http的返回状态码有了解吗?

    9、为什么说http是无状态的?

    10、为什么不用原生的APNS技术实现呢?

    11、了解GCD吗?

    12、说一下dispatch_group_t和dispatch_barrier_sync的区别吗?

    13、了解NSOperation吗?

    14、了解NSOperationQueue吗?

    字节三面内容:

    1、 算法题:求只有三项元素的数组中的顺序排列,时间复杂度要求O(n);

    2、 说一下你对OC程序编译和连接方面的理解?

    3、 说一下内存管理相关的操作?

    4、 说一下响应链的原理?

    5、 追问:hitTest有尝试过重写吗?

    6、 http, session和cookie有了解过吗;

    7、 线程和队列的关系?

    8、 CALayer和UIView了解吗?

    需要更多iOS面试文集资料,加iOS开发交流群:789143298,群文件直接获取
    ——点击加入:iOS开发交流群


    展开全文
  • 高级iOS面试题全纪录

    千次阅读 2018-09-02 13:34:24
    iOS基础: 多线程使用,gcd跟operation区别,怎么取消正在执行的gcd任务 GCD 系列知识总结 NSOperation相关知识总结 可以仿照operation的工作原理,设置一个BOOL变量,当需要停止时设置成YES,执行任务的时候去...

    iOS基础:

    1.多线程使用,gcd跟operation区别,怎么取消正在执行的gcd任务

    2、 runtime的使用

    • iOS Runtime详解
    • swizzling中hook一个方法要先class_addMethod,假如成功class_replaceMethod,失败直接method_exchangeImplementations;这样做的原因是防止本类中没有实现这个方法,即使父类有实现这个方法也不应该替换父类该方法
    • 项目中按钮防止连续点击
    • 多页面通知的封装
    • 归档解档

    3、runloop的理解跟应用

    • iOS RunLoop详解
    • 本质上是一个while循环,一个线程对应一个loop。主线程loop默认开启,子线程要自己手动开启。一个loop钟有多个模式(mode),默认都是default模式。
    • 子线程保活,比如在子线程加一个定时器,默认执行一次就不会再执行了
    • 假如在主线程加一个定时器去修改UI,当我们滑动界面的时候就会发现UI不变了。因为默认是default模式,滑动界面时切换成响应模式。通过调整成common模式,就可以解决这个问题了。
    • 重任务分散,比如批量大图加载。

    4、 自动释放池工作原理

    5、响应链原理

    - (UIView *)hitTest:(CGPoint)point withEvent:(UIEvent *)event {
        if (!self.isUserInteractionEnabled || self.isHidden || self.alpha <= 0.01) {
            return nil;
        }
        if ([self pointInside:point withEvent:event]) {//这边point是在self上的位置
            for (UIView *subview in [self.subviews reverseObjectEnumerator]) {
                CGPoint convertedPoint = [subview convertPoint:point fromView:self];//convertedPoint是subView上的位置
                UIView *hitTestView = [subview hitTest:convertedPoint withEvent:event];
                if (hitTestView) {
                    return hitTestView;
                }
            }
            return self;
        }
        return nil;
    }
    • 扩大按钮点击范围
    • 修改响应视图
    • 让超出父视图的子视图响应操作

    6、自动打包技术
    - 持续集成开发:Jenkins自动打包实践

    7、 a,b任务并发执行,然后执行c任务怎么做,有哪些方法实现

    • dispatch_group_async(A),dispatch_group_async(B),dispatch_group_notify(C)
    • operation设置任务C依赖A,依赖B
    • 对C加栅栏
    -(void)testBarrier{
        dispatch_queue_t osConcurrent = dispatch_queue_create("dyConcurrent1", DISPATCH_QUEUE_CONCURRENT); //自己创建并行队列
        dispatch_async(osConcurrent, ^{
            for (int i = 0; i< 3; i++) {
                NSLog(@"任务1");
            }
        });
    
        dispatch_async(osConcurrent, ^{
            for (int i = 0; i< 3; i++) {
                NSLog(@"任务2");
            }
        });
    
        dispatch_barrier_async(osConcurrent, ^{//这边一定要是自己创建的并行队列,系统global无效
            NSLog(@"追加追加追加");
        });
        dispatch_async(osConcurrent, ^{
            for (int i = 0; i< 3; i++) {
                NSLog(@"任务3");
            }
        });
    }
    输出:
    任务12并发执行,执行完执行追加追加,再执行任务3
    

    一个dispatch_barrier允许你在一个并行队列中创建一个同步点。当在队列中遇到这个barrier时,这个barrier block便会延迟执行(同时所有在其后的block都会延迟),直至所有在barrier之前的block执行完成。这时,这个barrier block便会执行。之后队列便恢复正常执行。

    8、多线程中的锁使用,要是你你怎么实现

    网络相关:

    1. https请求流程,哪一步有可能被攻破
    2. tcp,udp协议

    数据结构:

    1. 数组、字典底层实现

    开放性问题:

    • 你的优势是什么
    • 你们公司做的最好的是哪一块
    • 组建化做了吗,路由要是你设计你怎么设计,每种设计的优缺点

    • 列表内容

      1、openUrl的方式 {scheme}://{module}/{page}?{para1=1&para2=2 … }

    • RN有了解吗?你们公司为什么不用RN,原因是什么
    • 要是你入职能为我们公司带来哪些改变
    • 最近在看什么书,以后职业规划?
    • 你有什么问题问我吗?
    展开全文
  • 2020年iOS面试题及答案

    千次阅读 2020-04-20 16:20:57
    尝试做一下回答 1,分类和扩展有什么区别?可以分别用来做什么?分类有哪些局限性?分类的结构体里面有哪些成员? ①类别中原则上只能增加方法(能添加属性的的原因只是通过runtime能添加属性的的原因只是通过...

    问题来源:链接:https://juejin.im/post/5e75aba6e51d4526d71d6558

    1,分类和扩展有什么区别?可以分别用来做什么?分类有哪些局限性?分类的结构体里面有哪些成员?

    ①类别中原则上只能增加方法(能添加属性的的原因只是通过runtime能添加属性的的原因只是通过runtime的objc_setAssociatedObject和objc_getAssociatedObject方法解决无setter/getter的问题而已);
    ②类扩展不仅可以增加方法,还可以增加实例变量(或者属性),只是该实例变量默认是@private类型的(
    用范围只能在自身类,而不是子类或其他地方);
    ③类扩展中声明的方法没被实现,编译器会报警,但是类别中的方法没被实现编译器是不会有任何警告的。这是因为类扩展是在编译阶段被添加到类中,而类别是在运行时添加到类中。
    ④类扩展不能像类别那样拥有独立的实现部分(@implementation部分),也就是说,类扩展所声明的方法必须依托对应类的实现部分来实现。
    ⑤定义在 .m 文件中的类扩展方法为私有的,定义在 .h 文件(头文件)中的类扩展方法为公有的。类扩展是在 .m 文件中声明私有方法的非常好的方式。

    最重要的还是类扩展是在编译阶段被添加到类中,而类别是在运行时添加到类中。
    分类方法未实现,编译器也不会报警告。
    分类方法与原类中相同会优先调用分类。

    分类的结构体

    typedef struct objc_category *Category;
    struct objc_category {
      char *category_name                          OBJC2_UNAVAILABLE; // 分类名
      char *class_name                             OBJC2_UNAVAILABLE; // 分类所属的类名
      struct objc_method_list *instance_methods    OBJC2_UNAVAILABLE; // 实例方法列表
      struct objc_method_list *class_methods       OBJC2_UNAVAILABLE; // 类方法列表
      struct objc_protocol_list *protocols         OBJC2_UNAVAILABLE; // 分类所实现的协议列表
    }
    

    2,讲一下atomic的实现机制;为什么不能保证绝对的线程安全(最好可以结合场景来说)?

    atomic是在setter和getter方法里会使用自旋锁spinlock_t来保证setter方法和getter方法的线程的安全。可以看做是getter方法获取到返回值之前不会执行setter方法里的赋值代码。如果不加atomic,可能在getter方法读取的过程中,再别的线成立发生setter操作,从而出现异常值。

    加上atomic后,setter和getter方法是线程安全的,原子性的,但是出了getter方法和setter方法后就不能保证线程安全了

    @property (atomic, strong) NSArray*                arr;
    //thread A
    for (int i = 0; i < 10000; i ++) {
        if (i % 2 == 0) {
            self.arr = @[@"1", @"2", @"3"];
        }
        else {
            self.arr = @[@"1"];
        }
    }
    
    //thread B
    for (int i = 0; i < 100000; i ++) {
        if (self.arr.count >= 2) {
            NSString* str = [self.arr objectAtIndex:1];
        }
    }
    

    上面的例子线程B里面可能会因为数组越界而引起crash,因为加入在B线程里判断self.arr.count >= 2的时候数组是self.arr = @[@“1”, @“2”, @“3”];但是当调用[self.arr objectAtIndex:1]可能self.arr的值已经在线程A里被更改为了@[@“1”],此时数组越界了。因此,虽然self.arr是atomic的,还是会出现线程安全问题。

    3,被weak修饰的对象在被释放的时候会发生什么?是如何实现的?知道sideTable么?里面的结构可以画出来么?
    被weak修饰的对象在被释放时候会置为nil,不同于assign;

    Runtime维护了一个weak表,用于存储指向某个对象的所有weak指针。weak表其实是一个hash(哈希)表,Key是所指对象的地址,Value是weak指针的地址(这个地址的值是所指对象指针的地址)数组。

    1、初始化时:runtime会调用objc_initWeak函数,初始化一个新的weak指针指向对象的地址。
    2、添加引用时:objc_initWeak函数会调用 objc_storeWeak() 函数, objc_storeWeak() 的作用是更新指针指向,创建对应的弱引用表。
    3、释放时,调用clearDeallocating函数。clearDeallocating函数首先根据对象地址获取所有weak指针地址的数组,然后遍历这个数组把其中的数据设为nil,最后把这个entry从weak表中删除,最后清理对象的记录。

    struct SideTable {
        // 保证原子操作的自旋锁
        spinlock_t slock;
        // 引用计数的 hash 表
        RefcountMap refcnts;
        // weak 引用全局 hash 表
        weak_table_t weak_table;
    }
    
    struct weak_table_t {
        // 保存了所有指向指定对象的 weak 指针
        weak_entry_t *weak_entries;
        // 存储空间
        size_t    num_entries;
        // 参与判断引用计数辅助量
        uintptr_t mask;
        // hash key 最大偏移值
        uintptr_t max_hash_displacement;
    };
    

    4,Autoreleasepool 所使用的数据结构是什么? AutoreleasePoolPage 结构体了解么?

    Autoreleasepool所使用的数据结构是什么?AutoreleasePoolPage结构体了解么

    6,iOS 中内省的几个方法? class 方法和 objc_getClass 方法有什么区别?

    1.当参数obj为Object实例对象
    object_getClass(obj)与[obj class]输出结果一直,均获得isa指针,即指向类对象的指针。

    2.当参数obj为Class类对象
    object_getClass(obj)返回类对象中的isa指针,即指向元类对象的指针;[obj class]返回的则是其本身。

    3.当参数obj为Metaclass类对象
    object_getClass(obj)返回元类对象中的isa指针,因为元类对象的isa指针指向根类,所有返回的是根类对象的地址指针;[obj class]返回的则是其本身。

    4.obj为Rootclass类对象
    object_getClass(obj)返回根类对象中的isa指针,因为跟类对象的isa指针指向Rootclass‘s metaclass(根元类),即返回的是根元类的地址指针;[obj class]返回的则是其本身。

    总结:
    经上面初步的探索得知,object_getClass(obj)返回的是obj中的isa指针;而[obj class]则分两种情况:一是当obj为实例对象时,[obj class]中class是实例方法:- (Class)class,返回的obj对象中的isa指针;二是当obj为类对象(包括元类和根类以及根元类)时,调用的是类方法:+ (Class)class,返回的结果为其本身。

    7,RunLoop的作用是什么?它的内部工作机制了解么?(最好结合线程和内存管理来说)
    Runloop是什么?
    深入理解RunLoop | Garan no dou

    字面意思是“消息循环、运行循环”,runloop内部实际上就是一个do-while循环,它在循环监听着各种事件源、消息,对他们进行管理并分发给线程来执行。

    1.通知观察者将要进入运行循环。
    线程和 RunLoop 之间是一一对应的

    2.通知观察者将要处理计时器。

    3.通知观察者任何非基于端口的输入源即将触发。

    4.触发任何准备触发的基于非端口的输入源。

    5.如果基于端口的输入源准备就绪并等待触发,请立即处理该事件。转到第9步。

    6.通知观察者线程即将睡眠。

    7.将线程置于睡眠状态,直到发生以下事件之一:

    事件到达基于端口的输入源。
    计时器运行。
    为运行循环设置的超时值到期。
    运行循环被明确唤醒。

    8.通知观察者线程被唤醒。

    9.处理待处理事件。

    如果触发了用户定义的计时器,则处理计时器事件并重新启动循环。转到第2步。
    如果输入源被触发,则传递事件。
    如果运行循环被明确唤醒但尚未超时,请重新启动循环。转到第2步。

    10.通知观察者运行循环已退出。

    8:苹果是如何实现 autoreleasepool的?

    arc下编译器会优化成
    void *context = objc_autoreleasePoolPush();
    // {}中的代码
    objc_autoreleasePoolPop(context);
    复制代码
    向一个结构AutoreleasePoolPage,中写入需要自动释放的对象,类似一种标记,调用objc_autoreleasePoolPop(context)后,就会把这中间的对象release一下。
    这里要注意的是,方法返回值是怎么做到自动释放的?
    其使用Thread Local Storage(TLS)线程局部存储,每次存入线程或者从线程取出来。
    我们没有卸载{}中的自动释放对象,会在每个runloop结束时候去释放,相当于一个大的autoreleasepool中。
    参考文章
    苹果是如何实现autoreleasepool的

    8,哪些场景可以触发离屏渲染?(知道多少说多少)

    • shouldRasterize(光栅化)
    • masks(遮罩)
    • shadows(阴影)
    • edge antialiasing(抗锯齿)
    • group opacity(不透明)
    • 复杂形状设置圆角等
    • 渐变
    展开全文
  • iOS面试题基础

    千次阅读 2019-08-02 08:26:10
    分类、扩展、代理、通知、KVC、KVO、属性关键字 一、分类(Category) 1、分类的作用? 声明私有方法,分解体积大的类文件 2、分类的特点?...在运行时时期,将 Category 中的实例方法列表、协议列表、属性列表添加...

    分类、扩展、代理、通知、KVC、KVO、属性关键字

    一、分类(Category)

    1、分类的作用?

    声明私有方法,分解体积大的类文件

    2、分类的特点?

    可以为系统类添加分类。在运行时时期,将 Category 中的实例方法列表、协议列表、属性列表添加到主类中后(所有Category中的方法在方法列表中的位置是在主类的同名方法之前的),然后会递归调用所有类的 load 方法,这一切都是在main函数之前执行的。

    3、分类可以添加哪些内容?

    实例方法,类方法,属性(添加getter和setter方法,并没有实例变量,添加实例变量需要用关联对象)

    4、如果工程里有两个分类A和B,两个分类中有一个同名的方法,哪个方法最终生效?

    取决于分类的编译顺序,最后编译的那个分类的同名方法最终生效,而之前的都会被覆盖掉(这里并不是真正的覆盖,因为其余方法仍然存在,只是访问不到,因为在动态添加类的方法的时候是倒序遍历方法列表的,而最后编译的分类的方法会放在方法列表前面,访问的时候就会先被访问到,同理如果声明了一个和原类方法同名的方法,也会覆盖掉原类的方法)。

    5、如果声明了两个同名的分类会怎样?

    会报错,所以第三方的分类,一般都带有命名前缀

    6、分类能添加成员变量吗?

    不能。只能通过关联对象(objc_setAssociatedObject)来模拟实现成员变量,但其实质是关联内容,所有对象的关联内容都放在同一个全局容器哈希表中:AssociationsHashMap,由AssociationsManager统一管理。

    二、扩展(Extension)

    1、扩展的作用?

    声明私有属性,声明私有成员变量

    2、扩展的特点?

    编译时决议,只能以声明的形式存在,多数情况下放在在宿主类的.m中,不能为系统类添加扩展

    三、代理(Delegate)

    代理是一种设计模式,委托方声明协议,定义需要实现的接口,代理方按照协议实现方法

    一般用weak来避免循环引用

    四、通知(NSNotification)

    使用观察者模式用于实现跨层传递信息的机制。传递方式是一对多。

    五、KVO(key-value-observing)

    KVO是观察者的另一实现

    使用了isa混写(isa-swizzling)来实现KVO

    使用setter方法改变值KVO会生效,使用KVC改变值KVO也会生效,因为KVC会调用setter方法

    - (void)setValue:(id)value {
        [self willChangeValueForKey:@"key"];
        [super setValue:value];
        [self didChangeValueForKey:@"key"];
    }

    直接赋值成员变量不会触发KVO,因为不会调用setter方法,需要加上willChangeValueForKey和didChangeValueForKey

    六、KVC(key-value-coding)

    KVC可以通过key直接访问对象的属性,或者给对象的属性赋值,这样可以在运行时动态的访问或修改对象的属性

    当调用setValue:属性值 forKey:@”name“的代码时,,底层的执行机制如下:

    1、程序优先调用set<Key>:属性值方法,代码通过setter方法完成设置。注意,这里的<key>是指成员变量名,首字母大小写要符合KVC的命名规则,下同

    2、如果没有找到setName:方法,KVC机制会检查+ (BOOL)accessInstanceVariablesDirectly方法有没有返回YES,默认该方法会返回YES,如果你重写了该方法让其返回NO的话,那么在这一步KVC会执行setValue:forUndefinedKey:方法,不过一般开发者不会这么做。所以KVC机制会搜索该类里面有没有名为<key>的成员变量,无论该变量是在类接口处定义,还是在类实现处定义,也无论用了什么样的访问修饰符,只在存在以<key>命名的变量,KVC都可以对该成员变量赋值。

    3、如果该类即没有set<key>:方法,也没有_<key>成员变量,KVC机制会搜索_is<Key>的成员变量。

    4、和上面一样,如果该类即没有set<Key>:方法,也没有_<key>和_is<Key>成员变量,KVC机制再会继续搜索<key>和is<Key>的成员变量。再给它们赋值。

    5、如果上面列出的方法或者成员变量都不存在,系统将会执行该对象的setValue:forUndefinedKey:方法,默认是抛出异常。

    如果想禁用KVC,重写+ (BOOL)accessInstanceVariablesDirectly方法让其返回NO即可,这样的话如果KVC没有找到set<Key>:属性名时,会直接用setValue:forUndefinedKey:方法。

    当调用valueForKey:@”name“的代码时,KVC对key的搜索方式不同于setValue:属性值 forKey:@”name“,其搜索方式如下:

    1、首先按get<Key>,<key>,is<Key>的顺序方法查找getter方法,找到的话会直接调用。如果是BOOL或者Int等值类型, 会将其包装成一个NSNumber对象

    2、如果上面的getter没有找到,KVC则会查找countOf<Key>,objectIn<Key>AtIndex或<Key>AtIndexes格式的方法。如果countOf<Key>方法和另外两个方法中的一个被找到,那么就会返回一个可以响应NSArray所有方法的代理集合(它是NSKeyValueArray,是NSArray的子类),调用这个代理集合的方法,或者说给这个代理集合发送属于NSArray的方法,就会以countOf<Key>,objectIn<Key>AtIndex或<Key>AtIndexes这几个方法组合的形式调用。还有一个可选的get<Key>:range:方法。所以你想重新定义KVC的一些功能,你可以添加这些方法,需要注意的是你的方法名要符合KVC的标准命名方法,包括方法签名。

    3、如果上面的方法没有找到,那么会同时查找countOf<Key>,enumeratorOf<Key>,memberOf<Key>格式的方法。如果这三个方法都找到,那么就返回一个可以响应NSSet所的方法的代理集合,和上面一样,给这个代理集合发NSSet的消息,就会以countOf<Key>,enumeratorOf<Key>,memberOf<Key>组合的形式调用。

    4、如果还没有找到,再检查类方法+ (BOOL)accessInstanceVariablesDirectly,如果返回YES(默认行为),那么和先前的设值一样,会按_<key>,_is<Key>,<key>,is<Key>的顺序搜索成员变量名,这里不推荐这么做,因为这样直接访问实例变量破坏了封装性,使代码更脆弱。如果重写了类方法+ (BOOL)accessInstanceVariablesDirectly返回NO的话,那么会直接调用valueForUndefinedKey:方法,默认是抛出异常

    七、属性关键字

    1、读写权限:readonly,readwrite(默认)

    2、原子性:(atomic),nonatimic。atomic读写安全,但效率低,不是绝对的安全,比如操作数组,增加或移除,这种情况可以使用互斥锁来保证线程安全

    3、引用计数

    retain/strong

    assign修饰基本数据类型

    weak不改变修饰对象的引用计数,对象释放后,weak指针自动置为空

    copy分深拷贝和浅拷贝

    浅拷贝,对象指针的复制,目标对象指针和源对象指针指向同一块内存空间,引用计数增加

    深拷贝,对象内容的复制,开辟一块新的内存空间

    可变的对象的copy和mutableCopy都是深拷贝

    不可变对象的copy是浅拷贝,mutable是深拷贝

    copy方法返回的都是不可变对象

    @property (nonatomic, copy) NSMutableArray * array;这样使用会crash,因为copy的对象是不可变的

    NSString使用copy修饰不用strong修饰,用strong修饰一个name属性,如果赋值的是一个可变对象,当可变对象的值发生改变的时候,name的值也会改变,这不是我们期望的,是因为name使用strong修饰后,指向跟可变对象相同的一块内存地址,如果使用copy的话,则是深拷贝,会开辟一块新的内存空间,因此可变对象值变化时,也不会影响name的值。

     

     

    展开全文
  • iOS面试

    2020-05-21 18:08:43
    文章目录1.关于简历[2.iOS面试要求( 20K-60K,总结腾讯,阿里和今日头条等的招聘信息)]...2.iOS面试要求( 20K-60K,总结腾讯,阿里和今日头条等的招聘信息) ...
  • iOS 2019 最新面试题集锦

    千次阅读 2019-03-31 12:03:03
    一、 js 与 原生OC交互方式: ...在iOS 7 之后Apple添加了一个新的库JavaScriptCore,用来做js交互。 首先导入JavaScriptCore 库,然后在OC 中获取上下文对象。在定义好JS需要调用的方法。JSContext对象conte...
  • iOS面试题(七)

    千次阅读 2019-08-08 16:22:40
    (1)get是从服务器上获取数据,post是向服务器传送数据。 (2)在客户端,Get方式在通过URL提交数据,数据在URL中可以看到;... (3)对于get方式,服务器端用Request.QueryString获取变量的值,对于post方式,服务器...
  • iOS 面试题汇总

    万次阅读 2019-07-17 17:06:21
    1. 简单介绍下NSURLConnection类及+ sendSynchronousRequest:returningResponse:error:与– initWithRequest:delegate:两个方法的区别? 答: NSURLConnection主要用于网络访问,其中+ sendSynchronousRequest:...
  • 2019iOS面试题大全

    2020-07-30 23:30:03
    2019iOS面试题大全,包含100多道题,覆盖面试需要的各个方面
  • iOS基础面试题(一)

    万次阅读 多人点赞 2016-03-23 18:19:35
    kaikaijia同学私信我,说...iOS面试题系列: iOS面试题(二) iOS面试题(三) iOS面试题(四) 随着iOS平台开发的职位的增加,笔试、面试也越来越有“套路”,这里我总结了一些面试题,多数是Objective-C的基础知识,适
  • C语言基础19-21天。其中包括property、继承多态、《购票系统》。
  • C语言基础1-2天。其中包括开发概述及简单语法。
  • 本课程主要介绍了开发iOS app的一些基本情况。例如,需要的硬件和软件条件,如何申请开发者账号,XCode的常用功能介绍。后给出一个iOS App的案例来演示开发App的过程。
  • 小波说雨燕 第五季 Core Data实战

    万人学习 2019-06-26 11:52:34
    小波带你从新手角度,啃读原版英文ios8 +swift教材 课程素材免费下载
  • C语言基础7-8天。知识点回顾、初识数组与排序。
  • C语言基础3-4天。其中包括运算符和判断语句。
  • 老镇讲堂-Swift动画编程指南

    万人学习 2019-06-24 11:58:56
    掌握Swift动画编程
  • 从零练就iOS高手实战班

    万人学习 2018-10-22 21:38:03
    iOS课程教学从入门到实战,系统讲解Swift编程,精讲基础语法,详解iOS基础框架,知识点涵盖新潮实用的swift,AppleWatch App开发。 咨询QQ:2528047463 咨询群:462917576 付费学员答疑群:446896569
  • iOS基础面试题(四)

    万次阅读 2013-11-27 10:33:57
    iOS面试题系列: iOS面试题(一) iOS面试题(二) iOS面试题(三) 1 谈谈对Block 的理解?并写出一个使用Block执行UIVew动画? 答案:Block是可以获取其他函数局部变量的匿名函数,其不但方便开发,并且可以...
  • C语言基础5-6天。其中包括循环的应用和有参和无参函数。
1 2 3 4 5 ... 20
收藏数 28,720
精华内容 11,488
关键字:

ios面试