嵌入式面经111题答案汇总_3大嵌入式项目源码分享

111道嵌入式面试题答案汇总专栏链接(承诺免费技术答疑) --> 《嵌入式/C++面试题解析大全》

1、简介

本人是2020年毕业于广东工业大学研究生:许乔丹,有国内大厂CVTE和世界500强企业工作经验,整理超全面111道嵌入式面试题目答案解析(承诺提供专栏内容免费技术答疑),本专栏内容主要有:

  • 面试过程口头提问的问题答案汇总,承诺提供免费技术答疑,以及其他的交流,如要怎么入门c++,简历如何写,算法题如何刷等等,实现校招全陪伴!

2、项目经验

如果你找的是单片机,那就只要单片机的项目,如果你是嵌入式linux,你可以最多写一个单片机项目,其他都要写嵌入式linux的项目。

如果你找嵌入式linux应用开发工作,也可以写linux驱动项目,但必须有一个应用层的项目。

如果你找嵌入式linux驱动开发项目,最好也要有一个应用层项目,突出你对多进程多线程那些知识点有所了解。

项目数量2-4个,此时就需要靠过往的经验积累了,如果确实没有项目,可以向身边做嵌入式的同学请教一下,快速掌握,同时也分享几个项目供参考:

2.1 基于人脸属性识别的嵌入式电影推荐系统(嵌入式人工智能项目、可提供源码)

1)情况:为解决“信息过载”问题,提出基于人脸属性识别的广告推荐系统。

2)目标:独立负责,摄像头捕捉人脸并预测年龄、性别,显示屏可输入用户职业,系统根据此三大信息推荐8部电影并在显示屏显示。

3)行动:搭建RK3399开发板开发环境,通过OpenCV获取摄像头图像,Dlib检测人脸,采用WRN神经网络预测年龄、性别,结合基于用户的协同过滤以及决策树模型进行电影推荐。使用PyQt5设计人机交互界面实现职业获取和电影信息显示。

4)成果:在RK3399开发板可实时获取被推荐人年龄、性别、职业,据此推荐8部电影并将其电影名字和海报图显示在屏幕上。

alt

2.2 基于Linux6818开发板的视频播放器(最好的入门项目,可提供源码)

本项目基于嵌入式linux6818开发板,制作一个音视频播放器。开发板移植安装好mplayer,我提前下载了5个mv,使用mplayer命令分别在5个视频里截取某一秒的画面,共得到5张图片,也就是所谓的视频缩略图,将5个缩略图显示在显示屏的右边,当作是播放列表,支持上下滑动浏览播放列表,点击其中某个图片,即可播放对应视频,并实现播放器常见的开始、停止、上下首、音量调节、进度调节、全屏、静音等功能。使用到多进程技术:有名管道、消息队列、信号量;使用到多线程技术:互斥锁、条件变量。

alt

2.3 基于Linux6818开发板的智能车库项目(进阶项目,可提供源码)

没错,也是粤嵌6818开发板,搭配触摸屏、USB摄像头、音响,模拟实现真实场景中的智能车库常见功能:

  • 实时视频监控
  • 自动识别车牌
  • 自动语音播报
  • 停车计费

需要使用到V4L2子系统,FrameBuffer子系统、OpenCV、多进程多线程编程、ALSA子系统、智能语音引擎、网络编程、数据库编程等。

alt

3、嵌入式111道高频面试题

八股文不在于量多,熟悉以下111道题就够啦

第一章 进程线程

1.1 进程线程的基本概念

  • 1.1.1 什么是进程,线程,彼此有什么区别⭐⭐⭐⭐⭐
  • 1.1.2多进程、多线程的优缺点⭐⭐⭐⭐
  • 1.1.3什么时候用进程,什么时候用线程⭐⭐⭐
  • 1.1.4多进程、多线程同步(通讯)的方法⭐⭐⭐⭐⭐
  • 1.1.5进程的空间模型⭐⭐⭐⭐
  • 1.1.6进程线程的状态转换图 什么时候阻塞,什么时候就绪⭐⭐⭐
  • 1.1.7父进程、子进程的关系以及区别⭐⭐⭐⭐
  • 1.1.8什么是进程上下文、中断上下文⭐⭐
  • 1.1.9一个进程可以创建多少线程,和什么有关⭐⭐

