结构体指针的使用(二级)

来源:互联网 发布:股市热点软件 编辑:程序博客网 时间:2024/04/29 19:21
#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,%d\n",p2->data,p2->data1); //二级指针同一级指针赋值,两种方式*p3 = p1 ;//p3= &p1;  //容易出问题,不要使用 重要 原因printf("p1->data=%d,%d\n",p1->data,p1->data1);printf("(*p3)->data=%d,%d\n",(*p3)->data,(*p3)->data1); //二级指针的指针对象直接赋值(*p3)->data = 3;  (*p3)->data1 = 4;   printf("%d,%d\n",(*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,%d\n",p3[0]->data,p3[0]->data1);//指针对象的直接赋值p3[1]->data = 12;p3[1]->data1 = 13;printf("%d,%d\n",p3[1]->data,p3[1]->data1); //下面这种方式 错误;//(*p3)[1] = p1;printf("%d,%d\n",p3[0]->data,p3[0]->data1);printf("%d,%d\n",p3[1]->data,p3[1]->data1);printf("p3[2]->data=%d,%d\n",p3[2]->data,p3[2]->data1);printf("p3[3]->data=%d,%d\n",p3[3]->data,p3[3]->data1);printf("p3[4]->data=%d,%d\n",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;} 

0 0