面试复盘7——后端开发

前言

一面(2024-1.25)

首先上来是自我介绍。

(这里自我介绍时候项目只说了技术栈,没有说内容,不知道好不好)

(在校经历说的一点点口语化了)

先问的近期实习经历,和我确认我做的是什么。

实习经历1

1、存到Mysql时候是如何做的格式化?(有无字段提取如何)

有字段提取的实际,从kafka中提取出来来源的信息、目标的信息。(解析json绑定到结构体)

原始存的消息和Mysql存的都是json格式。

Pb+wire,主要是用到了哪些方面?

Mysql存储的消息,是如何制定清理规则。

这个服务的价值(讲了用途、和看日志相比这个服务的方便之处)

(重发功能:可以修改消息再发送。(比如配置错了的情况,直接改了就可以发))

实习经历2

简单问了一下内容就。。

学校项目

问我做了什么。我直说这个项目很水的hhhh。然后就没问了。

和我确定了一下之前用的什么,然后就开始做题了。

代码1

判断一个字符串是否回文。

和之前的[LeetCode-1题](https://leetcode.cn/problems/two-sum/description/)混了一点。。。想的用哈希表。

第一次循环赋进哈希表,第二次循环判断回文即可。复杂度O(N)。

让我优化...双指针那就是,一次循环 也是O(N)。

讲了一下go的goroutine、GMP模型。

代码2

两个goroutine,一个输出奇数一个输出偶数。通过通信,最终输出1-10。

发现很多小的细节还是有不完善... ...代码放这里了,基础操作还是得巩固。

go 复制代码
func main() {
	fmt.Println("begin")
	nums1 := []int{1, 3, 5, 7, 9}
	nums2 := []int{2, 4, 6, 8, 10}
	i, j := 0, 0
	var wg sync.WaitGroup
	chan1 := make(chan int)
	wg.Add(2)
	go func() {
		for ; i < 5; i++ {
			fmt.Println(nums1[i])
			chan1 <- 1
		}
		wg.Done()
	}()
	go func() {
		for ; j < 5; j++ {
			<-chan1
			fmt.Println(nums2[j])
		}
		wg.Done()
	}()

	wg.Wait()
}

夸赞了一个习惯------写代码先把核心写出来,再去完善枝叶。

反问

公司是做什么的、技术栈

聊了些基本情况就结束了

相关推荐
千金裘换酒7 小时前
LeetCode 移动零元素 快慢指针
算法·leetcode·职场和发展
独自归家的兔7 小时前
Spring Cloud核心架构组件深度解析(原理+实战+面试高频)
spring cloud·面试·架构
程序员小寒11 小时前
从一道前端面试题,谈 JS 对象存储特点和运算符执行顺序
开发语言·前端·javascript·面试
闲看云起12 小时前
LeetCode-day6:接雨水
算法·leetcode·职场和发展
青莲84313 小时前
Android 事件分发机制 - 事件流向详解
android·前端·面试
收获不止数据库13 小时前
黄仁勋2026CES演讲复盘:旧世界,裂开了!
大数据·数据库·人工智能·职场和发展
AlenTech14 小时前
226. 翻转二叉树 - 力扣(LeetCode)
算法·leetcode·职场和发展
求梦82014 小时前
【力扣hot100题】合并区间(9)
算法·leetcode·职场和发展
爱编程的小吴14 小时前
【力扣练习题】121. 买卖股票的最佳时机
算法·leetcode·职场和发展
蘋天纬地16 小时前
蚂蚁数科二面-如果目前当前系统qps是100,如何降低成本
面试