2022-10-26 7pm 第一次实习面试,总体不难,但答 得一塌糊涂 1.自我介绍 2.能实习多久,什么时候可以到 3.切片底层结构、扩容机制 3.进程,线程,协程联系和区别 4. 启动100个协程…怎么实现中断任务(具 体忘了) 5.sync. WaitGroup的底层是怎么样实现的 6.go调度模型讲讲 7.mysql了解吧,讲讲索引、事务 8.索引是怎么存储的,MySQL
很久之前面的了,简单写一下 实习 实习工作具体介绍 Redis分布式锁如何使用 RocketMQ实现延时消息使用场景、原理 如果延时topic里有一亿条消息,如何取出即将到延时时间的消息?全表扫描? 看你说服务QPS很高,对于高并发场景下有什么需要注意的问题 异步调用一定比同步调用快吗 100的QPS,同步调用开100个进程,是否比多线程(线程池)更优? TransmittableThreadLo
复盘了一下感觉还是自己太菜了 感觉问的问题也算合理,我应该能答出来才对
八股: mysql索引怎么存 优点 慢查询优化 redis hash怎么存, 哈希冲突 扩容, 查询流程 kafka为什么快, 消息怎么存 kafka怎么保证消息一定被消费 go的map底层结构 自选锁 互斥锁 自选锁的应用场景 😩忘记了, 可以说CAS Raft模块最难的一个, 为什么 两个候选者票数相同发生什么 项目 实习的难点是什么😩没什么可说的 实习的系统你觉得可以怎么优化😩 需求怎
#度小满##面经##实习# 1、自我介绍 2、为什么选择golang,而不是java等学校有开设的课程 3、为什么并发环境下更有优势 4、介绍下gmp 5、介绍下协程,他与线程的区别是什么 6、说一下什么是虚拟地址 7、如果没有虚拟地址,只有物理地址可以吗 8、说一下线程间是如何进行通讯 9、选一个你做的项目,详细说一下做的思路 10、算法题 两个排序后切片,如何在不使用额外空间 也不能排序的情况
1. 半小时围绕实习经历,进行细问,结合自己理解和思考 2. 部署公司开源监控软件 3. 代码题:并发访问多个URL,存储状态信息 --------------------------------------------------------- 面试体验很好,代码题早上刷到有个老哥分享了,很感谢。 (吐槽好多人真的只看面经,不写不发的,还一堆情绪
一面 1、数据库事务 2、三次握手 3、四次挥手,解释第三次挥手 4、time_wait的作用 5、time_wait过多会导致什么 6、http版本以及区别 7、介绍虚函数 8、mysql:求平均值、两个表联合查数据 9、死锁条件 10、查看进程的命令 11、核心是二叉树层序遍历 二面: 1、红黑树b+树文件系统的底层结构是什么 2、介绍单例模式 3、进程、线程区别 4、多进程、多线程区别,与多
问题内容: 我正在尝试将可工作的mongo查询转换为golang中的bson。我掌握了一些基本知识,但仍在努力寻找如何将更高级的查询集成到组合中的方法。 有人可以帮助我转换以下查询吗?希望它应该给我我需要的方向…不幸的是,除了评估和查询之外,我无法找到许多示例。 这在mongo中有效: 这适用于golang / bson: 我该如何正确介绍该声明? 问题答案: 在您的情况下,它将是:
问题内容: 场景:我正在尝试解析一个XML结构,但我不知道如何在xml属性值包含文本和更多嵌套值的情况下建立结构。所有其他属性都已正确设置,我不确定是否需要获取源的值并创建一个单独的解析器来检索元素的值。 编辑: 我正在尝试将源解析为以下形式的字符串:你好%{first_name}%{last_name} 用当前结构解组xml字符串将返回一个空结构 使用innerxml的@plato将源设置为:
问题内容: 有人对Golang的功能有很好的解释吗? 我环顾四周,但除了Golang主文档对以下内容的解释外,没有找到其他内容: NopCloser返回带有无操作Close方法的ReadCloser,该方法包装提供的Reader r。 任何指示或解释将不胜感激。谢谢。 问题答案: 每当需要返回时,同时确保可用,则可以使用来构建这样的ReaderCloser。 您可以在此gorest分支中看到一个示
问题内容: 我尝试在MongoDB中找到我的用户,但是当我运行此代码时: 只是告诉我: 并且不要返回其他值! 非常感谢您的参与! 问题答案: 只是您应该在结构名称的开头使用大写字母!而且你也不需要 你可以写 : 祝好运 :))
上述实现并发的代码中为了保持主线程不挂掉,我们都会在最后写上一个死循环或者写上一个定时器来实现等待 goroutine 执行完毕 上述实现并发的代码中为了解决生产者消费者资源同步问题,我们利用加锁来解决,但是这仅仅是一对一的情况,如果是一对多或者多对多,上述代码还是会出现问题 综上所述,企业开发中需要一种更牛 X 的技术来解决上述问题,那就是管道(Channel) Channel 的本质是一个队列
Go 语言中的结构体和 C 语言中结构体一样,都是用来保存一组 不同类型的数据 Go 语言中的结构体和 C 语言中结构体一样,都需要先定义结构体类型再利用结构体类型定义结构体变量 定义结构体类型 type 类型名称 struct{ 属性名称 属性类型 属性名称 属性类型 ... ... } type Studentstruct { name string age int
golang 里面有两个保留的函数: init 函数(能够应用于所有的 package) main 函数(只能应用于 package main) 这两个函数在定义时不能有任何的参数和返回值 go 程序会自动调用 init() 和 main(),所以你 不能 在任何地方调用这两个函数 package main 必须包含一个 main 函数,但是每个 package 中的 init 函数都是可选的 一
这是一个第三方的 Oracle 数据库的 Go 语言客户端驱动包。 示例代码: import ( "database/sql" _ "gopkg.in/rana/ora.v3")func main() { db, err := sql.Open("ora", "user/passw@host:port/sid") defer db.Close()} package main