#include "stdafx.h"
#include <stdio.h>
struct s
{
char *st;
struct s *sp;
};
struct s *p1,*p2;
void swap(struct s *p1,struct s *p2);
int main()
{
int i;
struct s *p[3];
static struct s a[]={
{"abc",a+1},{"def",a+2},{"ghi",a}
};
for(i=0;i<3;i++)
{
p[i]=a[i].sp;
}
swap(*p,a);
printf("%s %s %s\n",p[0]->st,(*p)->st,(*p)->sp->st);
return 0;
}
void swap(struct s *p1,struct s *p2)
{
char *temp;
temp = p1->st;
p1->st = p2->st;
p2->st = temp;
}
This program outputs as abc,abc,ghi. My doubt is what does p[0]->st,(*p)->st,(*p)->sp->st outputs.we havent intialised st with abc or ghi.How does it outputs the string?
The value of the
stmember for each structure in the statically allocated arrayais actually initialized through an initialization list. Writinghas the same effective meaning after its execution as writing the following:
And what’s effectively happened after both methods of initialization is you have a statically-allocated circular linked list of
struct s, where the data-members of each node in the list (thestmember) is pointing to a string literal like “abc”, “def”, etc. Thespdata member is pointing to the next node in the linked list.