首页 > 编程知识 正文

二级指针的定义,结构体指针怎么初始化

时间:2023-05-03 17:04:43 阅读:227939 作者:2950

一: <span style="font-size:18px;">#include<stdio.h>  #include<stdlib.h>  typedef struct node{       int data;       int data1;   }*link,tree;    int  main()   {             int i;            tree *p1;            link p2;            link *p3;             p1 = (link)malloc(sizeof(tree));           p2 = (link)malloc(sizeof(tree));            //先给p3指向的内存分配空间  这里的P3为二级指针,所以得先给指针本身的分配            p3 = (link *)malloc(sizeof(link));            /* 再给二级指针指向的指针分配空间,其实二级指针**p相当于指针数组 *p[]           *  给指针所占有的结构体分配空间            *  这里只给第一个指针对象分配空间          */          (*p3) = (link)malloc(sizeof(tree));                      p1->data=1;             p1->data1=2;           //一级指针的两种不同定义结构体指针方式赋值          p2 = p1;           printf("%d,%dn",p2->data,p2->data1);           //二级指针同一级指针赋值,两种方式          *p3 = p1 ;          //p3= &p1;  //容易出问题,不要使用 重要 原因          printf("p1->data=%d,%dn",p1->data,p1->data1);          printf("(*p3)->data=%d,%dn",(*p3)->data,(*p3)->data1);           //二级指针的指针对象直接赋值          (*p3)->data = 3;            (*p3)->data1 = 4;             printf("%d,%dn",(*p3)->data,(*p3)->data1);                     printf("/***********************************/n");                    printf("/***********************************/n");          /*上面说过二级指针**p就相当与指针数组*p[]          * 当给二级指针分配空间时,那么就可以给其指针对象赋值,         * 其指针对象就是一个指针数组         * 就可以任意创建所需的指针对象         * 下面就是给其指针对象分配空间          ******/          //连续创建5个指针对象,同时分配内存          for(i=0;i<5;i++)          {              p3[i] = malloc(sizeof(tree));                    if (NULL == p3)                  {                      printf("malloc error!n");                      return -1;                  }                        }          //给其第一个指针对象 赋值          p3[0] = p1 ;          p1->data = 10;          p1->data1 = 11 ;          printf("%d,%dn",p3[0]->data,p3[0]->data1);          //指针对象的直接赋值          p3[1]->data = 12;          p3[1]->data1 = 13;          printf("%d,%dn",p3[1]->data,p3[1]->data1);          //下面这种方式 错误;          //(*p3)[1] = p1;          printf("%d,%dn",p3[0]->data,p3[0]->data1);          printf("%d,%dn",p3[1]->data,p3[1]->data1);          printf("p3[2]->data=%d,%dn",p3[2]->data,p3[2]->data1);          printf("p3[3]->data=%d,%dn",p3[3]->data,p3[3]->data1);          printf("p3[4]->data=%d,%dn",p3[4]->data,p3[4]->data1);            for(i=0;i<5;i++)          {              if(p3[i])              free(p3[i]);          }          //free(p2);          free(p1);          //free(p3);           return 0;  }           </span> 二: 二级指针初始化

int **temp;

int i = 0;

//初始化

temp = new int*[100];

for(i = 0; i < 100; i++)

  temp[i] = new int[200];

 

//释放

for(i = 0; i < 100; i++)

  delete []temp[i];

delete []temp;

 

可以理解为temp[100][200];

因为在VC中直接定义过大的二维数组,运行会报错,

如int temp[600][600]; 编译可以过去,但是运行就会出现错误,

此时改为二级指针就可解决。

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。