腾讯视频 一面

面试官: 自我介绍?

面试官: 项目相关的问题?

面试官: 可以简单地介绍一下HTTPS是如何实现的吗?

: HTTPS在HTTP的基础上增添了SSL/TLS协议来保障数据的安全传输。它与HTTP的区别在于,首先进行加密以保证数据不被窃取,然后通过SSL证书认证来防止中间人攻击,最后添加一些对话密钥和签名来确保数据的完整性。主要使用了非对称加密算法和对称加密算法来实现加密的手段。非对称加密需要公钥和私钥,安全性比对称加密高,但效率较低。对称加密协商一个密钥后,传输效率较高。HTTPS首先建立非对称加密算法来协商密钥,然后在TCP传输中使用该密钥提高效率,并持续进行对称加密。此外,HTTPS会进行SSL证书验证,确保服务器连接的可靠性。

面试官: 除了使用MD5加密外,你了解到还有其他常用的加密手段吗?

: 除了MD5加密外,常用的加密手段还有MD5、SHA-1、SHA-256等哈希加密算法。MD5加密是可逆的,但不安全,容易受到彩虹表攻击。而SHA系列算法则是不可逆的,更安全。另外,还有加盐算法,即在加密前对数据添加特定字符,增加安全性,防止直接对比。此外,Bcrypt加密是一种密码哈希函数,用于加密密码和验证用户身份。它采用了逐渐变慢的哈希算法,可以有效地抵御暴力破解和彩虹表攻击。

面试官: 可以讲讲浏览器访问过程中的一些加密细节吗?

: 当浏览器访问一个HTTPS网站时,首先会进行所谓的“TLS握手”过程,确保建立起一个安全的连接。这个过程开始于浏览器检查服务器的SSL/TLS证书,该证书由受信任的证书颁发机构(CA)签发。浏览器会验证证书的有效性,包括证书持有者的身份、证书的有效期以及证书的签名。一旦证书验证通过,浏览器和服务器就会协商一个会话密钥,用于接下来的对称加密通信。这个过程通常涉及到非对称加密技术,如RSA或ECC,它们用于安全地交换会话密钥。在会话密钥协商完成后,所有的数据传输都会使用对称加密算法(如AES),这是因为对称加密比非对称加密更快,更适合大量数据的传输。在HTTPS通信中,还会使用哈希函数(如SHA-256)来确保数据的完整性和一致性。服务器会为传输的数据计算哈希值,并发送给客户端。客户端也会独立计算接收数据的哈希值,并通过比较来验证数据在传输过程中是否被篡改。此外,为了提供额外的安全层,HTTPS还使用了消息认证码(HMAC),通常是结合哈希函数使用,以验证消息的完整性和认证消息的发送者。

面试官: 简单地解释一下虚拟内存是如何工作的吗?

: 虚拟内存是一种扩展了物理内存的概念,它允许计算机将硬盘上的一部分空间作为虚拟内存,用于存储暂时不被使用的程序或数据。当程序需要更多内存空间时,虚拟内存会将不常用的数据暂时保存到硬盘上,从而释放出内存空间供其他程序使用。

虚拟内存的工作原理包括以下几个步骤:

  1. 地址映射: 操作系统将每个程序的内存地址映射到物理内存或虚拟内存中的某个位置。程序访问内存时,操作系统会根据映射关系将程序指令或数据加载到内存中。
  2. 页面置换: 当物理内存不足以容纳所有程序的数据时,操作系统会将不常用的页面(内存中的一段数据)转移到硬盘上的虚拟内存中,从而为其他程序释放出空间。这个过程称为页面置换,常用的置换算法包括最近最少使用(LRU)和先进先出(FIFO)等。
  3. 页面调度: 当程序需要访问虚拟内存中的数据时,操作系统会将所需的页面从硬盘上调入内存,并更新地址映射表,以便程序能够正确地访问数据。

虚拟内存的优点在于它可以扩展物理内存的容量,使计算机能够同时运行更多的程序,提高了系统的整体性能和稳定性。然而,虚拟内存也会带来一定的性能开销,因为数据需要在内存和硬盘之间频繁地传输。

面试官: 对于内存管理,你了解的有哪些细节呢?

