好未来| IM平台| 一二面| Go社招

alt

技术体系-数字效能部-知音楼-golang开发工程师

一面 8.14

  1. 自我介绍
  2. Golang
    1. GMP的调度器原理及怎么工作的
    2. 开发的时候需要控制goroutine的数量,避免调度的开销或者内存的增大,通过哪些机制可以避免或限制
    3. 垃圾回收简单介绍一下机制
    4. gin框架
      1. 介绍一下路由机制,或者举个例子
      2. 用没用过他的中间件,或者自己写过中间件吗,在你的业务里,比如说鉴权啊等
  3. 项目
    1. go+mysql重构中台系统,初衷是什么?当时为什么要重构,遇到了什么问题吗?有哪些优势
    2. 升级的过程中,有没有遇到数据迁移,从mongo迁移到mysql这块有做吗,怎么做的?
    3. 像你们迁移的时不是一到切的吧,这中间会产生新的数据,这个增量数据这块,你们是怎么处理的
    4. 迁的时候流量分发这块考虑了没有,服务升级可能会遇到新老服务的兼容,可能需要并行的去跑新老服务,这块你们有做流量的分发或者转发吗?比如说我们上新的服务的时候可能前期的话会逐步的去放量5%,10%这种?
    5. 负载均衡这块怎么做的?是在服务器网关这块去做还是怎么做的?
    6. 分布式缓存怎么理解?引入分布式缓存会设计到数据一致性的问题,在不同的节点上都会有缓存
    7. 渠道数据抓取,是抓哪里的数据?
      1. 数据的准确性完整性这是怎么做的?有核对核销还是怎么?
      2. 过程中有没有遇到数据对不上的,怎么解决的?数据的准确性确实非常关键和重要
  4. mysql
    1. 介绍一下事务的隔离级别
    2. 常用的是哪种级别
    3. b+树的特点或者优势介绍一下
    4. 有没有做过sql的优化?比如通过哪些方面去优化一个sql(索引,查询)
  5. kafka
    1. 用消息队列的一些场景和优势
    2. kafka的生产者,消费者的原理了解过吗,简单的介绍一下对kafka的理解
    3. 选举这一块了解过吗
  6. clickhouse
  7. rpc
    1. 原理和使用rpc的优势
    2. 底层通信协议是什么协议
    3. 你们rpc服务这一块的服务注册发现是怎么做的
  8. redis
    1. 数据类型简单介绍一下,以及常用的
    2. 你们用redis做缓存还是持久化还是都有
    3. 持久化机制简单介绍一下
  9. 程序题:实现一个简单的并发计数器 请编写一个Go程序,实现一个线程安全的计数器。要求如下: 提供增加计数的方法 Increment() 提供获取当前计数值的方法 Value() 要求: 使用Go语言内置的并发机制(如goroutines和channels)或互斥锁(sync.Mutex)来确保计数器在多线程环境下是线程安全的
package main

import (
    "fmt"
    "sync"
)

// Counter 是一个线程安全的计数器结构体
type Counter struct {
    mu    sync.Mutex
    count int
}

// Increment 增加计数
func (c *Counter) Increment() {
    c.mu.Lock()   // 加锁,确保线程安全
    c.count++     // 增加计数
    c.mu.Unlock() // 解锁
}

// Value 获取当前计数值
func (c *Counter) Value() int {
    c.mu.Lock()         // 加锁,确保读取时的线程安全
    defer c.mu.Unlock() // 使用 defer 语句确保方法结束时解锁
    return c.count
}

func main() {
    counter := &Counter{}

    var wg sync.WaitGroup

    // 启动多个 goroutine 并发地增加计数器
    for i := 0; i < 1000; i++ {
        wg.Add(1)
        go func() {
            defer wg.Done()
            counter.Increment()
        }()
    }

    wg.Wait() // 等待所有 goroutine 完成

    fmt.Println("Final Counter Value:", counter.Value())
}

  1. 反问
    1. 知音楼团队-IM系统(类似于钉钉和飞书),做一些ai赋能提供工资效率,数字化伙伴和机器人,集团知识库的落地,低代码平台,Golang + Python
    2. 最近刚搬到朱辛庄
    3. 会评估一下,面试需要几轮,到时候再看

