libgc 加 .make 在 vc6 vs2008 中的编译方法
开源代码多数是用 .mak 编译 win 平台,网上的教程多是说明命令行的,但这样在装了多个版本 vs 的电脑上很容易混乱,要每次执行不同的 vcvars32.bat 其实这个批处理不过是设置 sdk 的路径等等,例如 "D:\Program Files\Microsoft Visual Studio 9.0\VC\bin\NMAKE" /f "D:\gs_d\vctest\gc-7.0\gc.mak" CFG="gc - Win32 Release"
那个 cfg 标志是用来指定编译版本的,实现可看对应的 mak,如果没有执行那个 bat 文件夹的话就可能报 "NMAKE : fatal error U1073: don't know how to make '"\sys\TYPES.H"'"
其实不过是缺少 include 路径环境变量罢了,这些其实是可以由 vs 来完成的,vc6下比较简单,打开 .mak 文件会自动转存为 dsw ,但 vs2008 不行.不过我发现好象不支持一样,实际也是可以的,我发现一个取巧的方式:先用vc6生成 dsw 再用 vs2008 打开就行了. 我觉得vs2008 还不可以直接建立 .mak 工程的,不过怎么做还不明白.
用 vs 编译的最大好处是可以方便的在其中调试代码 -- 你用命令行不行吧?
--------------------------------------------------
最新的 libgc 不支持 vc6 ,不过修改一下就行,主要就是有些类型 vc6 不支持,在 vs2008 中参考写一个就行了,例如
typedef unsigned __int64 uintptr_t;//clq test
typedef unsigned long ULONG_PTR, *PULONG_PTR;
//clq test//strcat_s(exePath, sizeof(exePath), "\\..");
strncat(exePath, "\\..", sizeof(exePath));
--------------------------------------------------
使用c/c++中的垃圾收集库——libgc
libgc是一个保守的内存垃圾清理器,它会周期性的扫描程序中的数据,并标记所有的当前在heap对象中正在被使用的内存,随后释放所有未被标记的的内存。
但是,libgc不会检测使用libgc以外的allocator分配的内存空间,也不会对其进行自动的释放。
使用libgc可以解决一下问题:
1、内存的泄露;2、未分配空间就释放(premature frees); 3、内存的碎片。
但它不能解决内存被重写造成的问题。
具体使用:
1、先到 http://www.hpl.hp.com/personal/Hans_Boehm/gc/网站下载软件,包名字为gc.tar.gz
1.
./configure --prefix=……
2.
make
3.
make
install
2、把头文件<~/gc/include/gc.h>放到方便的地方。
3、编译时连接gc库:方法1:动态链接 gcc memgc.c -lgc -ldl 使用libgc.so, libdl.so两个库
方法2:静态链接 gcc memgc.c ~/gc/lib/libgc.a -lpthread 使用libpthread.so
注:静态链接的好处是可以拷贝到类似的系统中用,而不需要在那台机器上安装gc库
用法示范:
1. 把GC作为内存泄漏的检测工具, 方法如下:
01.
#include "../gc/include/leak_detector.h"
02.
03.
int
main()
04.
{
05.
int
*p[10];
06.
int
i;
07.
GC_find_leak = 1;
08.
//如果去掉这一句,就变成了标准的GC功能,这一句使它按内存检测方式运行
09.
for
(i = 0; i < 10; ++i)
10.
{
11.
p[i] = (
int
*)
malloc
(
sizeof
(
int
)+i);
12.
}
13.
for
(i = 2; i < 10; ++i)
14.
{
15.
free
(p[i]);
16.
}
17.
for
(i = 0; i < 9; ++i)
18.
{
19.
p[i] = (
int
*)
malloc
(
sizeof
(
int
)+i);
20.
}
21.
CHECK_LEAKS();
22.
//标准GC不需要这一句,这里强制GC_gcollect();
23.
}
编译运行如下:
gcc a.c -lgc -ldl 或者 gcc a.c libgc.a -lpthread
./a.out
显示:
Leaked composite object at 0×805bff0 (b.c:10, sz=5)
Leaked composite object at 0×805afe8 (b.c:10, sz=4)
当我们调试结束后,可以把检测去掉就可以了.
2.一个更有意义的做法是,我们使用标准GC的功能,那么我们根本不用释放申请的内存,不用时就忘掉它好了.
01.
#include "../gc6.1/include/gc.h"
02.
#define malloc(n) GC_malloc(n)
03.
//这样可以方便的使用而不改程序中原有的malloc
04.
#include ;
05.
int
main()
06.
{
07.
int
i;
08.
char
*p;
09.
for
(i = 0; i < 10000; ++i)
10.
{
11.
p =
malloc
(100000*
sizeof
(
int
));
12.
//malloc许多次,没有free
13.
if
(p==0)
14.
{
15.
printf
(
"No memory/n"
);
exit
(1);
16.
}
17.
}
18.
}
编译 gcc b.c -lgc -ldl 或者 gcc b.c /usr/local/lib/libgc.a -lpthread
./a.out &
运行时,不会把内存用光的.不会显示No memory信息.
转自:http://www.gomudemi.org/?p=43
void Cgct1Dlg::OnBnClickedButton1()
{
// TODO: Add your control notification handler code here
//AfxBeginThread(run, NULL);//不能这样用,可能是要和 libgc 专用的线程启动函数配合才行
//AfxBeginThread(run2, NULL);//不能这样用,可能是要和 libgc 专用的线程启动函数配合才行
GC_beginthreadex(NULL, 0, run, NULL, 0, NULL);
_beginthreadex(NULL, 0, run, NULL, 0, NULL);//#include <gc.h> 后才能自动 gc
//run(NULL);
}