腾讯实习内推

2024-06-22 22:18
文章标签 腾讯 实习

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

腾讯电话一面(32min)问得都是有关Linux下的网络编程和系统编程问题,范围很广但是不深,不难回答。

1 select,poll,epoll的区别;2 进程通信的IPC种类;3 有名管道和无名管道的区别;4 进程和线程的区别; 5 线程的私有栈空间;6 简述TCP通信中服务端和客户端的API;7 TCP中的三路握手;8C语言中的static修饰符;9 进程间如何传递文件描述符;10 进程的虚拟地址空间布局; 11 内核是如何实现创建线程和进程的;12 问了两个项目的具体实现。


腾讯视频二面(65min)

1 sizeof一个空类是多少,含有普通成员函数呢,含有虚函数呢,含有static函数或者static变量呢; 2 用宏F(a,b)实现两数的平方和,F(a++,a++)等于多少;3 内联函数和宏指令有什么区别;4 为什么在公有继承链中基类的析构函数要被声明成虚函数,一个不被继承的类析构函数被声明成虚函数好不好;5 给一个能随机产生1到10000的函数,如何能让它产生随机1到7000;6 fork之后父进程和子进程的栈变量是私有还是公有,堆变量呢,全局变量呢,常量呢,static 变量呢;7 用mmap将共享内存映射到进程的虚拟地址空间时有没有分配物理内存,什么时候才真正分配物理内存给共享变量;8 服务端在调用listen之后调用sleep,客户端connect之后会返回错误吗;9 服务端一直阻塞着(调用sleep),客户端调用send会返回错误吗; 10 说说TCP的拥塞控制和流量控制;11 extern "C"的作用;12 快速排序;13 反转字符串中的单词,空间复杂度O(1)。

HR面试 (30min) 三观正常就好。


最后给的offer是sng的即通平台部


阿里实习内推

阿里电话一面:

问题1:堆和栈的区别?

1 堆大栈小(针对虚拟地址空间)。例如深层次的递归可能造成栈溢出。

2 动态分配内存时要栈要快于堆。栈的分配函数被定义成内联函数,并且栈分配内存时仅仅需要修改栈帧(栈顶指针向下生长)。堆分配内存时涉及维护一个空闲链表(遍历链表找到可用的内存后修改链表返回),从异步安全角度考虑甚至涉及加锁和解锁。

3 malloc函数/new运算符分配的内存位于堆上,局部变量和自动变量位于栈上。

问题2:什么是B树?

1 B树的定义(大家自行百度,阿里特别喜欢问B树)。

2 什么地方使用到B树(一般来说磁盘之类的外设会使用B树存储数据,目的当然是为了减少频繁的数据访问)。

3 B树的节点查找和节点添加,最好再熟悉一下B树的节点删除(当时我没说删除)。

问题3:进程的调度算法?

我就回答了Linux的优先级调度。根据nice值来确定进程的优先级,nice值越小则占CPU使用比重越大(注意了和时间片的长短没关系,每个进程所获得时间片都是一样)。为了公平原则,操作系统会时不时地惩罚高优先级的进程,依据进程使用时间片的情况,时间片使用越少(比如20ms的时间片只使用1ms),那么优先级提升得越高。这就解释了为什么I/O密集型进程优先级要高于计算密集型进程。在同等优先级的进程中使用轮询调度。

问题4: 进程和线程的区别?

一定要答全,答全。。。

问题5: 什么时候使用线程池(根据项目来问)?

1 当服务端处理单个任务时间较短且所需处理任务量较大时。因为线程频繁地创建和销毁会造成服务器性能损耗。

2 每一个任务是无状态的,前后请求没有关联。

ps 最好了解一下什么时候使用多进程和什么时候使用多线程。。。

问题6 :数据库操作?

太水了并不会,以后要加强。

问题7 :问项目(Web服务器和进程池实现FTP)

略。。。


阿里电话二面:

问题1:数据库操作?

依然不会。。。

问题2:说说熟悉的图算法?

遍历会BFS,DFS。最小生成树会prim。最短路径会A*。还会拓扑排序。对图还真不怎么熟悉,囧。。。

问题3:说说linux的文件系统?

1 每一个磁盘分区上有一个文件系统。划分超级块,i节点位图,block位图,i节点数组,block数组。

2 说了说i节点上的元数据,记不太清了。。。

问题4:软链接和硬链接的区别?

