聊聊Golang开发工程师

诞生背景


Go由Google三位顶尖工程师(Ken Thompson、Rob Pike、Robert Griesemer)设计,目标是解决两大行业痛点:

  • 硬件利用率不足:多核CPU普及,但C/C++等语言难以高效利用并发能力;

  • 开发效率低下:C++编译慢、Java冗长,且内存泄漏问题频发

现状:

随着云计算(Docker/K8s)、高并发中间件(消息队列、数据库)等场景依赖Go,以及字节跳动等大厂从python迁移到了Go,进一步推动了Go语言的繁荣。 尤其是字节出来的各类技术人员,又进一步把Go的技术栈带到了各家公司。随手翻阅一下求职网站,我们可以发现各个大厂,包括字节、拼多多、腾讯都会有golang开发工程师的招聘

面试概述

从一个面试官的角度出发,一名合格的Golang后台开发工程师我们需要具备哪些的能力,这一个专栏的文章我们就来聊一聊这块,核心能力大概分这么几块:

1.  Golang的基础知识

2. 项目的掌握情况

3. 架构的理解

4. 算法的能力

5. 管理能力

第四点算法的能力,如果是找中小厂的话,一般是不考察的。 但是如果想去字节等大厂,一般是会考察算法题的。

第五点从ld的角度出发的一个考察。

面试题初探

我们第一篇先略微提一些面试题,这些面试题是从网上收集的一些案例,可以看看各大厂究竟在面试哪些问题。

腾讯

一方面是通过电话直接沟通

  • go的调度
  • go struct能不能比较
  • go defer(for defer)
  • select可以用于什么
  • context包的用途
  • client如何实现长连接
  • 主协程如何等其余协程完再操作
  • slice,len,cap,共享,扩容
  • map如何顺序读取
  • 实现set
  • 实现消息队列(多生产者,多消费者)
  • 大文件排序
  • 基本排序,哪些是稳定的
  • http get跟head
  • http 401,403
  • http keep-alive
  • http能不能一次连接多次请求,不等后端返回
  • tcp与udp区别,udp优点,适用场景
  • time-wait的作用
  • 数据库如何建索引
  • 孤儿进程,僵尸进程
  • 死锁条件,如何避免
  • linux命令,查看端口占用,cpu负载,内存占用,如何发送信号给一个进程
  • git文件版本,使用顺序,merge跟rebase

字节一面(教育部门)
自我介绍,项目介绍
1.说说mysql的隔离级别
2.mysql的索引类型
3.项目里用了sqs,sns,有什么区别
4.mongo为什么不支持事务,mongo的速度,mongo的查询机制
5.redis的cluster内部是怎么高可用的,怎么选主
6.熟悉raft吗
7.算法题:有红黄蓝三种球,分别用123标识,每种颜色的球有n个,每种颜色的球数量相同,如122331213排列,要求123123123排列,要求时间O(n),空间O(1)
 

米哈游

一面摘录

  • Go 里面使用 Map 时应注意问题和数据结构?

    • 可以通过定义 value 为 struct 来节约内存;
    • 哈希分桶的结构,用哈希值的高八位和低八位分别来做桶内定位的依据和分桶的依据等;
  • Map 扩容是怎么做的?

    • 依照 Redis 渐进式 rehash 的思路说了一版;
  • Map 的 panic 能被 recover 掉吗?了解 panic 和 recover 的机制吗?

    • 不懂,但是实际上是不可以的,具体原因可以看看 Map 并发读写的时候抛出的是什么,是不是普通的 panic;
  • Map 怎么知道自己处于竞争状态?是 Go 编码实现的还是底层硬件实现的?

    • 通过结构体中的标记位实现的,可能是通过 CAS 操作的;
  • CAS 具体是怎么实现的呢?

  • 并发使用 Map 除了加锁还有什么其他方案吗?

  • 有对比过 sync.Map 和加锁的区别吗?

  • 说一下(Redis)分布式锁的实现?

    • setnx / 唯一 value / ttl
  • 基于 Redis 的分布式锁会有什么问题?

    • 主从模型下同步不保证一致会导致锁失效
  • Redis 分布式锁超时可以超时时间设长一点可以吗?不可以的话需要怎么解决?

    • 不根本解决问题,可以考虑旁路的 goroutine 不断自旋续期
  • 对 Redis 锁续期这个怎么实现呢?

  • 日常在用的 Redis 集群都是什么架构?在主从模式和 Redis Cluster 中分布式锁会有什么问题?

