知识点
1、如果#define定义在某个.c文件中,那么其他文件就用不了了,只有定义在.h中,其他文件引用这个.h,那么才能使用这个#define
static也是同样的,只能在当前.c文件中使用
堆栈
参考资料1
1、数据结构的堆(heap)栈(stack)和内存中的堆栈是不同的
2、在 C 语言中,内存分配方式不外乎有如下三种形式:
- 从静态存储区域分配:它是由编译器自动分配和释放的,即内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在,直到整个程序运行结束时才被释放,如全局变量与 static 变量还有一个字符串常量(整个C只有这三个是放在静态存储区中的)。
- 在栈上分配:它同样也是由编译器自动分配和释放的,即在执行函数时,函数内局部变量的存储单元都可以在栈上创建,函数执行结束时这些存储单元将被自动释放。需要注意的是,栈内存分配运算内置于处理器的指令集中,它的运行效率一般很高,但是分配的内存容量有限。
- 从堆(heap)上分配:也被称为动态内存分配,它是由程序员手动完成申请和释放的。即程序在运行的时候由程序员使用内存分配函数(如 malloc 函数)来申请任意多少的内存,使用完之后再由程序员自己负责使用内存释放函数(如 free 函数)来释放内存。也就是说,动态内存的整个生存期是由程序员自己决定的,使用非常灵活。需要注意的是,如果在堆上分配了内存空间,就必须及时释放它,否则将会导致运行的程序出现内存泄漏等错误。
3、最后介绍一下 C 语言中各类型变量的存储位置和作用域。
- 全局变量:从静态存储区域分配,其作用域是全局作用域,也就是整个程序的生命周期内都可以使用。与此同时,如果程序是由多个源文件构成的,那么全局变量只要在一个文件中定义,就可以在其他所有的文件中使用,但必须在其他文件中通过使用extern关键字来声明该全局变量。
- 全局静态变量:从静态存储区域分配,其生命周期也是与整个程序同在的,从程序开始到结束一直起作用。但是与全局变量不同的是,全局静态变量作用域只在定义它的一个源文件内,其他源文件不能使用。
- 局部变量:从栈上分配,其作用域只是在局部函数内,在定义该变量的函数内,只要出了该函数,该局部变量就不再起作用,该变量的生命周期也只是和该函数同在。
- 局部静态变量:从静态存储区域分配,其在第一次初始化后就一直存在直到程序结束,该变量的特点是其作用域只在定义它的函数内可见,出了该函数就不可见了。
移动
按照0-8排列
第0位要到第几位上去,就直接向右移动几位就行(移动几位就是加几)
字符编码
- Ascii(67):American Standard Code for Information Interchange,美国信息互换标准代码。只能用来表示英文,所以后来中文要加入进来时,就创建了GB2312 。
- GB2312(80) 信息交换用汉字编码字符集。通过以下方式做到与ASCII兼容:当我们设定系统使用 GB2312 标准的时候,它遇到一个字符串时,会按字节检测字符值的大小,若遇到连续两个字节的数值都大于127 时就把这两个连续的字节合在一起,用 GB2312 解码,若遇到的数值小于 127,就直接用 ASCII 把它解码。(快要退出历史舞台了,用的很少了)
- GBK (95):就是在 GB2312 标准的基础上增加了 14240 个新汉字 (包括所有后面介绍的 Big5 中的所有汉字) 和符号,这个方案被称为 GBK 标准。(现在政策要求,所有微软的系统进入中国默认编码是要GBK),GBK兼容GB2312,增加这么多字符,按照 GB2312 原来的格式来编码,2 个字节已经没有足够的编码,因此不再要求第 2 个字节的编码值必须大于 127,只要第 1 个字节大于 127 就表示这是一个汉字的开始,这样就做到了兼容 ASCII 和 GB2312 标准。
- unicode(91):万国码,为世界上所有字符都分配了一个唯一的数字编号。Unicode就相当于一张表,建立了字符与编号之间的联系。
- UTF-8(92):UTF,是Unicode Transformation Format的缩写,意为Unicode转换格式。更好的使用unicode(因为使用unicode占用内存大),可以解决存储和网络传输的问题(在计算机内存中,统一使用unicode编码,当需要保存到硬盘或者需要传输的时候,就转换为UTF-8编码。比如:用记事本编辑的时候,从文件中读取的UTF-8字符被转换为unicode字符到内存里,编辑完成后,保存的时候再把unicode转换为UTF-8保存文件)。对于英文字母,UTF-8编码和ASCII码是相同的,不过使用 UTF-8 编码汉字平均需要 3 个字节,比 GBK 编码要多一个字节,所以中国人用这个还是比较吃亏的。(UTF-8使用1/2/3/4个字节表示所有字符;优先使用1个字节,无法满足则增加一个字节,最多4个字节。英文占一个,欧洲语系占两个、东亚占3个,其他特殊字符占4个)
- UTF-8比GB2312的通用性更强,国内外都可以使用,但是会更大一些
在keil中,我们要发送的字符串,会根据keil中设定的编码方式,进行编码与发送的,有些设备只能接收gb2312,那就不能设定为utf-8
i++和++i
- i++和++i都是实现变量i的自增,两者的区别在于i++是先运算,再加1,而++i是先加1,后运算。
- i++,先是所在式子结束了再自+。可参考上面的for,其中的i++和++i都是一样的。
- 最后还有一个在指针中的应用
#include <stdio.h>
int main(int argc, char *argv[])
{
char a[100];
char b=<