1.2 并发,同步,异步,互斥,阻塞,非阻塞的理解

  • 1.2.1什么是线程同步和互斥⭐⭐⭐⭐⭐
  • 1.2.2线程同步与阻塞的关系?同步一定阻塞吗?阻塞一定同步吗?⭐⭐⭐⭐
  • 1.2.3并发,同步,异步,互斥,阻塞,非阻塞的理解⭐⭐⭐⭐⭐

1.3 孤儿进程、僵尸进程、守护进程的概念

  • 1.3.1基本概念⭐⭐⭐⭐⭐
  • 1.3.2如何创建守护进程:⭐⭐
  • 1.3.3正确处理僵尸进程的方法⭐⭐⭐⭐

第二章 C/C++高频面试题

2.1 c和c++区别、概念相关面试题

  • 2.1.1 new和malloc的区别⭐⭐⭐⭐⭐
  • 2.1.2 malloc的底层实现⭐⭐⭐⭐
  • 2.1.3在1G内存的计算机中能否malloc(1.2G)?为什么?⭐⭐
  • 2.1.4指针与引用的相同和区别;如何相互转换?⭐⭐⭐⭐⭐
  • 2.1.5 C语言检索内存情况 内存分配的方式⭐⭐⭐
  • 2.1.6 extern”C” 的作用⭐⭐⭐
  • 2.1.7头文件声明时加extern定义时不要加 因为extern可以多次声明,但只有一个定义⭐⭐⭐⭐
  • 2.1.8函数参数压栈顺序,即关于__stdcall和__cdecl调用方式的理解⭐⭐⭐
  • 2.1.9重写memcpy()函数需要注意哪些问题⭐⭐
  • 2.1.10数组到底存放在哪里⭐⭐⭐
  • 2.1.11 struct和class的区别 ⭐⭐⭐⭐⭐
  • 2.1.12 char和int之间的转换;⭐⭐⭐
  • 2.1.13 static的用法(定义和用途)⭐⭐⭐⭐⭐
  • 2.1.14 static的用法(定义和用途)⭐⭐⭐⭐⭐
  • 2.1.15const常量和#define的区别(编译阶段、安全性、内存占用等) ⭐⭐⭐⭐
  • 2.1.16 volatile作用和用法 ⭐⭐⭐⭐⭐
  • 2.1.17有常量指针 指针常量 常量引用 没有 引用常量⭐⭐⭐
  • 2.1.18没有指向引用的指针,因为引用是没有地址的,但是有指针的引用⭐⭐⭐
  • 2.1.19c/c++中变量的作用域⭐⭐⭐⭐⭐
  • 2.1.20 c++中类型转换机制?各适用什么环境?dynamic_cast转换失败时,会出现什么情况?⭐⭐⭐

