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

#include
#include
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;
} 





你可能感兴趣的:(结构体指针的使用(二级))