二面 8.15

  1. 共享屏幕手撕 leetcode 中等 53. 最大子数组和
func maxSubArray(nums []int) int {
    if len(nums) == 0 {
        return 0
    }
    localMax := nums[0]
    globalMax := nums[0]

    for i := 1; i < len(nums); i++ {
        // 判断是开始一个新的子数组还是从上一个子数组中继续
        localMax = max(nums[i], localMax+nums[i])
        // 更新全局最大和
        globalMax = max(globalMax, localMax)
    }
    return globalMax
}

func max(a, b int) int {
    if a > b {
        return a
    }
    return b
}

func main() {
    nums := []int{1, -2, 3, 10, -4, 7, 2, -5}
    fmt.Println("最大子数组和为:", maxSubArray(nums))
}
  1. 自我介绍
  2. 对好未来了解有多少
  3. 现在看过哪些公司了,那边面试怎么样,有多久了
  4. 你不会被裁吗?
  5. 项目
    1. 抽卡卡池缓存系统
    2. 游戏服务器这块用的实体机、虚拟机还是容器
    3. 容器应该不只一个吧,应该有多个吧?
    4. 多个pod的话,卡都写到内存里,抽的时候怎么保证本地内存里的数据几个pod之间数据协同的,比如说这个pod减,那边pod跟这减
    5. 接口每天的请求量多少
    6. 你觉得这个事情对你个人成长比较快是为什么?
  6. redis
    1. 常用的数据结构和应用的场景
    2. 两种持久化方式有什么不同,优缺点
  7. mysql
    1. 逻辑架构
    2. b+树 数据结构还有什么优势?
    3. 叶子节点仅保存索引,不存储实际数据,使得b+树的高度更低,为什么数据从子节点放到叶子节点会使这个树的高度变低
  8. 跨渠道数据抓取,采用了什么方法来确保数据抓取的准确性和完整性呢?
  9. 准确性和完整性怎么做的?怎么保证的?
  10. 反问
#好未来##Golang社招##二面##主管面##牛客在线求职答疑中心#
全部评论
不愧是社招。。。
2 回复 分享
发布于 08-21 14:07 北京
佬有offer了吗 关注好久了
点赞 回复 分享
发布于 08-21 18:23 广东
好未来oc了嘛?
点赞 回复 分享
发布于 09-27 17:30 广东
mark
点赞 回复 分享
发布于 11-05 11:20 台湾

相关推荐

最近又搬回宿舍了,在工位坐不住,写一写秋招起伏不断的心态变化,也算对自己心态的一些思考表演式学习从开始为实习准备的时候就特别焦虑,楼主一开始选择的是cpp后端,但是24届这个方向已经炸了,同时自己又因为本科非92且非科班,所以感到机会更加迷茫。在某天晚上用java写出hello&nbsp;world并失眠一整晚后选择老本行干嵌入式。理想是美好的,现实情况是每天忙但又没有实质性进展,总是在配环境,调工具,顺带还要推科研。而这时候才发现自己一直在表演式学习,徘徊在设想如何展开工作的循环里,导致没有实质性进展。现在看来当时如果把精力专注在动手写而不是两只手端着看教程,基本功或许不会那么差。实习的焦虑5月,楼主...
耶比:哲学上有一个问题,玛丽的房间:玛丽知道眼睛识别色彩的原理知道各种颜色,但是她生活在黑白的房间里,直到有一天玛丽的房门打开了她亲眼看到了颜色,才知道什么是色彩。我现在最大可能的减少对非工作事情的思考,如果有一件事困扰了我, 能解决的我就直接做(去哪里或者和谁吵架等等……),解决不了的我就不想了,每一天都是最年轻的一天,珍惜今天吧
投递比亚迪等公司10个岗位 > 秋招被确诊为…… 牛客创作赏金赛
点赞 评论 收藏
分享
10-15 10:57
已编辑
武昌理工学院 FPGA工程师
狠赚笔第一人:老哥学院本没实习还想拿13k学Java狠赚笔呢
点赞 评论 收藏
分享
评论
8
29
分享
牛客网
牛客企业服务