字节跳动面试经历及面试题.docx
字节跳动面试经历及面试题面试经历双方定好的时间内,经过漫长的等待,终于迎来了面试时间,心情无比紧张和忐忑不安。我打开邮箱,点进去了那个面试链接,在进入前就想提前5分钟进入飞书找找状态,没想到一进去之后面试官就已经早早在电脑面前静静的等候着了,一下子心情更紧张起来了(不得不说面试官长得跟王思聪有一些相似)。面试官首先上来问了一下是张童瑶吗,我说是的那咱们等一下时间后,就开始吧,我说好的。“你先做一下自我介绍。在我的一阵叭叭的自我介绍后,面试官又把自己介绍了一下和公司也介绍了一下。在双方互相了解之后,就开始了紧张又刺激的技术面试。当时面试题:说一说Java中的Lock类1.ock是java.util.concurrent.locks包下的接口,LOCk实现提供了比synchronized关键字更广泛的锁操作,它能以更优雅的方式处理线程同步问题。LOCk提供了比SynChrOniZed更多的功能。https访问过程首先,https是一种加密协议,http的升级版,默认https端口是443,通过服务器上的相应证书拿到私钥后解密,访问。从本地hosts寻找相关dns服务器地址,没有的话则回去当前网络配置的dns找服务器,默认dns服务器一般都是144.144.144.144或者8.888,找到相应服务器首先回到dns缓存服务器寻找缓存,没有的话会到dns递归服务器通过递归轮询方式一次一次找到最低级域的ip,拿着ip去找dns授权服务器去授权,最终存入缓存返给用户ip地址,用户机器拿到ip地址后,通过访问服务器ip并且携带https或者http请求头,服务器ip拦截到请求和端口后寻找相应应用服务器的地址并且执行相应服务器代码信息后返回最终数据到用户浏览器渲染。springboot和spring运行效率答案暂不补充,尝试自己寻找答案比看我解释的更详细,更好。SPringbOOtStaer启动器,就是为什么引入POm包,jar包就跟随main启动了答案暂不补充,尝试自己寻找答案比看我解释的更详细,更好。nacos注册不进去如何排查问题,又根据什么关键字?首先检查Nacos版本和当前SpringCIoud版本是否兼容、检查Nacos版本依赖是否注入、检查本地或NaCoS程序是否启动、检查NaCoS地址是否正确、查看项目中NaeoS账号密码等相关配置是否正确。再然后可以根据debug调试,跟着代码一步一步走,看为什么注册不进去,首先Nacos官网都是有相关的OPenApi的,客户端注册服务核心原理就是首先通过相关方法和类,获取当前项目中的Nacos配置信息,再然后通过拼接的方式拼成一个相应的注册服务OPenAPi,使用http请求OPenApi完成服务的注册。(还好之前看过nacos注册服务源码-)redis主从复制主从复制,是指将一台Redis服务器的数据,复制到其他的Redis服务器。前者称为主节点(master),后者称为从节点(SlaVe),数据的复制是单向的,只能由主节点到从节点。默认情况下,每台RediS服务器都是主节点;且一个主节点可以有多个从节点(或没有从节点),但一个从节点只能有一个主节点。微服务你是怎么用的,多深答案暂不补充,按自己对微服务理解回答,没有准确答案。ArrayList和LinekdList有什么区别,详细说一下;1.inkedeList和ArrayList是常用的两种存储结构,都可以实现了List接o1、数据结构不同ArrayList是Array(动态数组)的数据结构,LinkedList是Link(链表)的数据结构。2、效率不同当随机访问List(get和set操作)时,ArrayList比LinkedList的效率更高,因为LinkedLiSt是线性的数据存储方式,所以需要移动指针从前往后依次查找。当对数据进行增加和删除的操作(add和remove操作)时,LinkedList比ArrayList的效率更高,因为ArrayList是数组,所以在其中进行增删操作时,会对操作点之后所有数据的下标索引造成影响,需要进行数据的移动。3、自由性不同ArrayLiSt自由性较低,因为它需要手动的设置固定大小的容量,但是它的使用比较方便,只需要创建,然后添加数据,通过调用下标进行使用;而LinkedLiSt自由性较高,能够动态的随数据量的变化而变化,但是它不便于使用。4、主要控件开销不同ArrayList主要控件开销在于需要在IList列表预留一定空间;而LinkList主要控件开销在于需要存储结点信息以及结点指针信息。如果springboot没有tomcat怎么解决。有2中tomcat配置方法第一种:在IDEA中配置本机的Tomcat第二中:在Springboot项目中通过tomcat依赖,配置内置的tomcatspringboot内置tomcat怎么配置通过加入tomcat依赖包,等待依赖引入完成后,完成tomcat的配置,在项目中还可以配置tomcat端口、路径前缀和本地tomcat能配置的配置。为什么说线程不安全线程在同一时间操作修改一条数据后,就会造成线程同时争夺资源,所以线程不安全。具体详细请查找答案。进程和线程区别,JVM内存中的区别只留问题,答案暂不补充,尝试自己寻找答案比看我解释的更详细,更好。JVM内存堆分区块都有哪些方法区、堆、虚拟机栈、本地方法栈、程序计数器。具体详细请查找答案。spring、springmvc>SPringbOOt了解多少答案暂不补充,按自己对微服务理解回答,没有准确答案。spring和springboot有什么区别和联系只留问题,答案暂不补充,尝试自己寻找答案比看我解释的更详细,更好。笔试题聊完技术,又说让我们做几道题吧",我说行(其实之前就有做算法功课)。1、M叩时间过期,怎么用IrU算法实现没写出来,具体题目忘了,有知道的可以在评论区留言互相讨论2、链接3个链表合成一个链表并且排序题目:题目:给你一个链表数组,每个链表都已经按升序排列。请你将所有链表合并到一个升序链表中,返回合并后的链表。示例1:输入:lists=1,4,5,1,3,4,2,6输出:1,1,2,3,4,4,5,6解释:链表数组如下:l->4->5zl->3->4z2->6将它们合并到一个有序链表中得到。ll->23->4->4->56摘自力扣答案:/优先队歹UPUbIiCListNodemergeKLists(ListNodelists)/边界情况考虑if(lists.length=O)returnnull;Queue<ListNode>heap=newPriorityQueueO(ListNodea,ListNodeb)->(a.val-b.val);for(inti=0;i<lists.length;i+)1.istNodecurHead=listsi;while(curHead!=null)heap.offer(curHead);curHead=curHead.next;1.istNodehead=heap.poll();1.istNodenode=head;while(!heap.isEmpty()node.next=heap.poll();node=node.next;)/把链表中的环去掉,同时考虑(的情况if(node!=null)node.next=null;returnhead;)最后总之唠了很多,大概1小时的样子,有很多都想不起来了,核心的记得无比清楚。不过最终面试官反响还是挺好的。最后又问了个学历问题(本人也知道自己学历一般)。不清楚是不是学历问题,最终没有进入到二面,不管怎么说继续努力提升自己吧!