面试

网易云音乐面试总结

2018-04-16  本文已影响1022人  齐舞647

首先,很感谢网易小哥哥,我又发现了我的知识储备不足的地方,这篇Blog记录我平时学习的盲点,并希望自己不断进步。
有几个问题没答上来,这里详细记录一下。

1.block的内存数据类型是什么?block和函数有什么区别?使用block需要注意什么?

struct Block_descriptor {
    unsigned long int reserved;
    unsigned long int size;
    void (*copy)(void *dst, void *src);
    void (*dispose)(void *);
};

struct Block_layout {
    void *isa;
    int flags;
    int reserved; 
    void (*invoke)(void *, ...);
    struct Block_descriptor *descriptor;
    /* Imported variables. */
};

很显然是个结构体,里面有一个isa指针,指向了自己的类。还有一个函数指针,指向block代码块。
使用block需要注意两点:

  • 一个是变量传递到block结构体中,仅仅是值传递,所以在block中修改变量是不会影响到外面的变量的。
    只有加上了__block关键字,才可以改变外部的变量。(有点类似于C++函数里,实参和形参的区别)
  • 另一个是防止block对self持有,造成循环引用->内存泄漏。解决方法:在外面__weak一下self,再在block内部__strong一下self。

2.HTTPS和HTTP的差别在哪?有什么改进和优点。

超文本传输协议HTTP协议被用于在Web浏览器和网站服务器之间传递信息。HTTP协议以明文方式发送内容,不提供任何方式的数据加密,如果攻击者截取了Web浏览器和网站服务器之间的传输报文,就可以直接读懂其中的信息,因此HTTP协议不适合传输一些敏感信息,比如信用卡号、密码等。
为了解决HTTP协议的这一缺陷,需要使用另一种协议:安全套接字层超文本传输协议HTTPS。为了数据传输的安全,HTTPS在HTTP的基础上加入了SSL/TLS协议,SSL/TLS依靠证书来验证服务器的身份,并为浏览器和服务器之间的通信加密。

HTTPS和HTTP的区别主要为以下四点:

总结:HTTPS = HTTP + SSL / TLS
SSL 握手验证协议
TLS 安全传输协议
实现了加密和身份认证
用到了非对称加密(公钥、私钥)、CA证书=>为了验证公钥是否伪造
HTTPS是以安全为目标的HTTP通道,简单的讲是HTTP的安全版
HTTP没有任何的加密以及身份验证机制,很容易被窃听、篡改。
因此会造成个人隐私泄露、恶意的劫持等严重的安全问题。

3.三次握手协议:

三次握手

4.iOS事件传递的过程(事件响应呢??)参考资料

过程:
->产生触摸事件UIEvent
->UIApplication事件队列
->[UIWindow hitTest:withEvent:]
->返回更合适的view
->[子控件 hitTest:withEvent:](有就继续调用hitTest,没有更合适的就返回自身。。。进入递归遍历状态。。)
->返回最合适的view

hitTest解释:事件传递给窗口或控件的后,就调用hitTest:withEvent:方法寻找更合适的view。所以是,先传递事件,再根据事件在自己身上找更合适的view。
不管子控件是不是最合适的view,系统默认都要先把事件传递给子控件,经过子控件调用自己的hitTest:withEvent:方法验证后才知道有没有更合适的view。即便父控件是最合适的view了,子控件的hitTest:withEvent:方法还是会调用,不然怎么知道有没有更合适的!即,如果确定最终父控件是最合适的view,那么该父控件的子控件的hitTest:withEvent:方法也是会被调用的。

5.事件的响应:实际上是事件传递的逆过程 通过不断向上传递,将试图展示给用户

事件响应链

6.AFN3.0和2.0差别在哪里?
https://blog.csdn.net/u012411480/article/details/51678472

上一篇 下一篇

猜你喜欢

热点阅读