: 内存管理涉及到操作系统或运行时环境(比如Java的JVM)对内存的分配、使用和释放。在Java中,我们可以通过JVM参数来设置内存分配,比如堆大小、栈大小等。内存主要分为堆和方法区,堆用于存储对象实例,方法区存储类信息、常量池等。每个线程都有自己的栈和本地方法栈,用于方法的执行和数据的存储。内存管理还包括垃圾回收机制,用于回收不再使用的对象,释放内存资源,以提高内存利用率。

面试官: 你能简单地介绍一下对象内存的申请和回收流程吗?

: 当我们在程序中创建对象时,首先需要为对象分配内存空间。在Java中,对象的内存分配是在堆内存中进行的。在对象初始化时,JVM会根据对象的类结构在堆中为其分配内存,并初始化对象的属性。对象在创建后,如果没有任何引用指向它,就会变成不可达状态。垃圾回收器会定期扫描堆内存,标记并清理不可达对象,释放其占用的内存空间。这个过程通常包括标记、清除和整理阶段,确保内存空间的充分利用和碎片的最小化。

面试官: 你觉得Java的自动内存管理和C++的手动内存管理相比有什么优缺点吗?

: 自动内存管理的优点在于它减少了开发人员手动管理内存的工作量,提高了开发效率。由于垃圾回收器能够自动管理内存,程序员可以更专注于业务逻辑的实现,而无需过多考虑内存管理的细节。然而,自动内存管理也存在一些缺点。例如,由于垃圾回收器的运行需要消耗系统资源,可能会导致程序的性能有所下降。此外,无法预测垃圾回收器的执行时机,可能会造成一些不可预见的延迟。相比之下,手动管理内存虽然灵活,但需要程序员自己负责管理内存的分配和释放,容易引发内存泄漏和悬空指针等问题,开发难度较大。

面试官: 现在我们来实现一个多线程环境下的任务执行器,你觉得应该如何设计呢?

: 可以首先设计一个任务队列,用来存放待执行的任务。然后创建多个线程,这些线程会从任务队列中取出任务并执行。任务执行完成后,将结果存放到一个共享的列表中。需要注意的是,在多线程环境下,要确保线程安全,可以使用同步机制或锁来保证共享资源的安全访问。

全部评论
好强
点赞 回复 分享
发布于 04-24 11:16 陕西
点赞 回复 分享
发布于 04-25 15:08 云南
md5不可逆,sha可逆吧
点赞 回复 分享
发布于 05-02 00:28 江苏

相关推荐

HR面完两三个礼拜没消息了 说是已经招满了 后续该志愿不再推进一面:26min,两个面试官 有一个经理。问技术的话全是八股,挺死板的第一个面试官:* 自我介绍* 介绍一下实习* 实习中具体某个印象深刻的功能讲一下* 了解汇川吗?是干什么的* 哪里人? 对找工作地域有要求吗?我们这边有苏州、深圳的岗位 你更偏向于哪里呢?换经理了:问的是技术* 最近都在学什么技术* 平时怎么学习* 遇到困难怎么解决* spring的核心组件讲一下* springmvc的执行流程* 讲一下java中的集合* 具体说一下使用场景* hashmap put流程* 红黑树是什么样的结构?和平衡二叉树的区别* redis怎么保证操作的原子性* mysql索引讲一下* sql:用户表(id  name 身份证),name+身份证可能没有去重,一个sql删除重复的数据* 反问:二面:9.20 HR面试 差不多半小时* 无 自我介绍* 前面面试官也给你讲了一些部门的情况,可能对汇川的大致了解,可能有哪些业务?* HR讲了很多关于公司的情况* 现在还在实习吗?转正情况?(G* 讲讲实习遇到的难点* 实习和非技术人员有过相关沟通吗?有没有遇到什么问题点,并且去解决的过程?* 3头牛 过河 分别话费 1 2 5 分钟,一次可以骑上一头,赶着一头。把所有牛赶过去 赶回来最少花费的时间?* 工作后对个人方面想有哪些提升、问职业规划* 期望薪资* 有女朋友吗?* 工作地点期望?反问:* 后续的大致流程?---总监面试* 工作地点选择---苏州、深圳(目前入职基本就是苏州了,人员都在从深圳往苏州转移
查看28道真题和解析
点赞 评论 收藏
分享
10 53 评论
分享
牛客网
牛客企业服务