腾讯IEG后台开发实习二面

2023-11-09 15:10

本文主要是介绍腾讯IEG后台开发实习二面,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

腾讯IEG后台开发实习二面

IEG的后台开发二面,人生第一次二面,没想到是这样的……实际问的非常非常细这里并未全部展示。

一、基础知识

全是超细的基础知识
加粗的为我个人不会,日后强化。
1、操作系统内存是怎么分配的(虚拟内存方向)。问题一堆,其中有:“用什么手段监测虚拟内存的使用”我随便答了一些,后查发现Linux有个vmstat的虚拟内存实时监控工具。
2、用户态、内核态。Windows NT内存空间划分。我说只知道Linux,但NT其实也是一样的,低地址用户,高地址内核。
3、IO中断流程、中断表(中断向量表)。比如Linux系统的.INT表
4、隐藏、重写/覆盖(前者的基类函数是虚函数!)、new、malloc、free、new区别;new的对象能用free释放吗(会变成悬空指针,我一开始搞错了提了一嘴野指针给自己挖坑)。悬空指针:指针指向的对象已销毁或内存被释放。野指针:指向的空间值无法判断。如指针未初始化、赋值为nullptr。
5、const的作用(五个作用:常量、常指针、常成员函数、常函数形参、类的成员函数返回对象用const修饰则不能成为左值)、const与define的区别。
6、map的key有什么要求、如果用中括号访问有什么副作用,如果key不存在的时候会怎样(会在map中插入一个key的元素,value取默认值,返回value。也就是说,map[key]不可能返回nullptr)。
7、MyISAM与InnoDB,聚簇索引和非聚簇。
8、三次握手、time wait。实际应用中time wait会占用哪些资源,谁会成为瓶颈?我答了内存。。。实际会因为连接占用了端口号没释放,导致端口号枯竭!无法建立新的连接!!!
9、网络字节序大端小端。。。
10、如何判断程序有无死锁,如何解除。


二、算法题

口述了quick select,刚好之前写过这个的博客。
64匹马,8赛道问题。


三、总结

有很多基础题之前每次面试都看了,但因为一直没考这次没看,就翻车了……因为是第一次二面,不知道会问的这么细,所以大意了,所以不能有侥幸心理。同时Linux也要加急加急加急学习。


四、部分答案补充

vmstat(Virtual Meomory Statistics):https://blog.csdn.net/xie_qi_chao/article/details/105038864

中断详细过程:https://blog.csdn.net/weixin_33675507/article/details/93780804

中断向量表:https://baike.baidu.com/item/%E4%B8%AD%E6%96%AD%E5%90%91%E9%87%8F%E8%A1%A8/4947137?fr=aladdin

中断向量表用于存放中断程序的入口地址的偏移量和段基值。中断类型号指不同的中断类型,按照中断类型号从小到大的顺序存储对应的中断向量。

map相关

map的key不能为指针,不能重复。还有如下要求:
1 支持拷贝构造
2 支持operator =
3 operator < 如果没有operato r < ,那么 map模板必须增加第三个模板参数
4 有默认构造函数

中括号访问法必须先用find检测再访问,否则若不存在会创建一个新的key-value对。

网络字节序和大小端

①大端字节序(Big Endian):最高有效位存于最低内存地址处,最低有效位存于最高内存处。
②小端字节序(Little Endian):最高有效位存于最高内存地址,最低有效位存于最低内存处。
大小端示意图

UDP/TCP/IP协议规定: 收到的第一个字节被当作高位看待,这就要求发送端发送的第一个字节应当是高位。而在发送端发送数据时,发送的第一个字节是该数字在内存中起始地址对应的字节。可见多字节数值在发送前,在内存中数值应该以大端法存放。所以网络字节序也是大端模式。
异构计算机间通讯需要考虑字节序的转换;主机字节序为小端模式。

原文链接:https://blog.csdn.net/z_ryan/article/details/79134980
原文链接:https://blog.csdn.net/msdnwolaile/article/details/50727653

判断有无死锁

链接:https://www.nowcoder.com/questionTerminal/6b5e51a23c8a423f920b6215075c611c
https://blog.csdn.net/hd12370/article/details/82814348

