嵌入式笔试刷题(第16天)
11. 请解释以下内容:
void *(*(fp1)(int))[10]; float (*(*fp2)(int, int, float))(int); typedef double (*(*(*fp3)())[10])(); fp3 a; int (*(*f4())[10])();
✅ 解析:
这些是复杂的函数指针声明,可以使用从内到外的解读法。
- fp1:fp1 是一个函数,参数是 int,返回一个包含10个指针的数组,这些指针指向 void 类型。
- fp2:fp2 是一个函数指针,参数为 int, int, float,返回一个指向函数的指针,该函数的参数是 int,返回 float。
- fp3 和 a:fp3 是一种返回指针数组的函数指针类型,这些数组的元素又是函数指针,最终返回 double。
- f4:f4 是一个函数,返回一个指针,该指针指向一个包含10个函数指针的数组,这些函数指针的返回类型为 int。
12. C语言写个排序算法,并说明其优缺点。
✅ 示例(冒泡排序):
void bubble_sort(int arr[], int n) { for (int i = 0; i < n - 1; i++) { for (int j = 0; j < n - 1 - i; j++) { if (arr[j] > arr[j+1]) { int tmp = arr[j]; arr[j] = arr[j+1]; arr[j+1] = tmp; } } } }
✅ 优缺点:
- 优点:实现简单,适合小数据集,稳定排序。
- 缺点:效率低,时间复杂度 O(n²),不适合大数据量。
13. 取得当前时间的方法有哪些,说明优缺点。
✅ 常见方式(以 C 语言为例):
- time()(来自 <time.h>)返回自 Unix 纪元以来的秒数精度较低
- gettimeofday()(Linux)返回秒和微秒精度高,常用于性能测试
- clock_gettime()(POSIX)支持纳秒级精度,支持多种时钟源使用较复杂
14. 用 C++ 实现键盘输入 10 个数,按顺序输出并输出总和。
#include <iostre
剩余60%内容,订阅专栏后可继续查看/也可单篇购买
嵌入式笔试专栏 文章被收录于专栏
本专栏系统整理了嵌入式方向笔试中常见的知识点和高频考题,涵盖基础理论、常用算法、C语言陷阱、操作系统原理、驱动开发、常见外设通信协议(如 I2C/SPI/UART)、RTOS、Linux 内核、以及实用电路知识等内容。