23.07.14 16:38 작성
·
287
·
수정됨
1
안녕하세요 수강생 입니다.
문의 사항이 있어 글 남깁니다.
다중 구조체에 대해 문의남깁니다.
예를들어
struct test
{
int a=0;
int b=0;
}TEST[2][2] *PTEST[2][2];
이런 식 입니다.
이때, 구조체에 접근할 때 주소연산자가 아닌 대입으로 접근이 가능한데 왜 그런가요?
예를 들어..
PTEST[2][2]->a 는 접근이 안되고 TEST[2][2].a는 접근이 됩니다.
답변 1
1
안녕하세요, 답변 도우미 Soobak 입니다.
우선, 작동이 되는 코드를 알려주시면 감사하겠습니다.
죄송하게도, 노력해보았지만 질문에서 궁금하신 점이 정확히 무엇인지 제가 알기가 어렵네요. 🥲
왜냐하면, 예시로 들어주신 코드는 컴파일이 되지 않는 코드이며,
제 나름대로 컴파일이 가능하도록 수정하여도, 구조체 배열의 크기가 2
이기 때문에, PTEST[2][2]->a
와 PTEST[2][2].a
모두 배열의 인덱스 2
로 접근 불가능하기 때문입니다.
구조체에서 .
연산자와 ->
연산자의 차이점에 대해서는 설명드릴 수 있기에 설명드려보면 다음과 같습니다.
.
: 객체 자체 또는 객체에 대한 참조에서 멤버에 직접 접근할 때 사용합니다.
예시 코드
struct MyClass
{
int x;
};
MyClass obj;
obj.x = 10; // obj 객체의 멤버 x에 직접 접근합니다.
->
: 객체를 가리키는 포인터를 통해 멤버에 접근 할 때 사용합니다.object_ptr->member
은 (*object_ptr).member
와 동일한 표현입니다.
예시 코드
struct MyClass
{
int x;
};
MyClass obj;
MyClass* ptr = &obj;
ptr->x = 10; // ptr이 가리키는 객체의 멤버 x에 접근합니다.
위 내용과, 배열
과 포인터
의 관계를 바탕으로 생각해보시면 좋을 것 같습니다.
만약, 위 설명으로 이해가 안되신다면 정확하게 컴파일이 되는 코드와 궁금하신 점을 편하게 댓글로 남겨주세요.