嵌入式软件面试-linux-中高级问题

 

  1. Linux系统启动过程
    • BIOS自检并加载引导程序。
    • 引导程序(如GRUB)加载Linux内核到内存。
    • 内核初始化硬件,加载驱动,建立内存管理。
    • 加载init进程(PID为1),通常是systemdSysVinit
    • init进程启动其他系统服务和守护进程。
    • 加载登录shell,用户登录,系统就绪。
  2. NAND Flash和NOR Flash的区别及坏块自检
    • NAND Flash:写入和擦除速度快,容量大,但需要专门的读取和写入接口。自检坏块通常通过厂家提供的特定命令或机制完成。
    • NOR Flash:可以像内存一样直接寻址,但写入和擦除速度较慢。坏块检测通常在出厂时完成,使用时会避开这些坏块。
  3. 线程和进程的差别
    • 进程是资源分配的基本单位,拥有独立的地址空间。
    • 线程是CPU调度的基本单位,共享进程的资源(如地址空间)。
    • 线程间通信更快,但同步和互斥更复杂;进程间通信相对较慢,但隔离性更好。
  4. 进程间通信方法
    • 包括管道、消息队列、共享内存、信号量、套接字等。
    • 评价:不同方法各有优缺点,需根据应用需求选择。
  5. 多路IO中select的实现方法和评价
    • select通过监视文件描述符集合来实现多路IO。
    • 评价:select在文件描述符较多时性能下降,因为需要遍历整个集合。
  6. epoll与select的差别和评价
    • epoll使用事件驱动机制,只需关注活跃的文件描述符。
    • 评价:epoll在大量文件描述符时性能优于select,但实现更复杂。
  7. Makefile编写
    • 定义变量、目标、依赖关系和规则。
    • 使用命令来编译、链接源文件。
    • 可以包含条件判断、循环等控制结构。
  8. gcc编译过程
    • 预处理(处理#include和宏定义)。
    • 编译(将预处理后的文件转换成汇编代码)。
    • 汇编(将汇编代码转换成机器代码)。
    • 链接(将多个目标文件和其他库文件链接成可执行文件)。
  9. gdb调试方法
    • 设置断点、单步执行、查看变量值、调用栈等。
    • 使用gdb的命令行接口进行调试。
  10. trace跟踪
    • 使用如strace、ltrace等工具进行系统调用或库函数调用的跟踪。
    • 跟踪可以帮助定位性能瓶颈或错误。
  11. TCP和UDP差别
    • TCP:面向连接,可靠传输,有流量控制和拥塞控制,适合大数据量传输。
    • UDP:无连接,不可靠传输,开销小,适合实时性要求高的应用。
  12. TCP的三挥手和四次挥手
    • 三挥手是建立连接的过程:SYN-SYNACK-ACK。
    • 四次挥手是断开连接的过程:FIN-ACK-FIN-ACK。
  13. 项目开发中的困难及解决方法
    • 困难可能包括代码调试、性能优化、团队协作等。
    • 解决方法包括使用调试工具、性能分析工具,加强团队沟通和协作等。
  14. 解决Linux系统开发中的段错误
    • 使用gdb进行调试,查看崩溃时的堆栈信息。
    • 检查指针操作是否正确,是否访问了未初始化的指针或越界访问。
    • 使用编译器的内存检查选项,如gcc的-g -o0-fsanitize=address

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

安达发|印刷包装APS生产计划排产系统的商业价值

在当今快速消费和竞争激烈的市场环境中,印刷包装行业面临着前所未有的挑战。随着客户需求的多样化、交付期限的缩短以及原材料价格的波动,传统的生产管理方法已无法满足现代印刷包装企业的复杂需求。为了保持竞争力,企业必须采用先进的生产计…

【Java Web基础】一些网页设计基础(五)

文章目录 1. 图片在盒子内部垂直居中2. 底部设计,图片或子元素居中于父盒子(水平、垂直),随着屏幕大小放大或缩小3. 使用thymeleaf的th:each会导致样式失效错乱问题 1. 图片在盒子内部垂直居中 用弹性盒子实现垂直居中及用css实现…

【联邦学习贡献评估——联邦学习优化】

1. 模型复用 贡献评估往往需要计算不同参与方组合的数据价值, 然而模型相关的价值度量指标, 比如测试准确率, 需要基于数据重新训练并评测模型, 这导致了高昂的数据价值度量代价. 为了避免重复训练联邦模型的代价, 考虑复用全体参与方组合下训练联邦模型时各参与方的梯度更新,…

tcp seq ack

seq(Sequence Number):32bits,表示这个tcp包的序列号。tcp协议拼凑接收到的数据包时,根据seq来确定顺序,并且能够确定是否有数据包丢失。 ack(Acknowledgment Number):3…

【热门话题】深入浅出:npm常用命令详解与实践

🌈个人主页: 鑫宝Code 🔥热门专栏: 闲话杂谈| 炫酷HTML | JavaScript基础 ​💫个人格言: "如无必要,勿增实体" 文章目录 标题:深入浅出:npm常用命令详解与实践引言一、npm基本概…

基于SpringBoot和Vue的大学生租房系统的设计与实现

今天要和大家聊的是一款今天要和大家聊的是一款基于SpringBoot和Vue的大学生租房系统的设计与实现。 !!! 有需要的小伙伴可以通过文章末尾名片咨询我哦!!! 💕💕作者:李同…

力扣爆刷第102天之hot100五连刷96-100

力扣爆刷第102天之hot100五连刷96-100 文章目录 力扣爆刷第102天之hot100五连刷96-100一、136. 只出现一次的数字二、169. 多数元素三、75. 颜色分类四、31. 下一个排列五、287. 寻找重复数 一、136. 只出现一次的数字 题目链接:https://leetcode.cn/problems/sing…

YOLOv3学习

YOLOv3仅使用卷积层,使其成为一个全卷积网络(FCN)。文章中,作者提出一个新的特征提取网络,Darknet-53。正如其名,它包含53个卷积层,每个后面跟随着batch normalization层和leaky ReLU层。没有池…

基于springboot的医院医护人员排班系统

技术:springbootvuemysql 一、系统背景 本医护人员排班系统管理员,医护。管理员功能有个人中心,医院信息管理,医护信息管理,医护类型管理,排班信息管理,排班类型管理,科室信息管理&…

vivado 增量实施

增量实施 增量实现是指增量编译的实现阶段设计流程: •通过重用参考设计中的先前布局和布线,保持QoR的可预测性。 •加快地点和路线的编制时间或尝试最后一英里的计时关闭。 下图提供了增量实现设计流程图。该图还说明了增量合成流程。有关增量的更多…

一命通关广度优先遍历

前言 在这篇文章之前,已对非线性结构遍历的另一种方法——深度优先遍历进行了讲解,其中很多概念词都是共用的。为了更好的阅读体验,最好先在掌握或起码了解dfs的基础上,再来阅读本文章,否则因为会有很多概念词看不明白…

每日五道java面试题之mybatis篇(六)

目录: 第一题. MyBatis⽀持动态SQL吗?第二题. 说说Mybatis的⼀级、⼆级缓存?第三题. MyBatis的功能架构是什么样的?第四题. 为什么Mapper接⼝不需要实现类?第五题. 说说Mybatis的插件运⾏原理,如何编写⼀个…

GEE入门及进阶教程|使用表达式处理图像

目录 1.EVI的算术计算 2.使用表达式计算 EVI 3.使用表达式计算 BAI 1.EVI的算术计算 增强植被指数 (EVI) 旨在最大限度地减少 NDVI 的饱和度和其他问题,在叶绿素含量高的地区(例如雨林),EVI 不会像 NDVI 那样饱和(即…

转置卷积(transposed-conv)

一、什么是转置卷积 1、转置卷积的背景 通常,对图像进行多次卷积运算后,特征图的尺寸会不断缩小。而对于某些特定任务 (如图像分割和图像生成等),需将图像恢复到原尺寸再操作。这个将图像由小分辨率映射到大分辨率的尺寸恢复操作&#xff0c…

spring boot3登录开发-2(2短信验证码接口实现)

⛰️个人主页: 蒾酒 🔥系列专栏:《spring boot实战》 🌊山高路远,行路漫漫,终有归途 目录 写在前面 上文衔接 内容简介 短信验证码接口实现 1.依赖导入 2.接口分析 3.实现思路 3.功能实现 创建发送短信…

USART串口控制LED灯

#include "uart4.h"void uart4_init() {//使能GPIORCC->MP_AHB4ENSETR |(0x1<<1);RCC->MP_AHB4ENSETR |(0x1<<6);//使能UART4RCC->MP_APB1ENSETR |(0x1<<16) ;//GPIO MODER设置 复用模式设置GPIOB->MODER |(0x2<<4);G…

C语言例:设 int i=2;float f=14;,则执行语句f=(float)i; 后。变量i 的值

代码如下&#xff1a; #include<stdio.h> int main(void) {int i2;float f14;f(float)i;printf("i %d\n",i); //i2//强制转换不会改变数据类型printf("i %.1f\n",i);return 0; } 结果如下&#xff1a;

【Leetcode每日一题】 递归 - 两两交换链表中的节点(难度⭐)(38)

1. 题目解析 题目链接&#xff1a;24. 两两交换链表中的节点 这个问题的理解其实相当简单&#xff0c;只需看一下示例&#xff0c;基本就能明白其含义了。 2.算法原理 一、理解递归函数的含义 首先&#xff0c;我们需要明确递归函数的任务&#xff1a;给定一个链表&#xf…

网速监控,实时网络速度监控

带宽与网速 现在&#xff0c;对高带宽的需求空前高涨&#xff0c;而且网络&#xff08;包括标准的内部部署&#xff09;以及公共、私有和混合环境都变得更加复杂。 虽然带宽和网速经常互换使用&#xff0c;但它们并不总是相同的。网速更多的是与延迟有关&#xff0c;而不是与…

es 集群核心概念以及实践

节点概念&#xff1a; 节点是一个Elasticsearch的实例 本质上就是一个JAVA进程一台机器上可以运行多个Elasticsearch进程&#xff0c;但是生产环境一般建议一台机器上只运行一个Elasticsearch实例 每一个节点都有名字&#xff0c;通过配置文件配置&#xff0c;或者启动时候 -…