C++ 内存分配可视化

22 篇文章 0 订阅
16 篇文章 0 订阅

GitHub - archibate/mallocvis: allocation visualization in svg graph

大端字节序,数据从个十百位,地址从高到低
小端字节序,数据从个十百位,地址从低到高。little_endian
int x = 0x12345678;
int* p = &x;
char* ch = (char*)p;
if (0x5678 == *ch)
    std::cout << "小端" << std::endl;
if (0x1234 == *ch)
    std::cout << "大端" << std::endl;

if (std::is_signed<char>::value)
    std::cout << "x86架构" << std::endl;
else 
    std::cout << "Arm架构" << std::endl;

正常连续内存分配
#include <vector>

int main() {
    // 堆malloc
    std::vector<int>  memory;
    for (int i = 0; i < 1000; ++i) {
        memory.emplace_back(i*10);
    }
    return 0;
}

 主动内存分配释放
#include <vector>

class A {
private:
    float m_value;
    int m_id;
};
int main() {
    // 堆malloc
    std::vector<A*> AS;
    for (int i = 0; i < 1000; ++i) {
        AS.emplace_back(new A());
    }
	// 堆free
	for (int i = 0; i < 1000; ++i) {
		delete AS[i];
	}
    AS.clear();
    return 0;
}

 内存泄漏 
#include <vector>

class A {
private:
    float m_value;
    int m_id;
};
int main() {
    // 堆malloc
    std::vector<A*> AS;
    for (int i = 0; i < 1000; ++i) {
        AS.emplace_back(new A());
    }
    AS.clear();
    return 0;
}

 

注:宽度表示生存时间(黑色表示泄漏),高度表示内存占用大小,颜色表示每次调用地址

GitHub - sjp38/mallochook: An example for LD_PRELOAD using function hooking

Cpp17/latex/code/lang/tracknew.hpp at master · MeouSker77/Cpp17 · GitHub


创作不易,小小的支持一下吧!

  • 18
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码力码力我爱你

创作不易,小小的支持一下吧!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值