1、死锁的四个必要条件:
• 互斥条件(Mutual exclusion):资源不能被共享,只能由一个进程使用。
• 请求与保持条件(Hold and wait):已经得到资源的进程可以再次申请新的资源。
• 非剥夺条件(No pre-emption):已经分配的资源不能从相应的进程中被强制地剥夺。
• 循环等待条件(Circular wait):系统中若干进程组成环路,该环路中每个进程都在等待相邻进程正占用的资源。

2、避免死锁:
• 方案一:资源一次性分配。(破坏请求条件)
• 方法二:使用lock的特性,为获取锁操作设置超时时间(破坏死锁的请求与保持条件),如果一直获取不到锁就会放弃等待,释放之前获取的锁。
• 方法三:以确定顺序获取锁(破坏环路等待),比如银行家算法。

3、linux中查看死锁进程状态
使用pstack 和 gdb 工具对死锁程序进行分析
pstack 进程号 查看各个线程的堆栈信息
当进程吊死的时候,多次使用,死锁的线程将一直处于等锁的状态,确定某些线程一直没有变化,一直处于等锁的状态。那么这些线程很可能是死锁了。如果怀疑哪些线程发生死锁了,可以采用gdb 进一步attach线程并进行分析。
执行命令gdb attach 进程号,进入gdb调试终端
运行:(gdb) info thread

这篇关于腾讯IEG后台开发实习二面的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/376887

相关文章

Agent开发核心技术解析以及现代Agent架构设计

《Agent开发核心技术解析以及现代Agent架构设计》在人工智能领域,Agent并非一个全新的概念,但在大模型时代,它被赋予了全新的生命力,简单来说,Agent是一个能够自主感知环境、理解任务、制定... 目录一、回归本源:到底什么是Agent?二、核心链路拆解:Agent的"大脑"与"四肢"1. 规划模

Python+wxPython开发一个文件属性比对工具

《Python+wxPython开发一个文件属性比对工具》在日常的文件管理工作中,我们经常会遇到同一个文件存在多个版本,或者需要验证备份文件与源文件是否一致,下面我们就来看看如何使用wxPython模... 目录引言项目背景与需求应用场景核心需求运行结果技术选型程序设计界面布局核心功能模块关键代码解析文件大

C++多线程开发环境配置方法

《C++多线程开发环境配置方法》文章详细介绍了如何在Windows上安装MinGW-w64和VSCode,并配置环境变量和编译任务,使用VSCode创建一个C++多线程测试项目,并通过配置tasks.... 目录下载安装 MinGW-w64下载安装VS code创建测试项目配置编译任务创建 tasks.js

一文详解Python如何开发游戏

《一文详解Python如何开发游戏》Python是一种非常流行的编程语言,也可以用来开发游戏模组,:本文主要介绍Python如何开发游戏的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、python简介二、Python 开发 2D 游戏的优劣势优势缺点三、Python 开发 3D

基于Python开发Windows自动更新控制工具

《基于Python开发Windows自动更新控制工具》在当今数字化时代,操作系统更新已成为计算机维护的重要组成部分,本文介绍一款基于Python和PyQt5的Windows自动更新控制工具,有需要的可... 目录设计原理与技术实现系统架构概述数学建模工具界面完整代码实现技术深度分析多层级控制理论服务层控制注

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

90%的人第一步就错了! 顺利登录wifi路由器后台的技巧

《90%的人第一步就错了!顺利登录wifi路由器后台的技巧》登录Wi-Fi路由器,其实就是进入它的后台管理页面,很多朋友不知道该怎么进入路由器后台设置,感兴趣的朋友可以花3分钟了解一下... 你是不是也遇到过这种情况:家里网速突然变慢、想改WiFi密码却不知道从哪进路由器、新装宽带后完全不知道怎么设置?别慌

基于Go语言开发一个 IP 归属地查询接口工具

《基于Go语言开发一个IP归属地查询接口工具》在日常开发中,IP地址归属地查询是一个常见需求,本文将带大家使用Go语言快速开发一个IP归属地查询接口服务,有需要的小伙伴可以了解下... 目录功能目标技术栈项目结构核心代码(main.go)使用方法扩展功能总结在日常开发中,IP 地址归属地查询是一个常见需求:

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版