[RTT例程练习] 3.2 动态内存管理之rt_realloc和free

realloc 用于重新分配内存的场景。如果原先通过 malloc分配的空间过小,则可通过realloc重新分配大小。当然具体实现的时候分两种情况,如果原内存块后有足够的空间,则之间将原内存块扩大,如果不够,则重新寻找一个地方,将原数据也拷贝至此。

代码:

#include <rtthread.h>

struct rt_thread thread1;
static rt_uint8_t thread1_stack[512];
void thread1_entry(void* parameter)
{
    int i,j = 1;
    char *ptr[10]; /* 用于放置10个分配内存块的指针*/
    /* 对指针清零*/
    for (i = 0; i <10; i ++)
    ptr[i] = RT_NULL;
    while(j--)
    {
        for (i = 0; i <10; i++)
        {
            /* 每次分配(1 <<i)大小字节数的内存空间*/
            ptr[i] = rt_malloc(10);
            /* 如果分配成功*/
            
            if (ptr[i] != RT_NULL)
            {
                rt_kprintf("get memory: 0x%x\n", ptr[i]);
                rt_realloc(ptr[i],16);
                /* 如果分配成功*/
                if (ptr[i] != RT_NULL)
                {
                    rt_kprintf("memory realloc success!\n");
                    /* 释放内存块*/
                    rt_free(ptr[i]);
                    rt_kprintf("memory free success!\n");
                    ptr[i] = RT_NULL;
                }
            }
        }
    }
}


int rt_application_init()
{
    rt_thread_init(&thread1,
        "thread1",
        thread1_entry, RT_NULL,
        &thread1_stack[0], sizeof(thread1_stack),
        10, 100);
    rt_thread_startup(&thread1);
    
    return 0;
}

结果:

get memory: 0x20000c58
memory realloc success!
memory free success!
get memory: 0x20000c58
memory realloc success!
memory free success!
get memory: 0x20000c58
memory realloc success!
memory free success!
get memory: 0x20000c58
memory realloc success!
memory free success!
get memory: 0x20000c58
memory realloc success!
memory free success!
get memory: 0x20000c58
memory realloc success!
memory free success!
get memory: 0x20000c58
memory realloc success!
memory free success!
get memory: 0x20000c58
memory realloc success!
memory free success!
get memory: 0x20000c58
memory realloc success!
memory free success!
get memory: 0x20000c58
memory realloc success!
memory free success!


转载于:https://www.cnblogs.com/lyyyuna/archive/2013/04/06/4123918.html

`struct rtable`是Linux内核中用于表示路由表项的结构体,它包含了以下字段: - `struct dst_entry dst`:表示路由目标的抽象结构,包含了一些通用的目标路由信息; - `int rt_flags`:表示路由表项的一些标志位,例如是否是主机路由表项、是否启用了源地址验证等; - `unsigned int rt_priority`:表示路由表项的优先级,用于决定路由选择时的权重; - `u32 rt_iif`:表示数据包进入的接口,用于数据包的转发和路由选择; - `struct net_device *rt_dev`:表示数据包要从哪个网络设备出去; - `struct rtable *u`:表示指向上一级路由的指针,通常用于实现路由缓存; - `struct flowi fl`:表示流信息,包含了要进行路由选择所需要的源、目的地址、服务类型等信息; - `struct rt6_info *rt6i`:表示IPv6路由表项的信息; - `struct fib_info *fib_info`:表示当前路由表的信息,包括了路由表的ID等; - `int arp_status`:表示路由表项的ARP状态; - `unsigned long rt_genid`:表示路由表项的生成ID; - `void *peer`:表示路由表项对应的邻居设备; - `struct neigh_parms *parms`:表示路由表项对应的邻居设备的参数; - `struct hh_cache *hh`:表示硬件地址缓存,用于提高路由性能; - `int rt_metric`:表示路由表项的度量值,用于决定路由选择时的优先级; - `unsigned long rt_mtu`:表示路由表项对应的最大传输单元; - `u32 rt_window`:表示路由表项对应的窗口大小,通常用于TCP拥塞控制; - `u32 rt_ssthresh`:表示路由表项对应的慢启动阈值,通常用于TCP拥塞控制; - `u32 rt_tos`:表示路由表项对应的服务类型; - `u32 rt_mark`:表示路由表项对应的标记; - `u32 rt_via_tos`:表示路由表项对应的网关服务类型; - `u32 rt_irtt`:表示路由表项对应的初始往返时间(Initial Round-Trip Time); - `u32 rt_pmtu`:表示路由表项对应的路径最大传输单元(Path MTU); - `u32 rt_hoplimit`:表示路由表项对应的跳数限制,通常用于IPv6; - `u32 rt_rxhash`:表示路由表项对应的数据包接收哈希值; - `struct timer_list rt_timer`:表示路由表项的计时器,用于实现路由缓存; - `struct timer_list rt_advise_timer`:表示路由表项的建议计时器; - `unsigned long rt_rmx[RTAX_MAX]`:表示路由表项的一些额外信息,例如RTT(Round-Trip Time)等; - `unsigned long rt_cpu`:表示路由表项所在的CPU编号; - `struct rcu_head rcu`:表示RCU(Read-Copy Update)头,用于实现无锁读写操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值