작성
·
196
1
#define _SRT_SECURE_NO_WARNINGS
#include <stdio.h>
int main(void)
{
char* name[] = { "Aladdin", "Jasmine", "Magic Carpet", "Genie" };
const int n = sizeof(name) / sizeof(char*);
//name이라는 "포인터의 배열"에 4개의 원소가 담겨있단 얘기고, 4개의 문자열의 첫번째 문자 주소가 된다라고 하셨는데
교수님께서 n은 4라고 하셨거든요 ?sizeof(name)은 포인터변수니 4라고 생각했는데 sizeof(char*) 이것도 포인터 자료형이니까 4바이트잖아요 근데 찍어보니 sizeof(name)이 16바이트던데 이유 부탁드립니다!
for (int i = 0; i < n; ++i)
printf("%s at %u\n", name[i], (unsigned)name[i]);
printf("\n");
char aname[][15] = { "Aladdin", "Jasmine", "Magic Carpet", "Genie" };
//
const int an = sizeof(aname) / sizeof(char[15]);
for (int i = 0; i < an; ++i)
printf("%s at %u\n", aname[i], (unsigned)&aname[i]); //2차원배열이면 aname[i] i행의 시작주소를 담잖아요?
근데 여기서 또 &를 붙이는 이유가 궁금합니다 %u로 주소찍을때.
printf("\n");
return 0;
}
답변 1
3
1. 배열과 배열이 아닌 것에 sizeof(**) 를 출력해보세요
2. 이해하기 더 쉬운 예가 있는데,
int arr[3]
에서
printf("%p %p\n", arr, &arr);
printf("%p %p\n", arr+1, &arr+1);
을 하면
00000000, 00000000
00000004, 0000000C
이 출력됩니다.
arr 는 첫번째 원소에 대한 포인터(pointer to the first element of array)이고,
&arr 는 전체 배열에 대한 포인터(pointer to whole array) 입니다. 때문에 배열 사이즈가 더해진거죠.
둘은 결과로는 같아보이지만, 실제론 다릅니다. 이걸 알려주시려고 말씀하셨던 것 같습니다.
2. 내용은 https://www.geeksforgeeks.org/whats-difference-between-array-and-array-for-int-array5/
읽어보시면 더 도움 될 것 같네요
그리고...제일 위에 #define _CRT_SECURE_NO_WARNINGS 에요.....