菜鸟补录面试 & 知乎一面(golang开发)分享

菜鸟补录 & 知乎一面

  • 1. 菜鸟补录面试
    • 1)实习经历
    • 2)项目中redis使用了哪些数据结构?哪些场景下用了什么数据结构?怎么考虑的?
    • 3)项目中缓存同步怎么实现的?
    • 4)接上题,如果在业务中采用异步机制的方式进行缓存同步有哪些问题?
    • 5)Rabbitmq是如何确保消息的不丢失?
    • 6)Rabbitmq如何避免消息堆积问题?
    • 7)Redis分布式锁的底层原理是什么?
    • 8)场景题:分布式集群下有32台redis(主从集群),其中一台redis宕机了,会发生什么问题?一致性Hash的引入解决了什么问题?
    • 9)JDK8的新特性有哪些?
    • 10)JDK8中HashMap的底层实现相比于JDK7做了哪些优化?
    • 11)红黑树的特点?HashMap中为什么使用红黑树?
    • 12)ConcurrentHashMap怎么保证线程安全的?
    • 13)JVM:垃圾回收算法,垃圾回收器,哪些情况下容易发生OOM?如何排查?
    • 14)Java基础:==和equals;封装、继承、多态怎么理解?
    • 15)Spring中IOC的底层过程
    • 16)Sprng中AOP的底层实现
    • 17)singleton和prototype的适用场景有哪些?
    • 18)Http的请求方式有哪些?
    • 19)GET请求和POST请求有哪些区别?对于大数据量的请求使用哪种更好?
    • 20)TCP三次握手过程?为什么使用三次握手而不是两次?
    • 21)算法题:上台阶问题(斐波那契数列),口头描述使用递归和非递归的方式
    • 22)闲聊:最近在看哪些技术栈(云原生&golang);评价下自己;手头上有哪些offer?为什么秋招找了8个offer全都拒了?回答:人嘛,总要有点梦想,万一实现了呢?
  • 2. 知乎一面(golang开发)
    • 1) 实习经历
    • 2)Hibernate和mybatis两者的区别是什么?Hibernate的具体使用流程是什么样的?
    • 3)项目中哪些业务场景使用到了redis?项目中提了基于session的共享问题?你是怎么解决的?
    • 4)Redis的常用数据结构,string类型的底层怎么实现的?
    • 5)Redis分布式锁怎么实现的?
    • 6)Java和golang怎么体现面向对象思想的?我从封装,继承,多态三个角度分别进行描述
    • 7)Spring的IOC和AOP底层实现
    • 8)Nginx中的反向代理有哪些规则?在项目中用到了哪些规则?相比于正向代理的区别是什么?
    • 9)Docker容器化是什么?怎么自定义一个镜像上传?dockerfile和compose容器编排了解过吗?
    • 10)Golang的有哪些比较突出的特点?
    • 11)Goroutine是什么?相比于java中线程或者是OS级别的线程有什么区别?
    • 12)GMP模型?
    • 13)Go指令的调度流程是什么样的?

1. 菜鸟补录面试

1)实习经历

2)项目中redis使用了哪些数据结构?哪些场景下用了什么数据结构?怎么考虑的?

3)项目中缓存同步怎么实现的?

我采用的是本地缓存同步(当前微服务的数据库数据与缓存数据同步,可以直接在数据库修改时加入对Redis的修改逻辑,保证数据一致) + 跨服务缓存同步策略(对于服务A调用了服务B,并对查询结果缓存。服务B数据库修改,可以通过rabbitmq通知服务A,服务A修改Redis缓存数据)。另外说了,其实可以使用Canal框架,用来伪装成MySQL的salve节点,监听MySQL的binLog是否变化,然后再去修改Redis缓存数据(但是在项目中没有使用到)

4)接上题,如果在业务中采用异步机制的方式进行缓存同步有哪些问题?

5)Rabbitmq是如何确保消息的不丢失?

6)Rabbitmq如何避免消息堆积问题?

7)Redis分布式锁的底层原理是什么?

8)场景题:分布式集群下有32台redis(主从集群),其中一台redis宕机了,会发生什么问题?一致性Hash的引入解决了什么问题?

9)JDK8的新特性有哪些?

10)JDK8中HashMap的底层实现相比于JDK7做了哪些优化?

11)红黑树的特点?HashMap中为什么使用红黑树?