硬链接:共享i节点,i节点引用计数递增,删除任意一个文件不会对其他文件造成影响,因为只有引用计数为零时才真正删除文件。不能硬链接一个目录也不能跨文件系统。

软链接:类似windows的符号链接,文件内容指向所链接的文件,当源文件删除时该链接文件失效。

问题5:说说磁盘的预读技术?

进程每次从磁盘读取数据时都会比需求更多,存储在一个内核缓冲区上,下一次读取时先从缓冲区上找,找不到再访问磁盘。可以说内核缓冲区是磁盘的一个缓存,目的是为了减少对磁盘的调用,因为磁盘访问实在太慢了。。。

问题6:说说虚拟地址空间?

自行百度。

问题7:虚拟地址空间有什么好处?

1 每一个进程都有自己独立的地址空间,各不干扰,保证代码和数据的安全。

2 进程可以使用一系列相邻的虚拟地址来访问物理内存中不相邻的内存。

3 可以在一个物理内存较小的主机上运行多个进程。

问题8:问了一些简单Linux操作命令,不难回答。

问题9:问Linux命令中的管道线?

1 管道线的标准定义就连接多个不同命令,以前一个命令的标准输出作为后一个命令的输入,最大的特点就是用一行shell命令实现多个功能的叠加。

2 我说了说Linux中shell命令的编程实现,举了一个例子 ls -l | wc -l (统计当前目录下的子文件个数,不统计子文件下的文件)。

问题10:问项目(Web服务器)

略。。。


阿里电话三面:

问题1:epoll中的边沿触发?

epoll有两种触发方式,水平触发和边沿触发。边沿触发更高效,因为相同文件描述符就绪信息仅会触发一次,如果不及时处理,下次再调用epoll时不会再提醒。

当对已连接套接字选用边沿触发方式时,应把它设定为非阻塞,一旦该已连接套接字就绪,循环读取数据直到返回一个错误,检验errno值判断数据是否被读空或是遇到错误,然后返回。

问题2:红黑树和AVL树?

越详细越好。

问题3:会哪些字符串匹配算法?

KMP,Sunday,RK。最后只让我说了KMP。

问题4:HTML中Post和Get的区别以及HTML的报文格式(根据项目来问)?

自行百度。

问题5:说说自己项目中使用的I/O模型。

非阻塞I/O和I/O复用。

ps:五种I/O模型请掌握,阻塞I/O,非阻塞I/OI/O复用,信号驱动式I/O,异步I/O。

问题6:问项目(进程池实现FTP)

问了项目具体实现,还问了遇到什么困难,怎么解决。

问题7:问项目(Web服务器)

问了项目具体实现,还问了接下来还有什么能改进的地方。

问题8:对什么技术最感兴趣?

服务端开发。。。


HR面就不说了


最后给的offer是淘宝技术部的服务端开发。


爱奇艺实习内推

一面-大概下午两点多

1、  实习做得服务器架构

2、  实习主要做了哪些事情

3、  实习开发的服务器并发量多大?中有碰到过因为大量并发连接而造成的宕机吗?

4、  TCP/IP 的了解,连接 3 次握手和关闭 4 次挥手, time_wait 的作用

5、  One loop per thread + threadpool 的理解

6、  One loop 的 loop 指什么

7、  Muduo 的 tcpconnection 对象为何要用 shared_ptr 接管

8、  Reactor 模式的理解

9、  同步 I/O (阻塞,非阻塞)异步 I/O 的理解

10 、为什么异步 I/O 会比同步 I/O 效率高

11 、 Muduo 修复的 race condition 是哪一处

12 、对于 Race condition 的理解

13 、 race condition 存在的条件

14 、面向对象和基于对象的区别

15 、了解过 libev 吗

16 、了解过 boost.asio 吗

 

二面-当天下午五点,跟一面只隔了两个多小时

1、  select 、 poll 、 epoll 的区别

2、  epoll 的 LT 和 ET 模式的理解

3、  Reactor 模式与 Proactor 模式的区别

4、  Unique_ptr 的理解

5、  阻塞、非阻塞、同步、异步几种 I/O 模型的理解

6、  STL 中 map 和 unorderedmap 内部是借助什么方法实现的

7、  Libev 、 boost.asio 在 Linux 平台上都是基于哪一种模式

8、  为什么 boost.asio 会在 Linux 平台上使用 Proactor

PS: 两轮面试官都是妹子,并且二面面试官人非常 nice ,说考虑到我是外地的,会去帮我申请提高实习薪资,感动。。。

HR面:
其实就是问一下到岗时间,说一下薪资


