C语言复杂表达式和指针高级应用
2016-04-29 16:05
459 查看
《朱老师物联网大讲堂》学习笔记
学习地址:www.zhulaoshi.org
(1).
指针数组,实质是数组,数组中存储的内容是指针变量,
数组指针,实质是指针,这个指针指向的是一个数组,
首先int *p; int p[5];前者是指针,后者是数组,
int *p[5];
核心是p,p是数组,数组有5个元素,每个元素都是指针,指针指向类型是int,整个符号是指针数组,
int (*p)[5];
核心是p,p是指针,指向数组,有5个元素,里面存的是int类型,
int *(p[5]);
同第一个,
1.p是核心,
2.找结合,找结合,找结合,,,
Ps:核心和*结合,表示是指针,和[]结合,表示是数组,和()结合表示是函数,
[]优先级大于*,
(2).
函数指针,还是指针变量,
函数的实质是一段代码,这段代码在内存中是连续分布的,函数名代表这段代码的首地址,
函数:void func( void );对应的函数指针:void ( *p )( void );类型是: void (*)( void );如果类型不匹配会警告或者报错,
函数名的一个特点,做右值时加不加&效果和意义都一样,
typedef char* (*ptype)(char *, const char *);
char * (*p1)(char *, const char *);
ptype p2;
p2 = p1;
结果是类型一致,你看吧~
(3).
函数指针实现多态之计算器,
(4).
函数指针多态之计算器,外加分层实现。
(5).
typedef struct student1
{
char name[20];
int age;
}student2,*p;
struct student1 s1;
student2 s2;
这两个效果一样,
const与tpyedef结合使用的陷阱,
内核中先定义typedef int size_t;
然后在特定情况下用size_t来代替int,
(6).
二重指针,它指向的变量类型必须是一重指针,
C语言为什么发明二重指针?原因和发明函数指针,数组指针,结构体指针一样,
(7).
二维数组,
int a[2][5],用楼房比喻,2代表楼层,5代表某层的房间,不同于内存的是,内存是规则连续的,试着把楼层拉直来想,
从思维角度来看,适合不同的应用场景,从效率角度来看与一维差不多,
二维数组的两种访问方式,
a[i][j]等同于*(*(p+i)+j),
(8).
int a[3][5];
int *p1 = a; //错误
int **p2 = a; //错误
int (*p3)[5] = a; //正确
我只说一句话:a是一个数组,数组中的每个元素又是一个拥有5个元素的数组,所以使用指针方式访问数组中的元素时侯,必须满足指针所指向的对象类型和数组中元素类型一致。
学习地址:www.zhulaoshi.org
(1).
指针数组,实质是数组,数组中存储的内容是指针变量,
数组指针,实质是指针,这个指针指向的是一个数组,
首先int *p; int p[5];前者是指针,后者是数组,
int *p[5];
核心是p,p是数组,数组有5个元素,每个元素都是指针,指针指向类型是int,整个符号是指针数组,
int (*p)[5];
核心是p,p是指针,指向数组,有5个元素,里面存的是int类型,
int *(p[5]);
同第一个,
1.p是核心,
2.找结合,找结合,找结合,,,
Ps:核心和*结合,表示是指针,和[]结合,表示是数组,和()结合表示是函数,
[]优先级大于*,
(2).
函数指针,还是指针变量,
函数的实质是一段代码,这段代码在内存中是连续分布的,函数名代表这段代码的首地址,
函数:void func( void );对应的函数指针:void ( *p )( void );类型是: void (*)( void );如果类型不匹配会警告或者报错,
函数名的一个特点,做右值时加不加&效果和意义都一样,
typedef char* (*ptype)(char *, const char *);
char * (*p1)(char *, const char *);
ptype p2;
p2 = p1;
结果是类型一致,你看吧~
(3).
函数指针实现多态之计算器,
(4).
函数指针多态之计算器,外加分层实现。
(5).
typedef struct student1
{
char name[20];
int age;
}student2,*p;
struct student1 s1;
student2 s2;
这两个效果一样,
const与tpyedef结合使用的陷阱,
内核中先定义typedef int size_t;
然后在特定情况下用size_t来代替int,
(6).
二重指针,它指向的变量类型必须是一重指针,
C语言为什么发明二重指针?原因和发明函数指针,数组指针,结构体指针一样,
(7).
二维数组,
int a[2][5],用楼房比喻,2代表楼层,5代表某层的房间,不同于内存的是,内存是规则连续的,试着把楼层拉直来想,
从思维角度来看,适合不同的应用场景,从效率角度来看与一维差不多,
二维数组的两种访问方式,
a[i][j]等同于*(*(p+i)+j),
(8).
int a[3][5];
int *p1 = a; //错误
int **p2 = a; //错误
int (*p3)[5] = a; //正确
我只说一句话:a是一个数组,数组中的每个元素又是一个拥有5个元素的数组,所以使用指针方式访问数组中的元素时侯,必须满足指针所指向的对象类型和数组中元素类型一致。
相关文章推荐
- 如何组织构建多文件 C 语言程序(二)
- 关于指针的一些事情
- 如何写好 C main 函数
- Lua和C语言的交互详解
- C# Pointer指针应用实例简述
- 关于C语言中参数的传值问题
- 简要对比C语言中三个用于退出进程的函数
- 深入C++中API的问题详解
- 基于C语言string函数的详解
- C语言中fchdir()函数和rewinddir()函数的使用详解
- C语言内存对齐实例详解
- C语言编程中统计输入的行数以及单词个数的方法
- C语言自动生成enum值和名字映射代码
- 使用C语言判断英文字符大小写的方法
- c语言实现的带通配符匹配算法
- C语言实现顺序表基本操作汇总
- C语言中计算正弦的相关函数总结
- 使用C语言详解霍夫曼树数据结构
- C语言实现选择排序、冒泡排序和快速排序的代码示例
- 探讨C语言的那些小秘密之断言