c语言小知识整理

这篇博客主要介绍了C语言的基础知识,包括知识点如#define的作用、堆栈内存分配、移动操作、字符编码,以及i++和++i的区别。还讲解了不同类型变量的占用大小、线程与进程的概念、哈希、debug与release模式的区别以及库(lib与dll)的类型和作用。博客内容详细,适合C语言初学者阅读。
摘要由CSDN通过智能技术生成

知识点

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=<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

成草

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值