2.2 继承、多态相关面试题 ⭐⭐⭐⭐⭐

  • 2.2.1继承和虚继承 ⭐⭐⭐⭐⭐
  • 2.2.2多态的类,内存布局是怎么样的 ⭐⭐⭐⭐⭐
  • 2.2.3被隐藏的基类函数如何调用或者子类调用父类的同名函数和父类成员变量 ⭐⭐⭐⭐⭐
  • 2.2.4多态实现的三个条件、实现的原理 ⭐⭐⭐⭐⭐
  • 2.2.5对拷贝构造函数 深浅拷贝 的理解 拷贝构造函数作用及用途?什么时候需要自定义拷贝构造函数?⭐⭐⭐
  • 2.2.6析构函数可以抛出异常吗?为什么不能抛出异常?除了资源泄露,还有其他需考虑的因素吗?⭐⭐⭐
  • 2.2.7什么情况下会调用拷贝构造函数(三种情况)⭐⭐⭐
  • 2.2.8析构函数一般写成虚函数的原因⭐⭐⭐⭐⭐
  • 2.2.9构造函数为什么一般不定义为虚函数⭐⭐⭐⭐⭐
  • 2.2.10什么是纯虚函数⭐⭐⭐⭐⭐
  • 2.2.11静态绑定和动态绑定的介绍⭐⭐⭐⭐
  • 2.2.12 C++所有的构造函数 ⭐⭐⭐
  • 2.2.13重写、重载、覆盖的区别⭐⭐⭐⭐⭐
  • 2.2.14成员初始化列表的概念,为什么用成员初始化列表会快一些(性能优势)?⭐⭐⭐⭐
  • 2.2.15如何避免编译器进行的隐式类型转换;(explicit)⭐⭐⭐⭐

第三章 网络编程

3.1 TCP UDP

  • 3.1.1 TCP、UDP的区别 ⭐⭐⭐⭐⭐
  • 3.1.2 TCP、UDP的优缺点⭐⭐⭐
  • 3.1.3 TCP UDP适用场景⭐⭐⭐
  • 3.1.4 TCP为什么是可靠连接⭐⭐⭐⭐
  • 3.1.5典型网络模型,简单说说有哪些;⭐⭐⭐
  • 3.1.6 Http1.1和Http1.0的区别⭐⭐⭐
  • 3.1.7 URI(统一资源标识符)和URL(统一资源定位符)之间的区别⭐⭐

3.2 三次握手、四次挥手

  • 3.2.1什么是三次握手⭐⭐⭐⭐⭐
  • 3.2.2为什么三次握手中客户端还要发送一次确认呢?可以二次握手吗?⭐⭐⭐⭐
  • 3.2.3为什么服务端易受到SYN攻击?⭐⭐⭐⭐
  • 3.2.4什么是四次挥手⭐⭐⭐⭐⭐
  • 3.2.5为什么客户端最后还要等待2MSL?⭐⭐⭐⭐
  • 3.2.6为什么建立连接是三次握手,关闭连接确是四次挥手呢?⭐⭐⭐⭐

第四章 常见算法

4.1 排序算法

  • 4.1.1各种排序算法的时间空间复杂度、稳定性⭐⭐⭐⭐⭐
  • 4.1.2各种排序算法什么时候有最好情况、最坏情况(尤其是快排) ⭐⭐⭐⭐
  • 4.1.3冒泡排序⭐⭐⭐⭐
  • 4.1.4选择排序⭐⭐⭐⭐
  • 4.1.5插入排序⭐⭐⭐⭐
  • 4.1.6希尔排序⭐⭐⭐⭐
  • 4.1.7归并排序⭐⭐⭐⭐
  • 4.1.8快速排序⭐⭐⭐⭐⭐
  • 4.1.9快排的partition函数与归并的Merge函数⭐⭐⭐

4.2 STL库相关

  • 4.2.1 vector list异同⭐⭐⭐⭐⭐
  • 4.2.2 vector内存是怎么增长的vector的底层实现⭐⭐⭐⭐
  • 4.2.3 vector和deque的比较⭐⭐⭐⭐
  • 4.2.4为什么stl里面有sort函数list里面还要再定义一个sort⭐⭐⭐
  • 4.2.5 STL底层数据结构实现⭐⭐⭐⭐
  • 4.2.6利用迭代器删除元素会发生什么?⭐⭐⭐⭐
  • 4.2.7 map是如何实现的,查找效率是多少⭐⭐⭐⭐⭐
  • 4.2.8几种模板插入的时间复杂度 ⭐⭐⭐⭐⭐

第五章 Linux操作系统常见面试题

