嵌入式笔试刷题(第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 语言为例):

  1. time()(来自 <time.h>)返回自 Unix 纪元以来的秒数精度较低
  2. gettimeofday()(Linux)返回秒和微秒精度高,常用于性能测试
  3. clock_gettime()(POSIX)支持纳秒级精度,支持多种时钟源使用较复杂

14. 用 C++ 实现键盘输入 10 个数,按顺序输出并输出总和。

#include <iostre

剩余60%内容,订阅专栏后可继续查看/也可单篇购买

嵌入式笔试专栏 文章被收录于专栏

本专栏系统整理了嵌入式方向笔试中常见的知识点和高频考题,涵盖基础理论、常用算法、C语言陷阱、操作系统原理、驱动开发、常见外设通信协议(如 I2C/SPI/UART)、RTOS、Linux 内核、以及实用电路知识等内容。

全部评论
点赞 回复 分享
发布于 04-25 21:41 山西
接好运
点赞 回复 分享
发布于 04-15 15:01 黑龙江

相关推荐

评论
2
1
分享

创作者周榜

更多
牛客网
牛客企业服务