总结

我们对于Golang面试有了一个初步的概念,后面我们会逐步展开来看一看一些核心面试的考察点,并展开介绍一下这些技术点。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/88798.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/88798.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

机器学习6——线性分类函数

线性分类函数 分类问题的两种决策方法: 概率方法:通过计算后验概率进行分类。优点是在概率分布已知的情况下可以得到最优解,缺点是实际中概率密度通常未知,需要通过大量数据估计。判别方法:假设判别函数的形式已知&…

Sentinel(三):Sentinel熔断降级

一、Sentinel熔断概念介绍 官方文档网址:circuit-breaking | Sentinel 1、Sentinel熔断基本介绍 除了流量控制以外,对调用链路中不稳定的资源进行熔断降级也是保障高可用的重要措 施之一。一个服务常常会调用别的模块,可能是另外的一个远程服…

PostgreSQL 主从集群搭建

下面是 PostgreSQL 主从复制(Streaming Replication)环境的安装与配置指南,适合在两台或多台服务器之间构建一主一从(或一主多从)的高可用读写分离系统。 环境准备 角色主机名/IP说明主库192.168.1.10可读写&#xff…

STM32安全固件升级:使用自定义 bootloader 实现SD卡固件升级,包含固件加密

前言 在 STM32 嵌入式开发中,Bootloader 是一个不可或缺的模块。ST 公司为 STM32 提供了功能完备的官方 Bootloader,支持多种通信接口(如 USART、USB DFU、I2C、SPI 等),适用于标准的固件更新方案。 然而&#xff0c…

一步部署APache编译安装脚本

接下来我来介绍以下编译安装的好处 编译安装的优点与缺点 一、优点 高度可定制 可根据实际需求启用或关闭特性(如 Apache 的模块、MySQL 的引擎等)。 灵活控制编译参数、优化性能(如 --enable-xxx、--with-xxx)。 更高的性能…

[Linux]mmap()函数内存映射原理及用法

一、内存映射 内存映射,简而言之就是将用户空间的一段内存区域映射到内核空间,映射成功后,用户对这段内存区域的修改可以直接反映到内核空间,同样,内核空间对这段区域的修改也直接反映用户空间。那么对于内核空间和用…

通信无BUG,ethernet ip转profinet网关,汽车焊接设备通信有心机

在运用“激光钎焊”对汽车车顶、侧面板、后行李箱盖等位置进行接合时,必须配备能够沿着复杂车身线条,对细窄焊接线实施高精度快速检测及模仿控制的“焊缝跟踪控制”。 那么汽车生产线的系统升级改造迫在眉睫,当西门子PLC和库卡机器人无法通信…

python脚本ETH获取最新发行版本并将是否更新信息发送到钉钉

import requests import json import time import hmac import hashlib import base64 import urllib.parse# 1. 配置钉钉机器人 webhook "https://oapi.dingtalk.com/robot/send?access_tokenXXX" secret "XXX" # 如果没有加签验证,请设…

【Docker基础】Docker容器管理:docker ps及其参数详解

目录 1 docker ps命令概述 1.1 命令定位与作用 1.2 命令基本语法 2 基础参数详解 2.1 默认输出解析 2.2 核心参数解析 2.2.1 -a, --all 2.2.2 -q, --quiet 2.2.3 --no-trunc 3 高级过滤与格式化 3.1 过滤器(--filter)详解 3.1.1 常用过滤条件 3.1.2 实际应用示例 …

应急响应-感染Neshta病毒

病毒确定: 根据感染现象确定为Virus/Win32.Neshta家族病毒 病毒表现: 该病毒为感染式病毒。该病毒会在系统%SystemRoot%目录下释放svchost.com文件,并通过添加注册表的方式确保每个exe文件执行的时候都会先执行这个文件。该病毒还会收集系统信…