5.1 Linux内核相关

  • 5.1.1 Linux内核的组成⭐⭐
  • 5.1.2用户空间与内核通信方式有哪些?⭐⭐⭐⭐⭐
  • 5.1.3系统调用read()/write(),内核具体做了哪些事情⭐⭐
  • 5.1.4系统调用的作用⭐⭐⭐⭐⭐
  • 5.1.5内核态,用户态的区别⭐⭐⭐⭐⭐
  • 5.1.6 bootloader内核 根文件的关系⭐⭐⭐⭐
  • 5.1.7 Bootloader多数有两个阶段的启动过程:⭐⭐⭐
  • 5.1.8 linux的内核是由bootloader装载到内存中的?⭐⭐⭐
  • 5.1.9为什么需要BootLoader⭐⭐⭐⭐
  • 5.1.10 Linux内核同步方式总结⭐⭐⭐⭐
  • 5.1.11为什么自旋锁不能睡眠 而在拥有信号量时就可以?⭐⭐⭐⭐
  • 5.1.12 linux下检查内存状态的命令⭐⭐⭐

5.2 其他操作系统常见面试题

  • 5.2.1大小端的区别以及各自的优点,哪种时候用⭐⭐⭐⭐⭐
  • 5.2.2 一个程序从开始运行到结束的完整过程(四个过程)⭐⭐⭐⭐⭐
  • 5.2.3什么是堆,栈,内存泄漏和内存溢出?⭐⭐⭐⭐
  • 5.2.4堆和栈的区别⭐⭐⭐⭐⭐
  • 5.2.5死锁的原因、条件 创建一个死锁,以及如何预防⭐⭐⭐⭐⭐
  • 5.2.6硬链接与软链接的区别;⭐⭐⭐⭐⭐
  • 5.2.7虚拟内存,虚拟地址与物理地址的转换⭐⭐⭐⭐
  • 5.2.8计算机中,32bit与64bit有什么区别⭐⭐⭐
  • 5.2.9中断和异常的区别⭐⭐⭐⭐⭐
  • 5.2.10中断怎么发生,中断处理大概流程⭐⭐⭐⭐
  • 5.2.11 Linux 操作系统挂起、休眠、关机相关命令⭐⭐
  • 5.2.12数据库为什么要建立索引,以及索引的缺点⭐⭐

第六章 单片机常见面试题

  • 6.1 CPU 内存 虚拟内存 磁盘/硬盘 的关系⭐⭐⭐
  • 6.2 CPU内部结构⭐⭐⭐⭐
  • 6.3 ARM结构处理器简析 ⭐⭐
  • 6.4波特率是什么,为什么双方波特率要相同,高低波特率有什么区别;⭐⭐⭐⭐
  • 6.5arm和dsp有什么区别⭐⭐
  • 6.6 ROM RAM的概念浅析⭐⭐⭐
  • 6.7 IO口工作方式:上拉输入 下拉输入 推挽输出 开漏输出⭐⭐⭐⭐
  • 6.8扇区 块 页 簇的概念⭐⭐⭐⭐
  • 6.9简述处理器在读内存的过程中,CPU核、cache、MMU如何协同工作?画出CPU核、cache、MMU、内存之间的关系示意图加以说明⭐⭐
  • 6.10请说明总线接口USRT、I2C、USB的异同点(串/并、速度、全/半双工、总线拓扑等)⭐⭐⭐⭐⭐
  • 6.11什么是异步串口和同步串口⭐⭐⭐⭐⭐
  • 6.12 I2C时序图⭐⭐⭐⭐⭐

alt

高级系列专栏:

安卓(安卓系统开发也要掌握)

嵌入式