滴滴出行实习内推

声明:问题是朋友提供的,回答是我自己写的,如不正确,和原作者无关。

一面(四十几分钟):
问题1 :自己设计实现一个信号量(口述思路)
利用FIFO(有名管道)实现。初始化创建一个管道并且往管道中写入value(value即为信号量的初始值)个字符。调用sem
_post(解锁)往管道中写入一个字符,调用sem_wait(加锁)从管道中读取一个字符,如果管道为空则阻塞调用。还可以用共享内存实现,参考UNP卷二。
问题2 :Linux创建进程的几种方式,之间的区别
fork:通过写时拷贝机制创建子进程,子进程通过拷贝父进程的页表与父进程共享相同的物理内存(被标记为只读),当其中一方试图修改物理内存上的数据时发生中断,内核拷贝被修改页并修改子进程的页表使其指向新拷贝的一页,之后对该页上的数据进行修改不再产生中断。因此可以理解成父进程和子进程拥有独立的地址空间而相互不干扰。 
vfork:vfork之后,子进程先运行,当子进程调用exec或者exit后运行父进程。子进程和父进程共享地址空间,因此不论在父进程还是子进程中对数据的修改另一方是可见的。vfork设计是用来执行新程序的,即vfork后子进程马上调用exec系列函数。
问题3 :多态的实现机制
多态的定义即以一个父类的指针或引用,寻址出公有继承链中子类的实例。所以多态与继承有关,而实现多态需要借助虚函数。当以父类指针或引用调用虚函数时,实际运行的是父类指针或者引用所指向的实际对象中定义的虚函数。
虚函数的实现依靠的是一颗虚指针(和实例有关)和一张虚表(和类有关)。当一个虚函数被调用时,我并不知道具体是哪个类的虚函数,但我知道虚指针的偏移和虚函数所处虚表中的哪个槽,从而找到虚函数的入口地址并激活虚函数的调用。
问题4:malloc 和 new 的区别
malloc/free是C/C++标准库函数,new/delete是C++运算符。他们都可以用于动态申请和释放内存。

对于内置类型数据而言,二者没有多大区别。malloc申请内存的时候要制定分配内存的字节数,而且不会做初始化;new申请的时候有默认的初始化,同时可以指定初始化;

对于类类型的对象而言,用malloc/free无法满足要求的。对象在创建的时候要自动执行构造函数,消亡之前要调用析构函数。由于malloc/free是库函数而不是运算符,不在编译器控制之内,不能把执行构造函数和析构函数的任务强加给它,因此,C++还需要new/delete。

问题5:不同类的占用内存大小
考虑内存对齐。
问题6:指针数组和数组指针的定义
指针数组:数组元素都是指针的数组。
数组指针:指向数组的指针。
问题7:升序链表的插入
问题8:一道算法题
问题9:Linux ( cd .. )基本操作指令
问题10:一个 shell程序
问题11:数据库 SQL 语句 - 多表查询( select grade, age from table1, table2 where table1.name=table2.name 等等)
问题12:如果让你去评测一款手机,你会怎么做
二面(十分钟):

问题1:普通进程与守护进程的区别

守护进程:脱离于终端并且在后台运行的进程。守护进程脱离于终端是为了避免进程在执行过程中的信息在任何终端上显示并且进程也不会被任何终端所产生的信息所打断。服务器常被设计成守护进程。

普通进程:无法脱离终端,即便是后台进程,当终端被关掉时,进程也结束。

问题2:僵尸进程的概念
父进程未结束但是子进程已经结束并且父进程没有显式回收子进程资源。
问题3:了解过测试吗(并没有,但是测试很重要啊。。后面巴拉巴拉。。。)
三面(HR):
直接发的offer,除了问了下大概什么时间能到岗外,没有多说一句话,五分钟结束。。。
总结:总得来说,这次面试全程还算是轻松愉快的,问的都是基础知识


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



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

相关文章

【文末附gpt升级秘笈】腾讯元宝AI搜索解析能力升级:千万字超长文处理的新里程碑

腾讯元宝AI搜索解析能力升级:千万字超长文处理的新里程碑 一、引言 随着人工智能技术的飞速发展,自然语言处理(NLP)和机器学习(ML)在各行各业的应用日益广泛。其中,AI搜索解析能力作为信息检索和知识抽取的核心技术,受到了广泛的关注和研究。腾讯作为互联网行业的领军企业,其在AI领域的探索和创新一直走在前列。近日,腾讯旗下的AI大模型应用——腾讯元宝,迎来了1.1.7版本的升级,新版本在AI搜

