#include <iostream>
#include <stdlib.h>
#include <stdio.h>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
//动态内存分配与释放
//1 全局变量分配在内存中的静态存储区
//2 非静态的局部变量分配在内存中动态存储区,栈
//3 C中还建立内存动态分配区域,根据需要随时开辟和释放 ,自由存储区为堆。
// 堆中数据,不必在程序声明部分定义,也不必等到函数结束才释放
// 因为未在声明部分定义它们为变量或数组,因此不能通过变量名或数组名去引用这些数据,只能通过指针来引用。
//手动分配 malloc calloc realloc free
//realloc定义;void *realloc(void *p,unsignde int size); 重新分配空间
int main(int argc, char *argv[]) {
int n = 5;
//开辟4*5=20大小的空间
int *p = (int *)malloc(sizeof(int)*5);//将void强制转换为int返回类型
//开辟内存会出现两种情况:1:成功 2:失败
//调动malloc系统去申请大小为unsiged int size的空间,然后操作系统在自由存储空间中寻找是否有这么大的空间。找到后,将空间首地址返回给指针p,如果没有返回空NULL。
//判断p是否为空,及是否内存开辟失败
if(NULL == p){
printf("malloc memory fail!\n");
exit(1);
}
int i=0;
for( i=0; i<n; i++){
p[i] = i+1;
}
for( i=0; i<n; i++){
printf("%d ",p[i]);
}
///
//重新开辟5个空间,把p所指空间扩大到4*10=40大小
p = remalloc(p, sizeof(int)*10)
for (i = 5; i<10; i++ ){
p[i] = i+1;
}
return 0;
}
/*
//calloc 定义 :void *calloc(unsignde n,unsigned size);申请多少个空间,每个空间多大
int main(int argc, char *argv[]) {
int n;
printf("input n:>");
scanf("%d",&n);
int *p = (int *)calloc(n,sizeof(int));//将void强制转换为int返回类型
//开辟内存会出现两种情况:1:成功 2:失败
//调动malloc系统去申请大小为unsiged int size的空间,然后操作系统在自由存储空间中寻找是否有这么大的空间。找到后,将空间首地址返回给指针p,如果没有返回空NULL。
//判断p是否为空,及是否内存开辟失败
if(NULL == p){
printf("malloc memory fail!\n");
exit(1);
}
int i=0;
for( i=0; i<n; i++){
p[i] = i+1;
}
for( i=0; i<n; i++){
printf("%d ",p[i]);
}
return 0;
}
/*
// malloc定义:void *malloc(unsiged int size),返回类型void
//向系统动态申请空间分配给动态数组
int main(int argc, char *argv[]) {
int n;
printf("input n:>");
scanf("%d",&n);
int *p = (int *)malloc(sizeof(int)*n);//将void强制转换为int返回类型
//开辟内存会出现两种情况:1:成功 2:失败
//调动malloc系统去申请大小为unsiged int size的空间,然后操作系统在自由存储空间中寻找是否有这么大的空间。找到后,将空间首地址返回给指针p,如果没有返回空NULL。
//判断p是否为空,及是否内存开辟失败
if(NULL == p){
printf("malloc memory fail!\n");
exit(1);
}
int i=0;
for( i=0; i<n; i++){
p[i] = i+1;
}
for( i=0; i<n; i++){
printf("%d ",p[i]);
}
return 0;
}
/*
// 定义一个动态数组
int main(int argc, char *argv[]) {
int n;
printf("input n:>");
scanf("%d",&n);
int ar[n];
for(int i = 0; i<n;i++){
printf("%d ",ar[i]);
}
return 0;
}*/
#include <stdlib.h>
#include <stdio.h>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
//动态内存分配与释放
//1 全局变量分配在内存中的静态存储区
//2 非静态的局部变量分配在内存中动态存储区,栈
//3 C中还建立内存动态分配区域,根据需要随时开辟和释放 ,自由存储区为堆。
// 堆中数据,不必在程序声明部分定义,也不必等到函数结束才释放
// 因为未在声明部分定义它们为变量或数组,因此不能通过变量名或数组名去引用这些数据,只能通过指针来引用。
//手动分配 malloc calloc realloc free
//realloc定义;void *realloc(void *p,unsignde int size); 重新分配空间
int main(int argc, char *argv[]) {
int n = 5;
//开辟4*5=20大小的空间
int *p = (int *)malloc(sizeof(int)*5);//将void强制转换为int返回类型
//开辟内存会出现两种情况:1:成功 2:失败
//调动malloc系统去申请大小为unsiged int size的空间,然后操作系统在自由存储空间中寻找是否有这么大的空间。找到后,将空间首地址返回给指针p,如果没有返回空NULL。
//判断p是否为空,及是否内存开辟失败
if(NULL == p){
printf("malloc memory fail!\n");
exit(1);
}
int i=0;
for( i=0; i<n; i++){
p[i] = i+1;
}
for( i=0; i<n; i++){
printf("%d ",p[i]);
}
///
//重新开辟5个空间,把p所指空间扩大到4*10=40大小
p = remalloc(p, sizeof(int)*10)
for (i = 5; i<10; i++ ){
p[i] = i+1;
}
return 0;
}
/*
//calloc 定义 :void *calloc(unsignde n,unsigned size);申请多少个空间,每个空间多大
int main(int argc, char *argv[]) {
int n;
printf("input n:>");
scanf("%d",&n);
int *p = (int *)calloc(n,sizeof(int));//将void强制转换为int返回类型
//开辟内存会出现两种情况:1:成功 2:失败
//调动malloc系统去申请大小为unsiged int size的空间,然后操作系统在自由存储空间中寻找是否有这么大的空间。找到后,将空间首地址返回给指针p,如果没有返回空NULL。
//判断p是否为空,及是否内存开辟失败
if(NULL == p){
printf("malloc memory fail!\n");
exit(1);
}
int i=0;
for( i=0; i<n; i++){
p[i] = i+1;
}
for( i=0; i<n; i++){
printf("%d ",p[i]);
}
return 0;
}
/*
// malloc定义:void *malloc(unsiged int size),返回类型void
//向系统动态申请空间分配给动态数组
int main(int argc, char *argv[]) {
int n;
printf("input n:>");
scanf("%d",&n);
int *p = (int *)malloc(sizeof(int)*n);//将void强制转换为int返回类型
//开辟内存会出现两种情况:1:成功 2:失败
//调动malloc系统去申请大小为unsiged int size的空间,然后操作系统在自由存储空间中寻找是否有这么大的空间。找到后,将空间首地址返回给指针p,如果没有返回空NULL。
//判断p是否为空,及是否内存开辟失败
if(NULL == p){
printf("malloc memory fail!\n");
exit(1);
}
int i=0;
for( i=0; i<n; i++){
p[i] = i+1;
}
for( i=0; i<n; i++){
printf("%d ",p[i]);
}
return 0;
}
/*
// 定义一个动态数组
int main(int argc, char *argv[]) {
int n;
printf("input n:>");
scanf("%d",&n);
int ar[n];
for(int i = 0; i<n;i++){
printf("%d ",ar[i]);
}
return 0;
}*/