关于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指向这个地址了。

malloc是分配一块内存并返回这块内存的起始地址,你把该地址赋值给了*L,而L的值是L1的地址,因此*L就是L1。所以
*L=(Linklist)malloc(sizeof(Lnode));这条语句改变的就是L1啊。
ps:把指针理解成普通变量就容易理解了,指针只是一个保存地址的变量,可以解析而已。

 改变L不会影响L1,除非使用引用(C++)或者双重指针。
void CreateList(LinkList **L)
{
*L = (LinkList)malloc(...);
}
调用
ListList **t;
Create(t);
LinkList * l1 = *t;