腾讯Hardcoder-Android通讯框架简介

APP 的功能和业务特性不依赖于该框架。 总而言之,由于Hardcoder是腾讯主导的,所以我们不用太担心兼容性问题,腾讯会和手机厂商进行洽谈并提供解决方案,并且目前已经支持Hardcoder框架的手机厂商有OPPO、vivo、华为、小米、三星、魅族等。 Hardcoder 性能优化技术方案 Hardcoder 优化基础 Hardcoder 在Android系统侧主要优化的方法有提高 CP

2024.06.11校招 实习 内推 面经

绿*泡*泡VX: neituijunsir    交流*裙 ,内推/实习/校招汇总表格 1、校招 | 美团2025届北斗计划正式启动(内推) 校招 | 美团2025届北斗计划正式启动(内推) 2、实习 | 沃尔沃汽车 Open Day & 实习招聘 实习 | 沃尔沃汽车 Open Day & 实习招聘 3、夏令营 | 北京空间机电研究所“逐梦星空”夏令营招募令 夏令营 |

腾讯视频客户端缓存提取mp4文件工具

在腾讯视频客户端看过视频之后,可以利用本软件,从缓存中提取看过的视频。提取的视频将会保存为MP4文件。 下载地址:http://download.csdn.net/detail/u012107143/9769624 代码如下: @echo offsetlocal ENABLEDELAYEDEXPANSION:INPUT_PATHset video_path=F:\16

2018腾讯校园实习招聘面经——研发工程师

时间:2018年4月15日 下午 岗位:腾讯云-运营开发 下午很荣幸的参加了腾讯在武汉专场面试,大概面试在一个小时的时间。大公司真的不一样,一套完整的流程下来感觉特别舒服。 到达面试的酒店,先是微信扫一扫签到,然后到达会议室候场,轮到自己的时候会有微信通知+短信通知。基本上面试的时间和约好的相差不大,只会晚不会早,所以如果比较晚面试的也没必要提早太久过去。 好了话不多说啦,我就回忆一下面试

腾讯实习生招聘失败经历分享

腾讯实习生招聘开始,师兄们说进入腾讯实习转正的概率很大,果断投了网申,当然先准备了一份自认为良好的简历。接着收到腾讯的短信说参加笔试,线下,我特别喜欢线下,因为这样做题的感觉比较习惯,我之前买了本《程序员面试宝典》,看了一部分,发现笔试题目很多书里都有讲到类似的,遗憾的是我没有看完,很多题目凭记忆和感觉做的,线下果然棒,惊喜,我过了笔试,收到了面试通知。 现在的实习单位离面试地点超远,我请了假赶

不用写一行代码,deepseek结合腾讯云语音识别来批量转录Mp3音频

首先,打开window系统中的cmd命令行工具,或者powershell,安装腾讯云tencentcloud的Python库 pip install -i https://mirrors.tencent.com/pypi/simple/ --upgrade tencentcloud-sdk-python 然后,开通腾讯云的对象存储COS服务, 把要转录成文本的mp3音频文件上

腾讯面试题:根据上排给出的十个数,在其下排填出对应的十个数。

版权所有。所有权利保留。 欢迎转载,转载时请注明出处: http://blog.csdn.net/xiaofei_it/article/details/17172769 根据上排给出的十个数,在其下排填出对应的十个数,要求下排每个数都是先前上排那十个数在下排出现的次数。 上排的十个数如下: 0,1,2,3,4,5,6,7,8,9

网易实习--编程题

网游中,装备强化是提升角色战力的常见方法。 现在你参与开发的游戏中也有这项功能,团队正在设计每件装备强化所能提升的战力及需要消耗的金币数。为了设计出一个合理的强化系统,决定先做一些强化模拟测试,而你现在就在是该模拟程序的开发者。 假设现在有n件可以同时穿戴的装备,对于第i件装备,最多可以强化mi 次,对于第i件装备的第j次强化,会增加fij 的战力,并需要消耗gij 个金币。现在给出所有装备的数

腾讯2016笔试题答案

1.爸爸去哪儿中的3对父子站成一排,各自父子之间不能相邻,比如石头不能和郭涛挨着,以此类推,共有几种站法?   A.120   B.48   C.240   D.144   答案:C   2.请找出下面程序中有哪些错误:   1 int main()   2 {   3 int i=10;   4 int j=1;   5 const int *p1;//(1)