malloc 一次分配19G大内存

本文通过一个C语言程序实例,展示了如何使用malloc函数为结构体数组动态分配内存,并填充数据。程序定义了一个包含整型和字符数组的结构体,尝试分配不同规模的内存,最后释放已分配的内存。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

验证malloc分配内存能力

#include <stdio.h>
#include <string.h>
#include <stdlib.h>


//#define  SIZE  5024000 //19GB
#define  SIZE  102400

typedef struct bean {
    int16_t index;
    char name[1024*1024] ;
} bean;



int main() {
    
    bean *b;
    char *p=NULL;
    p="aadf";

    char a[10][10];

    for (int i = 0; i < 10; ++i) {
        for (int j = 0; j < 10; ++j) {
            a[i][j]='A';
        }
    }

    printf("bean size %ld\n", sizeof(bean));
    printf("bean size %ld\n", SIZE*sizeof(bean));
    b=malloc(SIZE*sizeof(bean));

    printf("b %p\n",b);
    printf("b+0 %p\n",b+0);

    printf("b size %ld\n", sizeof(*b));

    bean* t=b;
    for (int k = 0; k < SIZE; ++k) {

        
        t->index=k;
        sprintf(t->name,"BB %d",k);

        //printf("%d\n",k);
        
        t++;

    }
    
//
//    for (int l = 0; l < SIZE; ++l) {
//
//        printf("name:%s\n", b[l].name);
//        printf("index:%d\n", b[l].index);
//
//    }

    printf("%ld\n",sizeof(*b));
    
    free(b);
    return 0;

}

 

malloc申请内存后不会立刻分配,实际在for循环赋值时才真正分配内存

内存分配xcode截图

 

#include <stdio.h> #include <stdlib.h> #include <string.h> #include <time.h> // 骑手结构体 typedef struct Rider { int riderId; char name[50]; int status; // 0:空闲,1:忙碌 struct Rider* next; } Rider; // 订单结构体 typedef struct Order { int orderId; int userId; int restaurantId; int status; // 0:待分配,1:已分配,2:已取餐,3:已送达 time_t createTime; struct Order* next; } Order; // 队列结构体 typedef struct Queue { Rider* front; Rider* rear; int count; } Queue; // 初始化队列 Queue* initQueue() { Queue* q = (Queue*)malloc(sizeof(Queue)); q->front = q->rear = NULL; q->count = 0; return q; } // 判断队列是否为空 int isEmpty(Queue* q) { return q->count == 0; } // 入队(添加骑手到空闲队列) void enqueue(Queue* q, Rider* rider) { rider->next = NULL; if (isEmpty(q)) { q->front = q->rear = rider; } else { q->rear->next = rider; q->rear = rider; } q->count++; } // 出队(从空闲队列中取出骑手) Rider* dequeue(Queue* q) { if (isEmpty(q)) return NULL; Rider* temp = q->front; q->front = q->front->next; if (q->front == NULL) q->rear = NULL; q->count--; temp->next = NULL; return temp; } // 创建新骑手 Rider* createRider(int riderId, const char* name) { Rider* rider = (Rider*)malloc(sizeof(Rider)); rider->riderId = riderId; strcpy(rider->name, name); rider->status = 0; // 初始为空闲状态 rider->next = NULL; return rider; } // 创建新订单 Order* createOrder(int orderId, int userId, int restaurantId) { Order* order = (Order*)malloc(sizeof(Order)); order->orderId = orderId; order->userId = userId; order->restaurantId = restaurantId; order->status = 0; // 初始为待分配状态 order->createTime = time(NULL); order->next = NULL; return order; } // 分配骑手给订单 void assignRider(Queue* availableRiders, Order* order) { if (isEmpty(availableRiders) || order == NULL) { printf("没有可用骑手或订单为空,无法分配\n"); return; } // 从队列中取出一名空闲骑手 Rider* rider = dequeue(availableRiders); rider->status = 1; // 标记为忙碌状态 // 更新订单状态 order->status = 1; // 已分配骑手 // 模拟配送过程 printf("订单 #%d 已分配给骑手 %s (#%d)\n", order->orderId, rider->name, rider->riderId); // 模拟取餐 printf("骑手 %s 正在前往餐厅 #%d 取餐...\n", rider->name, order->restaurantId); // 模拟送餐 printf("骑手 %s 正在送餐到用户 #%d...\n", rider->name, order->userId); // 模拟送达 order->status = 3; printf("订单 #%d 已送达,骑手 %s 完成任务\n", order->orderId, rider->name); // 骑手完成任务,重新加入空闲队列 rider->status = 0; enqueue(availableRiders, rider); printf("骑手 %s 已返回空闲队列\n", rider->name); } // 释放队列内存 void freeQueue(Queue* q) { while (!isEmpty(q)) { free(dequeue(q)); } free(q); } int main() { // 初始化空闲骑手队列 Queue* availableRiders = initQueue(); // 添加几名骑手到空闲队列 enqueue(availableRiders, createRider(1, "张三")); enqueue(availableRiders, createRider(2, "李四")); enqueue(availableRiders, createRider(3, "王五")); // 创建几个订单 Order* order1 = createOrder(101, 1001, 501); Order* order2 = createOrder(102, 1002, 502); Order* order3 = createOrder(103, 1003, 503); // 分配骑手给订单 assignRider(availableRiders, order1); assignRider(availableRiders, order2); assignRider(availableRiders, order3); // 释放资源 free(order1); free(order2); free(order3); freeQueue(availableRiders); return 0; } 上述代码一定保持不变的情况下针对以下要求完善代码1.采用图结构表示餐厅、用户和骑手之间的位置关系,优化配送路径。 3配送跟踪:分配骑手接单,更新订单配送状态;用户可实时查询订单位置和预计送达时间;模拟骑手取餐、送餐过程。使用c语言进行编程上述代码一定不发生变化和修改只是进行功能的追加
最新发布
06-25
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值