#嵌入式##嵌入式笔面经分享##嵌入式Linux开发##嵌入式面经##许乔丹嵌入式面经#
全部评论
项目怎么获取
点赞 回复 分享
发布于 02-10 23:11 山西
项目怎么获取呀
点赞 回复 分享
发布于 2024-11-20 22:06 陕西
请问如何获取项目
点赞 回复 分享
发布于 2024-11-14 12:00 广东
项目怎么获取呀
点赞 回复 分享
发布于 2024-11-12 13:25 湖南
求项目文件
点赞 回复 分享
发布于 2024-11-12 09:35 湖南
你好,请问怎么获取项目
点赞 回复 分享
发布于 2024-10-05 01:33 安徽
大佬,求项目
点赞 回复 分享
发布于 2024-09-22 21:31 美国
已经订阅,如何获得项目
点赞 回复 分享
发布于 2024-09-13 15:42 广东
项目怎么获取
点赞 回复 分享
发布于 2024-09-13 15:40 广东
请问项目怎么获取呀
点赞 回复 分享
发布于 2024-09-11 17:55 广东
求项目资料
点赞 回复 分享
发布于 2024-09-09 16:38 辽宁
请问项目如何获取?
点赞 回复 分享
发布于 2024-09-09 09:14 广东
项目怎么获取?
点赞 回复 分享
发布于 2024-09-06 00:32 广东
哪里有项目文件😣
点赞 回复 分享
发布于 2024-09-05 17:13 陕西
怎么获取项目呀
点赞 回复 分享
发布于 2024-09-05 14:28 江苏
请问项目怎么获取呀
点赞 回复 分享
发布于 2024-09-05 07:54 河南
项目可以私发一份吗
点赞 回复 分享
发布于 2024-09-05 00:35 湖北
怎么获取项目
点赞 回复 分享
发布于 2024-09-05 00:18 辽宁
请问项目怎么获取呀
点赞 回复 分享
发布于 2024-09-04 10:29 江西
请问项目怎么获取呀
点赞 回复 分享
发布于 2024-09-04 07:47 陕西

相关推荐

