电子设计大赛【C语言核心知识点】讲解

发布于:2025-07-28 ⋅ 阅读:(15) ⋅ 点赞:(0)

 目录

前言

1. 基础语法

2. 流程控制

3. 函数

4. 数组与字符串

5. 指针(核心重点)

6. 内存管理

7. 结构体与联合体

8. 文件操作

9. 预处理器

10. 高级特性

内存布局图解


前言

在进行程序代码开发之前,需要掌握好C语言各个模块之间的内容。在TI开发板时,需要对C语言有更好的理解和应用,其中,主要考察的是对代码的操作和库函数的调用。因此,对于本次比赛内容,重新对C语言知识进行讲解。


1. 基础语法

模块 内容 示例 要点
数据类型 基本类型、派生类型 int a; float b; char c; 内存占用:char(1B) int(4B) float(4B) double(8B)
变量与常量 变量声明/初始化、常量定义 const int MAX=100; 命名规则:字母/数字/下划线,区分大小写
运算符 算术、关系、逻辑、位运算 a & b; c << 2; 优先级:`() > ! > 算术 > 关系 > && > > 赋值`
输入输出 printf()/scanf() printf("%d,%f", num, f); 格式符:%d整型 %f浮点 %c字符 


2. 流程控制

类型 语法结构 示例 应用场景
条件语句

if-else switch-case

if(score>90) grade='A';
else if(score>60) grade='B';

| 多分支判断 |
循环结构 | for while do-while |

for(int i=0; i<10; i++){
    sum += i;
}

| 重复操作 |
跳转语句 | break continue goto |

while(1){
    if(error) break;
}

| 中断循环/函数返回 |


3. 函数

模块 内容 示例 要点
函数定义 返回值类型、参数列表
int add(int a, int b) {
    return a+b;
}

| 需先声明后使用 |
参数传递 | 值传递、地址传递 |

void swap(int *x, int *y) {
    int t=*x; *x=*y; *y=t;
}

| 地址传递可修改实参 |
递归函数 | 函数调用自身 |

int factorial(int n) {
    if(n<=1) return 1;
    return n*factorial(n-1);
}

| 需有终止条件,栈空间有限 |
作用域 | 局部变量、全局变量 | static int count; | static延长生命周期,限制作用域 |


4. 数组与字符串

类型 声明方式 操作 注意事项
一维数组 int arr[5]; 索引访问:arr[0]=10; 下标从0开始,内存连续
多维数组 int matrix[3][3]; 嵌套循环遍历 行优先存储
字符数组 char str[20]; strcpy(s1,s2); strlen(s); '\0'结尾
字符串函数 <string.h>
strcat(s1,s2); // 拼接
strcmp(s1,s2); // 比较

| 注意缓冲区溢出风险 |


5. 指针(核心重点)

概念 语法 示例 应用场景
基本指针 变量地址操作
int *p = &a;
*p = 20; // 修改a的值

| 间接访问变量 |
指针运算 | 算术运算、关系运算 | p++; p1-p2; | 数组遍历、内存操作 |
数组指针 | 指针与数组关系 |

int arr[5];
int *p = arr; // p等价&arr[0]

| 数组名是常量指针 |
函数指针 | 指向函数的指针 |

int (*funcPtr)(int);
funcPtr = &add;

| 回调函数、策略模式 |
多级指针 | 指针的指针 | int **pp = &p; | 动态二维数组 |


6. 内存管理

操作 函数 示例 注意事项
静态分配 编译时分配 int arr[100]; 栈空间有限(通常1-8MB)
动态分配 malloc/calloc
int *p = (int*)malloc(10*sizeof(int));

| 堆空间较大,需手动释放 |
内存释放 | free() | free(p); p=NULL; | 避免野指针 |
内存操作 | memset/memcpy |

memset(p, 0, 100); // 内存置0
memcpy(dest, src, size);

| 底层内存操作 |


7. 结构体与联合体

类型 定义方式 特点 应用场景
结构体
struct Student {
    char name[20];
    int age;
};

| 不同数据类型的集合 | 数据封装 |
结构体指针 |

struct Student *s;
s->age = 20;

| 箭头运算符访问 | 动态结构体 |
联合体 |

union Data {
    int i;
    float f;
};

| 共享内存空间 | 节省内存、类型转换 |
枚举 |

enum Color {RED, GREEN=5, BLUE};

| 命名常量集合 | 状态机、选项设置 |


8. 文件操作

操作 函数 模式 示例
打开文件 fopen() "r"读 "w"写 "a"追加 FILE *fp = fopen("data.txt","r");
读写数据 fprintf/fscanf 格式化I/O
fprintf(fp, "%d", num);
fscanf(fp, "%d", &num);

字符I/O | fgetc/fputc | 单个字符 | ch = fgetc(fp); |
行I/O | fgets/fputs | 字符串 | fgets(buf, 100, fp); |
关闭文件 | fclose() | 释放资源 | fclose(fp); |


9. 预处理器

指令 功能 示例 应用场景
宏定义 #define #define PI 3.14159 常量定义、代码简化
条件编译 #ifdef/#endif
#ifdef DEBUG
    printf("Debug info");
#endif

10. 高级特性

特性 说明 示例 应用
位字段 紧凑存储布尔值
struct {
    unsigned int isReady:1;
    unsigned int hasData:1;
} status;

| 硬件寄存器操作 |
可变参数 | 不定参数函数 |

#include <stdarg.h>
void func(int n, ...) {
    va_list args;
    va_start(args, n);
    int val = va_arg(args, int);
}

printf()实现原理 |
内联函数 | inline关键字 | inline int max(int a, int b); | 减少函数调用开销 |
类型限定符 | const volatile | volatile int *reg; | 硬件编程、编译器优化控制 |


内存布局图解

+------------------+
|   代码区         | 程序指令(只读)
+------------------+
|   静态数据区      | 全局/静态变量
+------------------+
|       ↓ 堆       | 动态分配(malloc等)
|       ↑          |
+------------------+
|       ↓ 栈       | 局部变量、函数调用
|       ↑          |
+------------------+
|   命令行参数      | argc/argv
+------------------+



网站公告

今日签到

点亮在社区的每一天
去签到