全国计算机等级考试二级教程-C语言程序设计_第13章_编译预处理和动态存储分配
free(p);//释放内存
p = NULL;//软件工程规范,释放内存以后,指针应该赋值为空
#define _CRT_SECURE_NO_WARNINGS #include<stdio.h>
#include<stdlib.h>
//内存不可以反复释放,内存释放以后不可以引用,否则会出现垃圾数据
//内存释放以后,指针应该赋值为空,就可以规避再次引用,以及反复释放的问题 void check(int *px)
{
int i;
for (i = ;i < ;i++)//循环遍历
{
if (px[i] < )//抓不及格
{
printf("%d\n", px[i]);
}
}
} main()
{
int num;
int i;
scanf("%d", &num);
printf("num=%d\n", num); int *p = (int *)malloc(sizeof(int)*num); if (p == NULL)
{
printf("fail");
}
else
{
printf("succes\n");
for (i = ;i < num;i++)
{
p[i] = i;
printf("%d\n", p[i]);
}
printf("p=%x\n", p); free(p);//释放内存
p = NULL;//软件工程规范,释放内存以后,指针应该赋值为空 printf("p=%x\n", p);//内存释放以后,指针的值并不发生变化
printf("%d\n", p[]);//如果再次引用指针,就会出现垃圾数值
//如果指针为空,软件测试的时候就可以快速定位错误,否则的话,就会留下软件故障的隐患
} system("pause");
}
建立动态数组,输入5个学生的成绩,另外用一个函数检查其中有无低于60,输出不及格的成绩
#define _CRT_SECURE_NO_WARNINGS #include<stdio.h>
#include<stdlib.h> void check(int *px)
{
int i;
for (i = ;i < ;i++)//循环遍历
{
if (px[i] < )//抓不及格
{
printf("%d\n", px[i]);
}
}
} main()
{
int *p = (int *)malloc(sizeof(int) * );
int i; for (i = ;i < ;i++)
{
scanf("%d", &p[i]);
} printf("\n");
check(p); system("pause");
}
malloc,calloc都是分配内存,malloc根据大小,calloc根据元素大小还有个数
malloc分配后不会初始化,calloc会自动初始化为0
realloc就是内存不够用的情况下,拓展内存。如果原来的内存后部无人使用,就直接拓展。有人使用,就重新分配,并且先复制原来内存的内容,然后回收原来的内存
malloc函数
malloc函数返回值的类型为void *,函数的调用形式为:malloc(size);
#define _CRT_SECURE_NO_WARNINGS #include<stdio.h>
#include<stdlib.h> main()
{
int num;
int i;
scanf("%d", &num);
printf("num=%d\n", num); int *p = (int *)malloc(sizeof(int)*num); printf("%x\n", p); if (p == NULL)
{
printf("fail"); }
else
{
printf("succes\n");
for (i = ;i < num;i++)
{
p[i] = i;
printf("%d\n", p[i]);
}
free(p);
} system("pause");
}
calloc函数
calloc函数返回值的类型为void *,函数的调用形式为:calloc(n, size);
通过调用calloc函数所分配的存储单元,系统自动置初值为0
#define _CRT_SECURE_NO_WARNINGS #include<stdio.h>
#include<stdlib.h> main()
{
int num;
int i;
scanf("%d", &num);
printf("num=%d\n", num); int *p = (int *)calloc(num, sizeof(int)); printf("%x\n", p); if (p == NULL)
{
printf("fail"); }
else
{
printf("succes\n");
for (i = ;i < num;i++)
{
p[i] = i;
printf("%d\n", p[i]);
}
free(p);
} system("pause");
}
realloc函数
#define _CRT_SECURE_NO_WARNINGS #include<stdio.h>
#include<stdlib.h> main()
{
int num, addnum;
int i;
scanf("%d %d", &num, &addnum);
printf("num=%d,addnum=%d\n", num, addnum); int *p = (int *)malloc(sizeof(int)*num); if (p == NULL)
{
printf("fail");
}
else
{
printf("succes\n");
for (i = ;i < num;i++)
{
p[i] = i;
printf("%d\n", p[i]);
}
//重新分配内存,如果可以拓展就拓展,否则就重新分配
//拓展就是原来地址后面增加内存
//不够的情况下,就回收原来的内存,并在回收之前分配一片内存,将原来的内存复制过来
int *px = realloc((void *)p, sizeof(int)*(addnum + num));
for (i = num;i < num + addnum;i++)
{
px[i] = i;
printf("%d\n", px[i]);
}
free(px);
} system("pause");
}
define和const区别
#define _CRT_SECURE_NO_WARNINGS #include<stdio.h>
#include<stdlib.h> #define N 20 main()
{
int a[N]; //printf("%x", &N);编译器放在常量区,没有地址,无从修改 const int num = ;//可变的常量,可以强制去掉常量的属性 printf("%x", &num); system("pause");
}
传统数组的缺点:
1 数组长度必须事先制定,且只能是常整数,不能是变量。
#include<stdio.h>
main()
{
int a[]; /* OK */ int len = ; /* error */
int a[len];
}
2 传统形式定义的数组,该数组的内存程序员无法手动释放。
在一个函数运行期间,系统为该函数中数组所分配的空间会一直存在,直到该函数运行完毕时,数组的空间才会被系统释放。
3 数组的长度一旦定义,其长度就不能再更改。
数组的长度不能在函数运行的过程中动态的扩充或缩小。
4 A函数定义的数组,在A函数运行期间可以被其他函数使用,但A函数运行完毕之后,A函数中的数组将无法再被其他函数使用。
传统方式定义的数组不能跨函数使用。
#include<stdio.h>
main()
{
int i = ; /* 分配了4个字节,静态分配 */ int * p = (int *)malloc();
/*
malloc函数只有一个形参,并且形参是整型
4表示请求系统为本程序分配4个字节
malloc函数只能返回第一个字节的地址
上述语句分配了8个字节,p变量占4个字节,p所指向的内存也占4个字节
p本身所占的内存是静态分配的,p所指向的内存是动态分配的
*/ free(p);
/*
表示把p所指向的内存给释放掉
p本身的内存是静态的,不能由程序员手动释放,p本身的内存只能在p变量所在的函数运行终止时由系统自动释放
*/
}
动态一维数组
#include<stdio.h>
main()
{
int i;
int len;
int * parr; printf("请输入你要存放的元素的个数:\n");
scanf("%d", &len); parr = (int *)malloc( * len); printf("请输入你要存放的元素:\n");
for (i = ;i < len;++i)
{
scanf("%d", &parr[i]);
} printf("一维数组的内容是:\n");
for (i = ;i < len;++i)
{
printf("%d ", parr[i]);
}
}
动态内存和静态内存的比较:
静态内存是有系统自动分配,由系统自动释放。
静态内存是在栈分配的。
动态内存是由程序员手动分配,手动释放。
动态内存是在堆分配的。
全国计算机等级考试二级教程-C语言程序设计_第13章_编译预处理和动态存储分配的更多相关文章
- 全国计算机等级考试二级教程-C语言程序设计_第4章_选择结构
switch什么时候用break,什么时候不用break 调用break:一次执行一个分支,输入一个数据,对应一个级别 不调用break:连续执行多个分支 if...else 可以处理任何情况,大于小 ...
- 全国计算机等级考试二级教程-C语言程序设计_第8章_地址和指针
面试: unsigned int *p1 = # int *p2 = # #define _CRT_SECURE_NO_WARNINGS #include<std ...
- 全国计算机等级考试二级教程-C语言程序设计_第15章_位运算
位运算,不适用于实数,仅仅适用于整数.字符. C语言的位运算只能操作整数.字符,实数是指数方式表示的,不适用于位运算. #define _CRT_SECURE_NO_WARNINGS #include ...
- 全国计算机等级考试二级教程-C语言程序设计_第9章_数组
四维数组,可用于航天卫星,三维+时间 #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<stdlib.h> ...
- 全国计算机等级考试二级教程-C语言程序设计_第14章_结构体、共用体和用户定义类型
函数的返回值是结构体类型 #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<stdlib.h> struct ...
- 全国计算机等级考试二级教程-C语言程序设计_第10章_字符串
字符型指针数组 #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<stdlib.h> //参数中,int a ...
- 全国计算机等级考试二级教程-C语言程序设计_第5章_循环结构
for循环结构的嵌套 外层循环每循环一次,内层循环会完整循环一次. 外层循环是竖. 内层循环是横. for, do...while, while的选择: 如果有固定次数,如阶乘! ,判断素数,用 fo ...
- 全国计算机等级考试二级教程-C语言程序设计_第3章_顺序结构
1输入两个整数给变量x和y:然后输出x和y:在交换x和y中的值后,在输出x和y. #include <stdio.h> main() { int x, y, t; printf(" ...
- 全国计算机等级考试二级教程-C语言程序设计_第2章_C程序设计的初步知识
正负号与被除数一致. 3 % (-5) == 3 (-3) % 5 == -3 不用求余运算符,求出余数. int x, y; 答:x - x / y * y; const int i = 10; c ...
- 全国计算机等级考试二级教程-C语言程序设计_第7章_函数
函数执行,从右到左执行 #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<string.h> main() ...
随机推荐
- 2014.06.20 (转)IEEE与论坛灌水
转自"饮水思源" 电子类学生大都知道IEEE, 这个IEEE就像一个大的BBS论坛,而这个协会下面有很多杂志,比如图像处理,信号处理,微波技术等.这些杂志就是论坛下的分版 ...
- Hadoop 4、Hadoop MapReduce的工作原理
一.MapReduce的概念 MapReduce是hadoop的核心组件之一,hadoop要分布式包括两部分,一是分布式文件系统hdfs,一部是分布式计算框就是mapreduce,两者缺一不可,也就是 ...
- OAuth2.0基本流程
用户请求客户端>客户端通过在授权服务器上申请的apikey和apisceret>登录访问资源服务器
- GCC单独编译host/examples/ tx_waveforms.cpp
1.编译 须要链接uhd库和boost_program_options库以及boost_thread库: g++ tx_waveforms.cpp -o a -luhd -lboost_program ...
- SQL Common Sense 碎片一
1.关于时间 SELECT GETDATE() SELECT DATEPART(d,'2014-05-20 14:20:55.347') SELECT DATEDIFF(d,'2014-05-20 1 ...
- tab.js分享及浏览器兼容性问题汇总
在 样式布局分享-基于frozen.js的移动OA 文章中,用了到第三方组件 tab.js(带菜单的横屏滑动插件),其兼容性很差,进行优化后,已兼容全平台(且支持IE6+). tab.js GitHu ...
- 数据库————Select 查询
--创建mydb数据库create database mydb go --使用数据库use mydb go --水果表 create table Fruit ( Ids varchar() prima ...
- C# 数组的应用
//数组的应用: //(一).冒泡排序. //1.冒泡排序是用双层循环解决.外层循环的是趟数,里层循环的是次数. //2.趟数=n-1:次数=n-趟数. //3.里层循环使用if比较相临的两个数的大小 ...
- *++p和*p++的区别
*p++:先是用*p这个值,然后再使p的地址加1. #include<iostream>using namespace std;int main(){ char s[81]=&quo ...
- Git教程--Git分支管理
分支管理--原理分析 在前面讲到的版本回退里,每次提交,Git都把它们串成一条时间线,这条时间线就是一个分支.只有一条时间线的这条分支称为master,HEAD严格来说不是指向提交,而是指向maste ...