1.Linux系统的组成部分有哪些?Linux内核、Linux文件系统、Linux shell、Linux应用程序。  2.Linux内核的组成部分有哪些?(1)第一种分类方式:内存管理子系统、进程管理子系统、文件管理子系统、I/O管理子系统。 (2)第二种分类方式:进程调度(SCHED)、进程间通信(IPC)、内存管理(MM)、虚拟文件系统(VFS)、网络接口(NET)。 3.Linux内存管理模块MMU的作用是?(1)地址映射。 (2)内存分配和回收。 (3)内存保护。 (4)内存扩充。 4.操作系统调度策略有哪些?答案:(1)先来先服务(FCFS)。 (2)短进程优先(SPF)。 (3)高响应比优先(HRN)。 (4)时间片轮转(RR)。 (5)多级反馈队列(RRWMF)。 (6)最高优先权优先(FPF)。 解析:(1)先来先服务(FCFS):每次调度是从就绪队列中选择一个最先进入该队列的进程,为之分配处理机,使之投入运行。该进程一直运行到完成或发生某事件而阻塞后才放弃处理机。 (2)短进程优先(SPF):从就绪队列中选出一个估计运行时间最短的进程,将处理机分配给它,使它立即执行并一直执行到完成,或发生某事件而被阻塞放弃处理机时再重新调度。 (3)高响应比优先(HRN):在短作业优先的基础上,使作业的优先级随着等待时间的增加而以速率a 提高,则长作业在等待一定的时间后,必然有机会分配到处理机。 (4)时间片轮转(RR):将所有的就绪进程按先来先服务的原则排成一个队列,每次调度时,把CPU 分配给队首进程,并令其执行一个时间片,时间到了之后将它送往就绪队列的末尾。接着调度下一个队首进程……如此循环。 (5)多级反馈队列(RRWMF): ①设置多个就绪队列,并为各个队列赋予不同的优先级。第一个队列的优先级最高,第二个队列次之,其余各队列的优先权逐个降低。该算法赋予各个队列中进程执行时间片的大小也各不相同,在优先权愈高的队列中,为每个进程所规定的执行时间片就愈小。例如,第二个队列的时间片要比第一个队列的时间片长一倍,第i + 1个队列的时间片要比第i个队列的时间片长一倍。 ②当一个新进程进入内存后,首先将它放入第一队列的末尾,按FCFS原则排队等待调度。当轮到该进程执行时,如它能在该时间片内完成,便可准备撤离系统;如果它在一个时间片结束时尚未完成,调度程序便将该进程转入第二队列的末尾,再同样地按FCFS原则等待调度执行;如果它在第二队列中运行一个时间片后仍未完成,再依次将它放入第三队列,如此下去,当一个长进程从第一队列依次降到第n队列后,在第n 队列便采取按时间片轮转的方式运行。 ③仅当第一队列空闲时,调度程序才调度第二队列中的进程运行;仅当第1~(i-1)队列均空时,才会调度第i队列中的进程运行。如果处理机正在第i队列中为某进程服务时,又有新进程进入优先权较高的队列(第1~(i-1)中的任何一个队列),则此时新进程将抢占正在运行进程的处理机,即由调度程序把正在运行的进程放回到第i队列的末尾,把处理机分配给新到的高优先权进程。 (6)最高优先权优先(FPF):把处理机分配给就绪队列中优先权最高的进程,这时,又可进一步把该算法分成如下两种: ①非抢占式优先权算法:系统一旦把处理机分配给就绪队列中优先权最高的进程后,该进程便一直执行下去,直至完成;或因发生某事件使该进程放弃处理机时,系统方可再将处理机重新分配给另一优先权最高的进程。这种调度算法主要用于批处理系统中,也可用于某些对实时性要求不严的实时系统中。 ②抢占式优先权调度算法:系统同样是把处理机分配给优先权最高的进程,使之执行。但在其执行期间,只要又出现了另一个其优先权更高的进程,进程调度程序就立即停止当前进程(原优先权最高的进程)的执行,重新将处理机分配给新到的优先权最高的进程。  5.满足短作业优先又不会发生饥饿现象的操作系统调度策略是哪种?高响应比优先。  6.Linux I/O子系统的层次结构是怎样的?从上到下依次是用户层I/O软件,设备独立性软件,设备驱动程序,中断处理程序。  7.逻辑地址、线性地址、物理地址、总线地址、虚拟地址有什么区别?(1)逻辑地址:与内存段相关的偏移地址部分。例如,在C语言获取指针变量的值,就是逻辑地址,不和绝对的物理地址相关。 (2)线性地址:线性地址 = 逻辑地址 + 基地址。 (3)物理地址:如果启用了分页机制,那么线性地址使用页表项变换后就是物理地址。如果没有启用分页机制,那么线性地址就是物理地址。 (4)总线地址:x86下的I/O地址,ARM下的物理地址。(在x86下,外设的I/O地址是独立的,即有专门的指令访问外设I/O,I/O地址就是"总线地址",而RAM地址就是"物理地址"。在ARM下,I/O和RAM统一编址,但linux为了统一各个平台,仍然保留这个概念,总线地址其实就是物理地址。) (5)虚拟地址:MMU虚拟出来的地址。  8.你了解操作系统的内存分配方式吗?(1)分页存储管理:优点是不需要连续的内存空间,且内存利用率高(只有很小的页内碎片);缺点是不易于实现内存共享与保护。 (2)分段存储管理:优点是易于实现段内存共享和保护;缺点是每段都需要连续的内存空间,且内存利用率较低(会产生外部碎片)。 (3)段页式存储管理:优点是不需要连续的内存空间,内存利用率高(只有很小的页内碎片),且易于实现段内存共享和保护;缺点是管理软件复杂性较高,需要的硬件以及占用的内存也有所增加,使得执行速度下降。以上内容摘自专刊《嵌入式岗位笔试面试真题讲解》,该专刊不仅有真题讲解,还有经验分享,不清楚嵌入式该学什么的同学,想找嵌入式实习/正式工作的同学,都可以来看看:  https://blog.nowcoder.net/zhuanlan/v0ELPM#牛客AI配图神器#
查看8道真题和解析
点赞 评论 收藏
分享
评论
27
163
分享

创作者周榜

更多
牛客网
牛客企业服务