Cmalloc源码
‘壹’ c语言 关于malloc的用法
char*a3;
x=strlen(a1);
y=strlen(a2);
z=x+y+1;
a3=(char*)malloc(z);
‘贰’ 求几个比较有趣,简单的C语言源代码 小白自己敲着练一下手感
最简单的模拟计时器:
#include<stdio.h>
#include<conio.h>
#include<windows.h>
int m=0,s=0,ms=0; //m是分 s是秒 ms是毫秒
//以下是5个自编函数
void csh( ); //初始化界面
void yinc(int x,int y); //隐藏光标的函数(y值设为0就会隐藏)
void jishi( ); //计时器运行(每100毫秒变化一次)
void Color (short x, short y); //设定颜色的函数(y设为0就是黑底)
void gtxy (int x, int y); //控制光标位置的函数
int main( ) //主函数
{ csh( );
getch( );
while(1)
{ jishi( );
Sleep(100); //间隔100毫秒
if( kbhit( ) )break; //有键按下就退出循环
}
return 0;
}
void csh( ) //初始化界面
{Color(14,0); //设定淡黄字配黑底
printf(“ 计时器”);
Color(10,0); //设定淡绿字配黑底
printf(" ┌───────────┐");
printf(" │ │");
printf(" └───────────┘");
gtxy(10,4); //光标到屏幕第10列4行处输出
Color(7,0); //恢复白字黑底
printf(" 00:00:00 ");
yinc(1,0 ); //隐藏光标(yinc代表隐藏)
return;
}
void jishi( ) //计时器运行
{ms+=1;
if(ms==10){s+=1;ms=0;}
if(s==60){m+=1;s=0;}
gtxy(10,4);
Color(9,0); //设定淡蓝字配黑底
if(m>9) printf(" %d:",m);
else printf(" 0%d:",m);
Color(14,0); //设定淡黄字配黑底
if(s>9) printf("%d:",s);
else printf("0%d:",s);
Color(12,0); //设定淡红字配黑底
printf("0%d",ms);
}
void gtxy (int x, int y) //控制光标位置的函数
{ COORD pos;
pos.X = x;
pos.Y = y;
SetConsoleCursorPosition ( GetStdHandle (STD_OUTPUT_HANDLE), pos );
}
void Color (short ForeColor= 7, short BackGroundColor= 0) //设定颜色的函数
{ HANDLE handle = GetStdHandle ( STD_OUTPUT_HANDLE );
SetConsoleTextAttribute ( handle, ForeColor + BackGroundColor * 0x10 );
}
void yinc(int x,int y) //隐藏光标的设置(gb代表光标)
{ CONSOLE_CURSOR_INFO gb={x,y}; //x为1-100,y为0就隐藏光标
SetConsoleCursorInfo(GetStdHandle(STD_OUTPUT_HANDLE), &gb);
}
‘叁’ c语言malloc函数
1、malloc 向系统申请分配指定size个字节的内存空间。返回类型是 void* 类型。void* 表示未确定类型的指针。C,C++规定,void* 类型可以强制转换为任何其它类型的指针。
2、定义
原型:extern void *malloc(unsigned int num_bytes);
头文件:#include <stdlib.h>
功能:分配长度为num_bytes字节的内存块
返回值:如果分配成功则返回指向被分配内存的指针(此存储区中的初始值不确定),否则返回空指针NULL。当内存不再使用时,应使用free()函数将内存块释放。函数返回的指针一定要适当对齐,使其可以用于任何数据对象。
说明:关于该函数的原型,在以前malloc返回的是char型指针,新的ANSIC标准规定,该函数返回为void型指针,因此必要时要进行类型转换。
名称解释:malloc的全称是memory allocation,中文叫动态内存分配,当无法知道内存具体位置的时候,想要绑定真正的内存空间,就需要用到动态的分配内存。
相关函数:calloc、realloc、free、_alloca
3、函数全名:void *malloc(size_t size);
备注:void* 表示未确定类型的指针,void *可以指向任何类型的数据,更明确的说是指申请内存空间时还不知道用户是用这段空间来存储什么类型的数据(比如是char还是int或者...)
‘肆’ 对c语言中malloc函数的不解
malloc函数主要是用于功态申请内存。对于一些程序有可能会临时使用一些内存,用过后就不再需要了。虽然可以定义一个数组来实现,但如果需要的数量较大,且数量不固定,定义数组的方法会造成内存空间浪费。而用malloc可以实现动态申请内存,使用完后可以释放,能提高内存的利用率。当然如果是要始终保持数据的话,用数组会更方便。
用malloc函数申请内存是要指出数量的。且在使用时,不应超过申请的数量。如果对超过申请数量的内存单进行操作(特别是写入操作),是有可能因内存泄露而影响系统正常动行。
‘伍’ c语言 malloc函数是什么意义
分配内存空间,一般用在链表结构中
‘陆’ C语言:简单的malloc函数
int *p = (int*)malloc(1);声明了一个int*型指针,并初始化为malloc分配的空间首地址,但空间大小只有1字节。这个语句没有语法错误,指针类型也正确,只是内存分配不够。它带来的问题是潜在的:一般情况下,动态在堆上分配的空间是从偶数地址开始,最小间隔48个字节,这里只分配了1字节,那就有47个字节还空闲着;尽管一个int要4字节,但既然后面跟着47个空闲字节,它也就用了,C并不做这个边界限制。但是未分配的空间不受程序控制,是由系统控制的,说不定什么时候会把跟在p后面的一块分配给“别人”,如果“别人”在这一块又做了写操作,那输出就一般就不再是100000了,所以这样写是错误的,也是危险的。不过这还与编译器有关,有些编译器可能不是以48字节为间隔的,若是以2字节为间隔,那要是紧接着又分配了内存,4字节的int数就要侵占“别人”的地方了,会造成严重错误……
‘柒’ c语言malloc函数的使用,求解这个代码的意思,要详详细细的
#include
//编译预处理命令,包含头文件
#include
//同上
int
main()//主函数,程序执行从这里开始
{
while(1)//循环
malloc(1024*1024*100);//循环体,malloc函数,动态分布内存函数,你这里表示分配1024*1024*100个字节的内存空间
}//不过,你这是个死循环,运行必然会死机
‘捌’ C程序 malloc函数
原因是经过循环,原来存放申请空间的首地址的p,q已经被改变,并且释放了两次
#include<stdlib.h>
#include<stdio.h>
int main(){
int *p ,*q , *r; int i ;
r = q=p=(int *)malloc(12) ;
for(i=0;i<3;i++) { scanf("%d",p++); }
for(i=0;i<3;q++,i++)
{ printf("%d\n",*q); }
free(r);
}
‘玖’ C语言中的malloc()函数
需要包含头文件:
#i nclude
或
#i nclude
函数声明(函数原型):
void *malloc(int size);
说明:malloc 向系统申请分配指定size个字节的内存空间。返回类型是 void* 类型。void* 表示未确定类型的指针。C,C++规定,void* 类型可以强制转换为任何其它类型的指针。
从函数声明上可以看出。malloc 和 new 至少有两个不同: new 返回指定类型的指针,并且可以自动计算所需要大小。比如:
int *p;
p = new int; //返回类型为int* 类型(整数型指针),分配大小为 sizeof(int);
或:
int* parr;
parr = new int [100]; //返回类型为 int* 类型(整数型指针),分配大小为 sizeof(int) * 100;
而 malloc 则必须由我们计算要字节数,并且在返回后强行转换为实际类型的指针。
int* p;
p = (int *) malloc (sizeof(int));
第一、malloc 函数返回的是 void * 类型,如果你写成:p = malloc (sizeof(int)); 则程序无法通过编译,报错:“不能将 void* 赋值给 int * 类型变量”。所以必须通过 (int *) 来将强制转换。
第二、函数的实参为 sizeof(int) ,用于指明一个整型数据需要的大小。如果你写成:
int* p = (int *) malloc (1);
代码也能通过编译,但事实上只分配了1个字节大小的内存空间,当你往里头存入一个整数,就会有3个字节无家可归,而直接“住进邻居家”!造成的结果是后面的内存中原有数据内容全部被清空。
malloc 也可以达到 new [] 的效果,申请出一段连续的内存,方法无非是指定你所需要内存大小。
比如想分配100个int类型的空间:
int* p = (int *) malloc ( sizeof(int) * 100 ); //分配可以放得下100个整数的内存空间。
另外有一点不能直接看出的区别是,malloc 只管分配内存,并不能对所得的内存进行初始化,所以得到的一片新内存中,其值将是随机的。
除了分配及最后释放的方法不一样以外,通过malloc或new得到指针,在其它操作上保持一致。
‘拾’ C语言malloc问题
是因为上一次编译运行程序的时候,申请出来的空间没有释放掉,导致系统不再分配
检查一下是不是写错,例如
if(!a){
delete a;
a=NULL;
}