feixiangmenghu 发表于 2013-8-12 09:10:28

C指针详解和内存分配

int i;
char **p;
p=(char **)malloc(sizeof(char *));
for(i=0;i<A;i++)
   p=(char*)malloc(sizeof(char));

**** Hidden Message *****

feixiangmenghu 发表于 2013-8-12 10:46:03

c指针。。。

zzp705540019 发表于 2013-8-12 11:32:09

谢谢楼主!

孔凤明 发表于 2013-8-12 12:03:21

瞅瞅~~~~~~~~~~~~~~~~~~~~~~~~~~

我是师兄 发表于 2013-8-12 12:09:32

楼主你没隐藏的内容写错的

我是师兄 发表于 2013-8-12 12:12:10

写错好多
而且 既然介绍malloc 怎么可以一点都不提 free

岚澈清 发表于 2013-8-12 12:42:52

看一下看一下

.Naruto 发表于 2013-8-12 12:55:13

来看看是什么

asri 发表于 2013-8-12 13:22:38

先来支持支持了

asri 发表于 2013-8-12 13:25:00

int i;
char **p;
p=(char **)malloc(sizeof(char *));
for(i=0;i<A;i++)
   p=(char*)malloc(sizeof(char));

本帖隐藏的内容

int i;
char **p;
p=(char **)malloc(sizeof(char *));
for(i=0;i<A;i++)
   p=(char*)malloc(sizeof(char));



void* malloc(size_tsize)
这个函数请求分配大小为size字节的内存,并返回指向该块内存起始位置的指针
它接受的参数类型size_t是unsigned int的一个typedef,这种类型用来表示数据类型的大小(如char类型的大小为1(字节))
它返回的是一个void*类型的指针,需要强制转换成需要的指针类型之后才能使用

这样第三行代码的意思就是分配一块大小为sizeof(char*)(一个char*指针的大小)的内存,并通过赋值让p指向这块内存,其中p是一个指向char*类型指针的指针

第五行中,p相当于*(p + i),p是指向char指针的指针,p是对p间接引用就是char*类型指针,然后这个循环是对每个大于等于0小于A的i,分配一块大小为sizeof(char)的内存,并让p指向相应的这块内存





