关于C中二级指针传参的问题

 #include <stdio.h>
#include <stdlib.h>
#define m 3
#define n 4

typedef struct Lnode
{
    int data;
    struct Lnode *next;
}Lnode,*Linklist;//节点类型和指向结构的指针类型

void CreatlistF(Linklist *L);

void main ()
{
    Linklist L1;
//  Linklist p;//等价于Lnode *p;
    //p=&L;
    CreatlistF(&L1);
    printf("\n");
}

void CreatlistF(Linklist *L)
{
    *L=(Linklist)malloc(sizeof(Lnode));
    printf("\n");
}

代码如上,在调试过程中出现如下图结果:
图片说明
可以看到,此时指针L保存的是L1自身的地址

接下来分配一块内存,这一步会使指针L指向这块内存吧?
图片说明

这个过程表明,L1指向了这块分配好的内存地址

我不是太明白:

  • malloc不应该是返回一个指向这块内存地址的指针,假设这个指针是p,那么malloc那一句应该等价于*L=*p;
  • 所以说应该是让L指向这块内存,因而L存储的应该是分配的内存地址。
  • 怎么结果是使L1指向这个地址了。
查看全部
tk0320
ijpq
2016/08/09 10:41
  • 点赞
  • 收藏
  • 回答
    私信
满意答案
查看全部

2个回复