zoukankan      html  css  js  c++  java
  • A Reusable Aspect for Memory Profiling

    例子:

    malPro.acc文件:

    #include <stdlib.h>
    size_t totalMemoryAllocated;
    int totalAllocationFuncCalled;
    int totalFreeFuncCalled;

    void initProfiler() {
    totalMemoryAllocated = 0;
    totalAllocationFuncCalled = 0;
    totalFreeFuncCalled = 0;
    }

    void printProfiler() {
    printf("total memory allocated = %d bytes ", totalMemoryAllocated );
    printf("total memory allocation function called = %d ", totalAllocationFuncCalled);
    printf("total memory free function called = %d ", totalFreeFuncCalled);
    }

    before(): execution(int main()) {
    initProfiler();
    }
    after(): execution(int main()) {
    printProfiler();
    }

    before(size_t s): call($ malloc(...)) && args(s) {
    totalMemoryAllocated += s;
    totalAllocationFuncCalled ++;
    }
    before(size_t n, size_t s): call($ calloc(...)) && args(n, s) {
    totalMemoryAllocated += n * s;
    totalAllocationFuncCalled ++;
    }

    before(size_t s): call($ realloc(...)) && args(void *, s) {
    totalMemoryAllocated += s;
    totalAllocationFuncCalled ++;
    }


    before() : call(void free(void *)) {
    totalFreeFuncCalled++;
    }

    mal.c文件:

    #include <stdio.h>
    #include <malloc.h>
    void t1()
    {
    int *x ;
    printf(" core code:hehe ! ");
    x = (int *)malloc(sizeof(int) * 4);
    printf(" core code:hehe ! ! ");
    }
    int main()
    {
    t1();
    int *x ;
    printf(" core code:hehe ! ! ");
    x = (int *)malloc(sizeof(int) * 4);
    printf(" core code:hehe ! ! ");
    return 0;
    }

  • 相关阅读:
    C#中的Dictionary字典类介绍
    SQL server 2008r2 file is corrupt
    web service接口 wsdl和asmx有什么区别
    ascx
    C++: C++函数声明的时候后面加const
    C++三种野指针及应对/内存泄露
    C++构造和析构的顺序
    atan2()如何转换为角度
    C++11左值引用和右值引用
    C++ STL详解
  • 原文地址:https://www.cnblogs.com/xiaohuihui123/p/4565443.html
Copyright © 2011-2022 走看看