三大存储期限+堆和栈+malloc等函数+创建vector

本文详细介绍了堆和栈的使用场景,内存泄漏的概念以及如何通过malloc、calloc、realloc进行内存申请和释放。此外,还讲解了如何创建和操作C++中的VECTOR动态数组,涉及头文件保护和内存分配的动态调整。
摘要由CSDN通过智能技术生成

三大存储期限

image-20240411221025265

堆和栈的使用场景

栈的使用场景

image-20240411221218377

堆的使用场景

image-20240411221235683

image-20240411221243885

类型转换

image-20240411221311739

内存泄漏

​ 内存泄漏是指程序在运行过程中,未能适时释放不再使用的内存区域,导致这部分内存在程序的生命周期内始终无法被重用。

申请释放内存函数

free

image-20240411221537552

image-20240411221605132

malloc

image-20240411221415406

image-20240411221430378

calloc

image-20240411221752391

image-20240411221701729

失败处理

image-20240411222233373

realloc

image-20240411221929551

对于realloc失败的惯用法不同于前两种

image-20240411222014363

创建VECTOR

结构
image-20240411222531005

头文件的使用,注意如何使用头文件保护

vector.h

#ifndef VECTOR_H	// VECTOR_H就是一个宏 但是它没有值  
// 这个预处理指令的含义是 如果宏VECTOR_H没有定义, 那么就包含下面的代码

// 大家以后写头文件, 一律加保护
#define VECTOR_H

/*
	这里的这个用法, 非常类似C++/Java编程语言当中的泛型
	利用这种语法, 可以提高代码的扩展性和可维护性
	是一种推荐的做法
*/
typedef int ElementType;

typedef struct {
	ElementType *data;
	int size;
	int capacity;
} Vector;

// Vector的基本操作
// 新建一个Vector动态数组, 并且初始化动态数组的长度是10
Vector* vector_create(void);

// 销毁Vector, 包括释放结构体和动态数组两个结构
void vector_destroy(Vector *v);

// 插入: 向动态数组的末尾插入一个元素
void vector_push_back(Vector *v, ElementType new_val);

// 插入: 向动态数组的前面插入一个元素
void vector_push_front(Vector *v, ElementType new_val);

// 插入: 向动态数组的前面插入一个元素
void vector_insert_index(Vector *v, ElementType new_val, int idx);

#endif 

vector.c

#include "vector.h"
#include <stdlib.h>
#include <stdio.h>

#define DEFAULT_CAPACITY 10
#define THRESHOLD 1000



void resize(Vector *vector) {
	int old_len = vector->capacity;
	int new_len = old_len <= THRESHOLD ? (old_len << 1) : (old_len + (old_len >> 1));
	ElementType *tmp = vector->data;
	tmp = realloc(vector->data, sizeof(ElementType) * new_len);
	if (vector->data == NULL) {
		printf("realloc fail in resize\n");
		exit(-1);
	}
	vector->data = tmp;
	vector->capacity = new_len;
}


Vector *vector_create() {
	Vector *vector = calloc(1, sizeof(Vector));
	if (vector == NULL) {
		printf("calloc fail in vector_create\n");
		return NULL;
	}
	vector->data = calloc(DEFAULT_CAPACITY, sizeof(ElementType));
	if (vector->data == NULL) {
		printf("calloc fail in vector_create\n");
		free(vector);
		return NULL;
	}
	vector->capacity = DEFAULT_CAPACITY;
	return vector;
}

// 销毁一个Vector动态数组,释放内存。
void vector_destroy(Vector *v) {
	free(v->data);
	free(v);
}

// 向动态数组末尾添加一个元素
void vector_push_back(Vector *v, ElementType element) {
	if (v->size == v->capacity) resize(v);
	v->data[v->size++] = element;
}

// 在动态数组最前面添加元素,所有元素依次后移
void vector_push_front(Vector *v, ElementType val) {
	if (v->size == v->capacity) resize(v);
	for (int i = v->size - 1; i >= 0; i--) {
		v->data[i + 1] = v->data[i];
	}
	v->data[0] = val;
	v->size++;
}

// 将元素val添加到索引为idx的位置,idx后面的元素依次后移
void vector_insert(Vector *v, int idx, ElementType val) {
	if (v->size == v->capacity) resize(v);
	for (int i = v->size - 1; i >= idx; i--) {
		v->data[i + 1] = v->data[i];
	}
	v->data[idx] = val;
	v->size++;
}

测试main.c

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <math.h>
#include <ctype.h>
#include "vector.h"

#define ARR_SIZE(arr) (sizeof(arr) / sizeof(arr[0]))

/*

*/

int main(void) {
    Vector *v = vector_create();
    for (int i = 1; i <= 100; i++) {
        char *str = calloc(i + 1, sizeof(char));
        if (str == NULL) {
            printf("calloc fail in main\n");
            return -1;
        }
        for (int j = 0; j < i; j++) {
            str[j] = '0' + j % 10;
        }
        vector_push_back(v, str);
    }
    for (int i = 0; i < v->size; i++) {
        printf("%s\n",v->data[i]);
    }
    for (int i = 0; i < v->size; i++) {
        free(v->data[i]);
    }
    return 0;
}


  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值