12)ConcurrentHashMap怎么保证线程安全的?

13)JVM:垃圾回收算法,垃圾回收器,哪些情况下容易发生OOM?如何排查?

14)Java基础:==和equals;封装、继承、多态怎么理解?

15)Spring中IOC的底层过程

16)Sprng中AOP的底层实现

17)singleton和prototype的适用场景有哪些?

18)Http的请求方式有哪些?

19)GET请求和POST请求有哪些区别?对于大数据量的请求使用哪种更好?

20)TCP三次握手过程?为什么使用三次握手而不是两次?

21)算法题:上台阶问题(斐波那契数列),口头描述使用递归和非递归的方式

22)闲聊:最近在看哪些技术栈(云原生&golang);评价下自己;手头上有哪些offer?为什么秋招找了8个offer全都拒了?回答:人嘛,总要有点梦想,万一实现了呢?

反问:多久出通知呢?一个星期后给结果(经典一星期o-o)
总结:回答了9层左右吧,有两个问题没有回答全面。这次面试官比秋招面试好很多,愿意听你说,根据你的回答逐步深入

2. 知乎一面(golang开发)

1) 实习经历

2)Hibernate和mybatis两者的区别是什么?Hibernate的具体使用流程是什么样的?

3)项目中哪些业务场景使用到了redis?项目中提了基于session的共享问题?你是怎么解决的?

4)Redis的常用数据结构,string类型的底层怎么实现的?

5)Redis分布式锁怎么实现的?

6)Java和golang怎么体现面向对象思想的?我从封装,继承,多态三个角度分别进行描述

7)Spring的IOC和AOP底层实现

8)Nginx中的反向代理有哪些规则?在项目中用到了哪些规则?相比于正向代理的区别是什么?

9)Docker容器化是什么?怎么自定义一个镜像上传?dockerfile和compose容器编排了解过吗?

10)Golang的有哪些比较突出的特点?

回答:既有C语言的静态语言程序的运行速度,又能达到Python动态语言的快速开发;自动垃圾回收机制和runtime系统调度机制;强类型和编译性语言,而java是半编译半执行的;不区分平台,运行时不需要依赖外部库;由于goroutine天生支持高并发

11)Goroutine是什么?相比于java中线程或者是OS级别的线程有什么区别?

回答:Go中的并发其实就是函数相互独立运行的能力,Goroutines是一个并发运行的函数。有独立的栈空间,共享程序堆空间,调度由用户自己控制

12)GMP模型?

回答:M代表内核线程,记录内核线程栈信息,当goroutine调度到线程时,使用该goroutine自己的栈信息
P调度器processor,负责调度goroutine,维护一个本地goroutine队列,主线程从调度器上获得goroutine并执行,同时还负责部分内存的管理。(程序启动时创建,P的最大个数由GOMAXPROCS参数来控制)
G表示goroutine,每个goroutine都有自己的栈空间,定时器,初始化的栈空间在2k左右,空间会随着需求增长。
M代表一个工作线程,在M上有一个P和G,P是绑定到M上的,G是通过P的调度获取的,在某一时刻,一个M上只有一个G(g0除外)在P上拥有一个G队列,里面是已经就绪的G,是可以被调度到线程栈上执行的协程,也就是运行队列

13)Go指令的调度流程是什么样的?

回答:

  • 通过 go func() 创建一个goroutine
  • 有两个存储G的队列,一个是局部调度器P的本地协程队列,一个是全局协程队列。新创建的G保存在P的本地队列中,如果P的本地队列已满则保存在全局队列中
  • G只能运行在M中,一个M必须持有一个P。M从本地协程队列中选取一个可执行的G来执行,如果本地队列为空则采用stealing机制从其他协程队列中获取一个G来执行
  • 一个M调度G的执行过程是一个循环机制
    • 当M执行某一个G时发生syscall(系统调用)或者其他阻塞操作,M发生阻塞。如果当前一些G正在执行,runtime会将这个线程M从P中移除,然后创建一个新的内核线程M来执行G(如果有空闲的内核线程可进行复用)
    • 当M系统调用结束时,此时G会尝试获取一个空闲的P执行,放入到P的本地队列中。如果获取不到调度器P,那么线程M则进行休眠,加入到空闲线程队列中,协程G则放入到全局协程队列中

反问:技术面几轮?3轮

你可能感兴趣的:(面试总结,面试,golang,java)