嵌入式笔试题+面试题

一、嵌入式笔试题

1) int a;
2) int *a;
3) int **a;
4) int a[10];
5) int *a[10];
6) int (*a)[10];
7) int (*a)(int);
8) int (*a[10])(int);
(1) 一个整型数
(2) 一个指向整型数的指针
(3) 一个指向指针的的指针,它指向的指针是指向一个整型数
(4) 一个有10个整型数的数组
(5) 一个有10个指针的数组,该指针是指向一个整型数
(6) 一个指向有10个整型数数组的指针
(7) 一个指向函数的指针,该函数有一个整型参数并返回一个整型数
(8) 一个有10个指针的数组,该指针指向一个函数,该函数有一个整型参数并返回一个整型数

int (*a)[]
int (**a)[]
int **a[10]
(1) 以上各行代码在作为函数形参时分别是什么意思?
(2) 以上各行代码出现在变量定义时分别是什么意思?

数组指针:int (*a)[10];
指针数组:int *a[10];
函数指针:int (*a)(int);
指针函数:int *a(int);

int f(int *a[10]);
int f(int *a[]);
int f(int **a);
这三行东西有什么区别吗?

数组 / 指针 / 数组指针 / 指针数组

关键字
Static、Const、Volatile
Const和Volatile同时修饰一个参数

const int a;
int const a;
const int * a; // a是一个指向常整型数的指针
int * const a; // a是一个指向整型数的常指针
int const * a const;

相关连接

c/c++笔试题整理
经典16道:嵌入式C语言笔试题
从一道C语言数组指针的笔试题看面试者的能力和心态

内存管理

深入理解Linux内存管理--目录导航
探索 Linux 内存模型
Linux 驱动面试题总结

笔试代码

// 01.c


#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define Max(x,y)  ((x) > (y) ? (x) : (y))
#define Min(x,y)  ((x) < (y) ? (x) : (y))

int str_to_matrix(char * s, char * d, int * line, int * row)
{
  unsigned int i = 0;
  unsigned int mlen = 0;

  if(s==NULL || d==NULL || line==NULL || row==NULL)
    return -1;

  *line = 0;
  *row = 0;

  while(s[i] != '\0')
  {
    if(s[i] == '0' || s[i] == '1')
    {
      d[mlen] = s[i];
      mlen++;
    }

    if(s[i] == '\n')
    {
      *line = *line + 1;
    }

    i++;
  }

  *line = *line - 1;
  *row = mlen/(*line);
}

int main(void)
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值