字节跳动:2019秋招 后端开发工程师 一面

具体问题

  • 编程题:链表加法
    与这个题目类似:add-two-numbers,但是给出的两个数和计算的结果是正向的:链表头部就是最高位,尾部才是个位。

譬如135+25=160

input:
1->3->5
2->5
output:
1->6->0

当时思路:直接使用两个栈来存储两个链表,再每次从栈顶取元素相加。

面试官:能否只使用一个栈实现?

一个栈+递归??
存疑。

  • TCPUDP区别
    | 协议 | 是否面向连接 | 传输可靠性 | 传输形式 | 传输速率 | 所需资源 |
    | :----: | ---- | ---- | ---- | ---- | ---- |
    | TCP | 面向连接 | 可靠 | 字节流 | 慢 | 多 |
    | UDP | 不面向连接 | 不可靠 | 数据报文段 | 快 | 少 |

  • UDP最大数据报文长度
    UDP最大数据报文长度 = IP数据报的最大报文长度(65535字节) - IP首部(20字节) - UDP首部(8字节)

  • 介绍TCP拥塞控制
    慢开始、拥塞避免、快重传、快恢复。

  • 内核态与用户态的区别
    权限不同
    内核态:可以执行特权指令非特权指令
    用户态:仅能执行非特权指令

百度百科:特权指令
常见的特权指令有以下几种:
(1)有关对I/O设备使用的指令 如启动I/O设备指令、测试I/O设备工作状态和控制I/O设备动作的指令等。
(2)有关访问程序状态的指令 如对程序状态字(PSW)的指令等。
(3)存取特殊寄存器指令 如存取中断寄存器、时钟寄存器等指令。
(4)其他指令。

  • 内核态与用户态如何切换

用户态->内核态
切换过程中会用到 访管指令非特权指令,因为需要在用户态使用)

  • 系统调用,即用户程序要求操作系统的服务
  • 中断
  • 异常
  • 用户程序企图执行特权指令

内核态->用户态

  • 中断返回指令(特权指令,因为只能在内核态调用)

  • 介绍TIME_WAIT状态
    等待时间:2*MSL
    原因:确保连接的被动结束方(简称B)能够收到主动结束方(简称A)ACK报文。
    如果B没收到,则会重新发送FIN报文。丢失ACK的传输时间加上重发FIN传输的时间约为2*MSL

  • 局域网内不同设备发送消息的冲突如何处理
    主要考点:CSMA/CD协议

载波监听:不管在发送前,还是发送中,每个主机都必须不停地检测信道。
碰撞检测:边发送边监听。

当检测到冲突时,就立即停止发送,面的继续进行无效的发送,白白浪费网络资源,然后等待一段随机时间后再次发送。

使用 截断二进制指数退避 算法来确定重传时间:
每次从离散的整数集合[0,1,……,(2^{\min(重传次数,10)} -1)]中随机取一个数,记为r。重传推后的时间就是r倍的争用期。

参考:

  • 介绍HashMap的数据结构
    数组、链表、红黑树。

  • 如何设计一个支持并发的HashMap
    参考ConcurrenHashMapSynchronizedHashMap的实现。

  • 除了链表和红黑树,还可以如何处理Hash冲突
    公共溢出区、再哈希、顺序寻址(线性探测、二次探测、伪随机数)。

  • 使用再哈希处理哈希碰撞时,查找时如何区分使用的哪一个哈希算法
    当时回答的是,依次与每一个Hash算法计算的哈希值所在位置存储的数据进行equals比较,直到找到 或者 所有hash函数都比较完且不存在。
    不存在的判定条件应该是所有hash函数都比较完,而不应该是某一个hash值所在位置为空就停止:有可能为空的位置在当前查找的元素插入时存在,所以发生冲突继续使用后续的hash函数计算,而查找时那个位置的元素已被移除。

存疑

  • 介绍一下原子类
    对原子类的操作都具有原子性,即不可再拆分。

  • 原子操作的实现原理

参考:
聊聊并发(五)——原子操作的实现原理
原子操作是如何实现的? #3

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,937评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,503评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,712评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,668评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,677评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,601评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,975评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,637评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,881评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,621评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,710评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,387评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,971评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,947评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,189评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,805评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,449评论 2 342

推荐阅读更多精彩内容

  • Java基础 类加载的时机和类初始化的时机(引出tomcat类加载器)JVM和绝大多数用户自定义的类在JVM启动的...
    fanyank阅读 2,218评论 0 33
  • 一、Linux系统概述 不加引号可理解为宏,直接替换,单引号中特殊字符会被解释为普通字符,双引号中$,,'还是特殊...
    赤果_b4a7阅读 1,464评论 0 2
  • 本系列出于AWeiLoveAndroid的分享,在此感谢,再结合自身经验查漏补缺,完善答案。以成系统。 Java基...
    济公大将阅读 1,523评论 1 6
  • 包含的重点内容:JAVA基础JVM 知识开源框架知识操作系统多线程TCP 与 HTTP架构设计与分布式算法数据库知...
    消失er阅读 4,293评论 1 10
  • 想要的太多了,精力有点跟不上了,该怎么办? 刚刚参加完一个活动回来,已经将近午夜了,还有好多的事没有办呢,明天还要...
    超级赋能王张胜萍阅读 548评论 7 10