Hyperledger Fabric 入门笔记(二十)Fabric V2.5 测试网络进阶之Tape性能测试

文章目录 前言一、介绍二、架构三、安装说明四、使用方法4.1. 修改配置文件4.2. 启动测试网络4.3. 运行测试 前言 本文介绍由Hyperledger中国技术工作组提供的另一款区块链网络性能测试工具Tape的架构、安装和在Fabric测试网络中的使用。 一、介绍 Tape是一款轻量级的、可以快…

怎样在 VS Code 中快速创建 Vue 单文件组件(SFC)的基础模板结构?

问题 在Vue项目的开发中&#xff0c;我们经常遇到一个问题&#xff0c;创建新组件时要自己输入基本的框架&#xff0c;比如&#xff1a; <template><div class"page-box"></div> </template><script> export default {name: ,data()…

高防IP在服务器中的作用都有哪些?

高防IP作为一种通过技术手段让用户网络服务更加安全的一种IP地址&#xff0c;有着更高的防御能力&#xff0c;有着强大的流量清洗中心和防御系统&#xff0c;帮助企业实时监控网络流量&#xff0c;将恶意的用户请求识别并过滤掉&#xff0c;保护目标服务器不会受到网络攻击&…

实战 X-AnyLabeling:构建高效自动标注系统的工程实践

文章目录 一、项目背景与目标二、系统架构与模块划分2.1 模块组成说明2.2 架构图 三、模型封装与平台对接3.1 模型封装接口3.2 接入 X-AnyLabeling 平台 四、可视化与预测验证4.1 UI 预测标签预览 五、性能优化与工程经验5.1 模型加速与推理优化5.2 经验总结5.3 实际效果 本文将…

UC3842/UC3843反激教程教学开关电源 反激设计步骤,每一关键元器件计算

资料下载地址&#xff1a;UC3842/UC3843反激教程教学开关电源 反激设计步骤&#xff0c;每一关键元器件计算 1、原理图 2、PCB图 3、变压器设计资料 4、开关电源设计资料 5、主要元器件说明书 6、系统整体资料 7、说明文档 7.1、电源设计概述 电源规格&#xff1a;设计一款 2…

Docker 入门教程(二):Docker 的基本原理

文章目录 &#x1f433; Docker 入门教程&#xff08;二&#xff09;&#xff1a;Docker 的基本原理1. Docker 架构总览&#xff1a;三大核心角色2. 镜像与容器的关系3. 容器启动流程&#xff1a;docker run 背后发生了什么&#xff1f; &#x1f433; Docker 入门教程&#xf…

21.安卓逆向2-frida hook技术-HookOkHttp的拦截器

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 内容参考于&#xff1a;图灵Python学院 工具下载&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1bb8NhJc9eTuLzQr39lF55Q?pwdzy89 提取码&#xff1…

小程序入门:swpier 和 swpier-item 的基本使用

在前端开发中&#xff0c;创建交互式的用户界面组件是至关重要的。今天&#xff0c;我们将深入探讨 swpier 和 swpier-item 的基本使用方法&#xff0c;这两个组件在构建轮播图等滑动效果的场景中非常实用。 一、swpier 组件概述 swpier 组件是实现滑动效果的核心容器。它负责…

SQL学习笔记4

约束 1、约束 约束&#xff0c;是指作用在表中字段上的规则&#xff0c;用于限制字段输入的数据&#xff0c;使得表格式统一&#xff0c;数据内容正确。同一个字段的约束可以有多个 约束包括&#xff1a; 非空约束&#xff0c;限制表中的值不为null:not null 唯一约束&…

力扣刷题(第七十天)

灵感来源 - 保持更新&#xff0c;努力学习 - python脚本学习 比特位计数 解题思路 对于任意整数 x&#xff0c;其 1 的个数等于 x // 2 的 1 的个数加上 x % 2。状态转移方程&#xff1a;dp[x] dp[x // 2] (x % 2)。 class Solution:def countBits(self, n: int) ->…