C嵌入式面试题

C嵌入式程序开发笔试题(时间40分钟,总分:100分)

一、判断题(每题2分)

1、因为中断快速,所以代码尽量写在中断里()  FALSE
2、32 位程序开发指的指令是 32位()  FALSE
	题解:32 位程序开发指的是处理器的架构能够处理 32 位宽度的数据,而不单单是指指令本身是 32 位的。指令的长度和处理器的架构并不完全等同。例如,一些处理器可能具有 32 位的数据宽度,但它们的指令长度可能是 16 位、32 位或更长。
3、STM32的C开发可选择 Std、CMSIS、HAL或LL等库()	TRUE
	题解:CMSIS:	ARM Cortex-M 微控制器的标准软件接口,包括对处理器核心和外设的抽象层
4、标准C语言的注释方式有单行和块注释() 	TRUE
5、const int *p=&a;表示a一定是只读的()	FALSE
6、嵌入系统运行的第一条指令从 main 开始()	FALSE
7、"*”、"/"操作符的计算顺序是先算乘法后算除法()	FALSE
8、在嵌入式开发中 RTOS 指的是实时操作系统() 	TRUE
9、if语句里不能有 break() 	TRUE
10、通常按键检测需要去抖() 	TRUE

二、选择题(每题3分)

1、RAM与 ROM 的特性描述正确的一项是(A)

A、RAM 读写速度快,ROM 容量更大
C、RAM 读写速度快,容量也更大
B、ROM 读写速度快,RAM 容量更大
D、ROM 读写速度快,容量也更大

2、假设i的初值是 0,则i+++i+++i++表达式的值是(D)

A、0
B、1
C、2
D、3

3、假设 inti的初值是 0,运算结果不为1的是(B)

A、!i
B、~i
C、1-i
D、i^= 1

4、十六进制的 0000 减少1结果是(B)

A、7FFF
B、FFFF
C、8000
D、FFFE

5、以下时钟电路,按频率精度从高到低排列的是(A)

A、晶振,内部时钟发生器,RC振荡器
B、内部时钟发生器,晶振,RC振荡器
C、RC振荡器,内部时钟发生器,晶振
D、RC 振荡器,晶振,内部时钟发生器

6、按校验强度从高到低排列的是(D)

A、XOR, SUM,CRC
B、SUM,XOR,CRC
C、CRC,SUM,XOR
D、CRC,XOR, SUM

7、 不能调节 LED 亮度的是(D)

A、PWM输出
B、DAC 输出
C、高速 io 输出
D、继电器输出

8、那个不是 static的功能©

A、让函数外部不可见
B、让变量外部不可见
C、让函数在堆上分配
D、让变量在堆上分配

9、那个不是 break的功能(D)

A、打断 for
B、打断 while
C、打断switch
D、打断if

10、以下读取 64位定时器正确的是©

A、先读低32位再读高32位
B、先读高 32 位再读低 32 位
C、先读高再读低,再次读高
D、以上都对

三、填空题(每空2分)

1、常见的串行通信接口有
	答:IIC,SPI,uart
2、C语言中堆与栈的区别
	答:1、堆是由程序员处理的,栈是系统处理
		2、堆的空间足够大,栈的空间比较小
		3、堆是由高地址到低地址,栈是由低地址到高地址
		4、
3、嵌入式开发中常用的通信外设有
	答:IIC,SPI,RS485,
4、写出常见的几个嵌入式操作系统、
	答:ubuntu,rtos,vxworks

四、编程题(每题 10 分)
1、完成只修改 Reg 第 13 位为k的表达式

#define BIT_POS 13 /*范围:0~31 */
Reg =     Reg & ~(k << 13)   ;/*k为O或1*/

2、编写一个逐字节求和的函数

#include <stdio.h>
#include <stdint.h>
uint32_t checksum(const uint8_t *data, size_t length) {
    uint32_t sum = 0;

    // 逐字节计算和
    for (size_t i = 0; i < length; i++) {
        sum += data[i];
    }

    // 处理可能的溢出,确保结果在 32 位范围内
    sum = (sum & 0xFFFFFFFF);

    return sum;
}

int main() {
    // 测试数据
    uint8_t data[] = {0x12, 0x34, 0x56, 0x78};
    size_t length = sizeof(data) / sizeof(data[0]);

    uint32_t result = checksum(data, length);
    printf("Checksum: 0x%X\n", result);

    return 0;
}
image-20240903131938895

3、编写一个字符串反转函数

void StrReverse(char *pStr)
{
}#include <stdio.h>
#include <string.h>
void StrReverse(char *pStr)
{
	int i,j;
	char c;
	i = 0;
	j = strlen(pStr) - 1;
	printf("j = %d\n",j);
	while(i <= j){
		c = pStr[i];
		pStr[i] = pStr[j];
		pStr[j] = c;
		i++;j--;
	}
}
int main()
{
	char arr[] = "dingyanxiong";
	printf("arr = %s\n",arr);
	StrReverse(arr);
	printf("arr = %s\n",arr);
	return 0;
}
image-20240903132648371
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

牲码

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值