인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

워니냥님의 프로필 이미지
워니냥

작성한 질문수

홍정모의 따라하며 배우는 C언어

구조체 포인터의 포인터 연산에 관하여

작성

·

439

0

포인터 연산과 관련하여 질문이 있습니다.

int 는 ++연산을 하게되면 4byte씩 증가, char * 는 1byte씩 증가로 알고 있습니다.

따라서, 아래의 int형 변수 2개가 담겨 있는 구조체의 크기는 8byte이며

구조체 포인터에 ++연산을 하게 되면, 8byte 씩 증가를 할 것이라고 생각을 하였으나,

++ptr2를 한번 수행하면 2byte증가,

++ptr2을 연속 2번 수행하면 10byte가 증가하게 되는데 그 이유는 무엇인가요?

답변해주시면 감사하겠습니다.

#include <stdio.h>


int main()
{
typedef struct
{
	int num1;
	int num2;
} test;

	test s;

	s.num1 = 10;
	s.num2 = 20;

	void *ptr = &s;

	test *ptr2;
	ptr2 = &s;

	printf("size of struct s %lu\n", sizeof(s));
	
	printf("ptr2 adderss and value %p %d\n", ptr2, *((int *)ptr2) ) ;
	++ptr2;
	//++ptr2;
	printf("ptr2++ adderss and value %p %d\n", ptr2, *((int *)ptr2) ) ;
	
	printf("ptr address and value %p %d\n", ptr, *((int *)ptr));
	++ptr;
	++ptr;
	++ptr;
	++ptr;
	printf("++ptr address and value %p %d\n", ptr, *((int *)ptr));
	printf("ptr + 1 address %p\n", ++ptr);
	printf("ptr + 0x04 %p\n", ptr + 0x04);


	// int num = (int)(*(ptr + 4));
	// printf("%d\n", *(ptr + 4));
	
}

답변 1

0

int 는 ++연산을 하게되면 4byte씩 증가, char * 는 1byte씩 증가로 알고 있습니다.

>> char* 변수를 ++ 하면 1씩 증가하는 것은 맞으나, sizeof(char*)는 포인터의 크기인 점에 유의해주세요.

#include<stdio.h>

int main()
{
   char * ptr = "test";
   printf("%lu\n", sizeof(ptr));
   printf("%p\n", ptr);
   ptr++;
   printf("%p\n", ptr);

    return 0;
}

결과

8
0x100f33fa8
0x100f33fa9

'

그리고 주소 관련해서는..

혹시 십육진수 연산을 십진수로 헷갈린것 아니실까요?

#include <stdio.h>


int main()
{

typedef struct
{
	int num1;
	int num2;
} test;

	test s;

	s.num1 = 10;
	s.num2 = 20;

	test *ptr2;
	ptr2 = &s;

	printf("size of struct s %lu\n", sizeof(s));

	printf("ptr2 adderss and value %p %d\n", ptr2, *((int *)ptr2) ) ;
	++ptr2;
	printf("++ptr2 adderss and value %p %d\n", ptr2, *((int *)ptr2) ) ;
	++ptr2;
	printf("++++ptr2 adderss and value %p %d\n", ptr2, *((int *)ptr2) ) ;
	++ptr2;
	printf("++++++ptr2 adderss and value %p %d\n", ptr2, *((int *)ptr2) ) ;
	++ptr2;
	printf("++++++++ptr2 adderss and value %p %d\n", ptr2, *((int *)ptr2) ) ;
	++ptr2;
	printf("++++++++++ptr2 adderss and value %p %d\n", ptr2, *((int *)ptr2) ) ;
}

 

size of struct s 8
ptr2 adderss and value 0x16bc77748 10
++ptr2 adderss and value 0x16bc77750 1808234656
++++ptr2 adderss and value 0x16bc77758 71356660
++++++ptr2 adderss and value 0x16bc77760 0
++++++++ptr2 adderss and value 0x16bc77768 0
++++++++++ptr2 adderss and value 0x16bc77770 0

 

단순히 (warning 무시하시고) 십진수로 주소를 찍어보세요

#include <stdio.h>


int main()
{

typedef struct
{
	int num1;
	int num2;
} test;

	test s;

	s.num1 = 10;
	s.num2 = 20;

	test *ptr2;
	ptr2 = &s;

	printf("size of struct s %lu\n", sizeof(s));

	printf("ptr2 adderss and value %d %d\n", ptr2, *((int *)ptr2) ) ;
	++ptr2;
	printf("++ptr2 adderss and value %d %d\n", ptr2, *((int *)ptr2) ) ;
	++ptr2;
	printf("++++ptr2 adderss and value %d %d\n", ptr2, *((int *)ptr2) ) ;
	++ptr2;
	printf("++++++ptr2 adderss and value %d %d\n", ptr2, *((int *)ptr2) ) ;
	++ptr2;
	printf("++++++++ptr2 adderss and value %d %d\n", ptr2, *((int *)ptr2) ) ;
	++ptr2;
	printf("++++++++++ptr2 adderss and value %d %d\n", ptr2, *((int *)ptr2) ) ;
}

 

size of struct s 8
ptr2 adderss and value 1864857416 10
++ptr2 adderss and value 1864857424 1864857760
++++ptr2 adderss and value 1864857432 15438068
++++++ptr2 adderss and value 1864857440 0
++++++++ptr2 adderss and value 1864857448 0
++++++++++ptr2 adderss and value 1864857456 0
워니냥님의 프로필 이미지
워니냥

작성한 질문수

질문하기