我讲解一下c语言中动态分配内存的函数,可能有些初学c语言的人不免要问了:我们为什么要通过函数来实现动态分配内存呢?系统难道不是会自动分配内存吗??
既然有人会问这样的问题,那么我在这里好好的讲解一下吧!
首先让我们熟悉一下计算机的内存吧!在计算机的系统中有四个内存区域:1)栈:在栈里面储存一些我们定义的局部变量以及形参(形式参数);2)字符常量区:主要是储存一些字符常量,比如:char *p_str=”cgat”;其中”cgat”就储存在字符常量区里面;3)全局区:在全局区里储存一些全局变量和静态变量;4)堆:堆主要是通过动态分配的储存空间,也就是我们接下需要讲的动态分配内存空间。
什么时候我们需要动态分配内存空间呢?举一个例子吧。int *p; 我们定义了一个指向int类型的指针p;p是用来储存一个地址的值的,我们之所以要为p
这个变量分配空间是让它有一个明确的指向,打个比方吧!你现在做好了一个指向方向的路标,但是你并没有让这个路标指向一个确切的方位,也就是说现在的这个路标是瞎指向的,这样我们就不能够通过它来明确到底哪里是东,哪里是西,何为北,何为南了。虽然我们在计算机的内存里定义了一个指针变量,但是我们并没有让这个变量指示一个确切int类型变量的地址,所以我们就必须要让它有一个明确的指示方向。这样我们就要通过动态分配内存的方式来认为的规定它的方向!
我们在刚刚接触指针的时候遇到过这样的情况,int *p;p=&a;这种方法不是指针的动态分配内存,这个叫做指针变量的初始化!初始化同样也可以让指针变量有方向可指。
int *p;p=malloc(n*sizeof(类型名称));我们通过malloc()函数为一个指针变量p分配了地址,这样我们从键盘上键入的值就这样存储在p里面了,接下来我们就可以对这个p进行具体的操作了,比如scanf(“%s”,p)等等。当我们对p结束操作的时候还要释放p的内存空间。为什么要释放内存空间呢?在上面我已经讲过动态分配的变量时储存在堆里面,但是这个堆的空间并不是无限大的,也许当我们编一个小的程序的时候可能我们并不能够发现什么,但是对于那些大的程序,如果我们比及时释放堆的空间的时候会放生内存泄露。所谓内存泄露是因为堆的空间北我们动态分配用完了,这样当我们再去使用动态分配堆的空间的时候就没有足够的空间让我们使用了,这样就需要占有原来的空间,也就是会把其他的空间来储存我们键入的值,这样会导致原来储存的数据被破坏掉,导致了内存的泄露了。
同时当我们使用malloc()函数的时候还应该注意当我们释放完空间的时候还要将原先的指针变量赋予一个NULL,也就是赋予一个空指针,留着下次的时候使用它!如果我们不赋予|NULL行不行呢??答案是:不行的!如果我们不赋予一个空指针这样会导致原先的指针变量成为了一个野指针!何谓野指针?野指针就是一个没有明确指向的指针,系统不知道它会指向什么地方,野指针是很危险的,因此当我们每次使用完malloc()函数的时候都必须将指针赋予一个空指针!相对于malloc()函数,calloc()函数就不需要我们赋予NULL了,这是因为在每次调用完calloc()函数的时候系统会自动将原先的指针赋予一个空指针,即归于“0”。calloc()函数的原型是void *calloc(count,sizeof(类型名称));比如:p=(char*)calloc(4,sizeof(char));我们为p分配了指向char型指针的“4”个空间。
除了malloc()与calloc(),还有一个动态分配空间的函数realloc()函数,这个函数比前两个函数分配更多的空间,原型:void *realloc(void *p,size_t size);
该函数有几个作用:
1)    如果有足够的空间来扩充p的内存块,则返回一个指向p的指针;
2)    如果没有足够的空间来扩充p的内存块,则为p从新分配size的空间,并把原来的内容复制给p,指向p的开头,同时释放原来的空间,返回一个指向新内存块的指针;
3)    如果p=NULL,其作用于malloc()相似;
下面举一个程序的例子:
#define LONG 10
#include<string.h>
#include<stdlib.h>
#include<stdio.h>
main()
{
   char *message,buf;
   gets(buf);
   message=(char*)realloc(NULL,strlen(buf)+1);
   strcpy(message,buf);
   puts(message);
   gets(buf);
   message=(char*)realloc(message,(strlen(message)+strlen(buf)+1));
   strcat(message,buf);
   puts(message);
   return 0;
}

bzdyyab 发表于 2013-8-12 13:28:12

{:5_94:},{:5_94:}.{:5_94:}.,

逾越书 发表于 2013-8-12 13:54:09

不要回复行不行!!

年少花阁 发表于 2013-8-12 13:58:32

好好学习,超越楼主。

僦湜嬡沵 发表于 2013-8-12 15:15:29

谢谢楼主

794708540 发表于 2013-8-12 19:38:25

强烈支持楼主ing···························

BMamba 发表于 2013-8-12 21:11:33

这个没错都很纠结

leechen 发表于 2013-8-12 22:30:36

:big 太激动了额

牡丹花下死做鬼 发表于 2013-8-13 08:44:11

这倒是个好贴啊 我正好现在在学看指针

机灵小不懂 发表于 2013-8-13 09:13:10

学习学习。。。。

啊一 发表于 2013-8-13 13:00:13

看看 感谢分享
页: [1] 2 3 4 5 6 7 8 9 10
查看完整版本: C指针详解和内存分配