Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- server
- Algospot
- 인프런
- 백준
- web
- Math
- 따라하면서 배우는 C언어
- BFS
- BOJ
- 따배씨
- 정수론
- dfs
- BASIC
- sorting
- Python
- Cleancode
- String
- greedy
- Algorithm
- C언어
- 생활코딩
- JavaScript
- DP
- graph
- udemy
- programmers
- 종만북
- C
- 따라하며 배우는 C언어
- php
Archives
- Today
- Total
몽상실현개발주의
[따배씨] 14.11 신축성 있는 배열 멤버 본문
따배씨 - 따라하며 배우는 C언어
14강 구조체_2
14.11 신축성 있는 배열 멤버 Flexible Array Members
#include <stdio.h>
#include <stdlib.h>
int main()
{
/*
Flexible array member (struct hack in GCC)
// 지금은 표준
*/
struct flex
{
size_t count;
double average;
double values[]; // flexible array member (last member!)
// 구조체가 저장되는 메모리 구조상, flexible array 변수 위치를 마지막으로 두어야 사용하기 편함
};
const size_t n = 3;
struct flex* pf = (struct flex*)malloc(sizeof(struct flex) + n * sizeof(double));
// values 의 배열 크기 n 만큼 추가 동적할당
if (pf == NULL) exit(1);
printf("flexible array member\n");
printf("Sizeof struct flex %zd\n", sizeof(struct flex));
// Sizeof struct flex 16
printf("Sizeof *pf %zd\n", sizeof(pf));
// Sizeof *pf 8
printf("Sizeof malloc %zd\n", sizeof(struct flex) + n * sizeof(double));
// Sizeof malloc 40
printf("%lld\n", (long long)pf);
// 4388333424
printf("%lld\n", (long long)& pf->count);
// 4388333424
printf("%zd\n", sizeof(pf->count));
// 8
printf("%lld\n", (long long)& pf->average);
// 4388333432
printf("Address of pf->values %lld\n", (long long)& pf->values);
// Address of pf->values 4388333440
printf("Value of pf->values %lld\n", (long long)pf->values);
// Value of pf->values 4388333440
// printf("Sizeof pf->value %zd\n", sizeof(pf->values));
pf->count = n;
// 동적 할당을 받은 크기를 저장해 둠
pf->values[0] = 1.1;
pf->values[1] = 2.1;
pf->values[2] = 3.1;
pf->average = 0.0;
for (unsigned i = 0; i < pf->count; ++i)
pf->average += pf->values[i];
pf->average /= (double)pf->count;
printf("Average = %f\n", pf->average);
// Average = 2.100000
return 0;
}
struct flex
{
size_t count;
double average;
double values[]; // flexible array member (last member!)
};
- 구조체가 저장되는 메모리 구조상, flexible array 변수 위치를 마지막으로 두어야 사용하기 편함
double values[];
- 배열의 크기가 지정되지 않았기 때문에, 메모리 크기가 없는상태
- 동적할당을 받아야지 메모리 크기가 할당 됨
struct nonflex
{
size_t count;
double average;
double *values; // Use malloc()
};
struct nonflex nf;
int n = 3;
nf.values = (double *)malloc(sizeof(double) * n);
double *values;
nf.values = (double *)malloc(sizeof(double) * n);
- 동적 할당 배열
double *values;
- pointer 변수가 저장될 메모리 크기를 할당 받음
- 동적 할당된 array 의 주소는 구조체의 메모리 주소와 별도로 생성
- 연관 X
struct flex* pf = (struct flex*)malloc(sizeof(struct flex) + n * sizeof(double));
if(pf == NULL) exit(1);
*pf2 = *pf1; // Don't copy flexible members, use memcpy() instead
printf("%f %f %f\n", pf->values[0], pf->values[1], pf->values[2]);
// 1.100000 2.100000 3.100000
printf("%f %f %f\n", pf2->values[0], pf2->values[1],pf2->values[2]);
// 0.000000 0.000000 0.000000
- flexible array member 는 대입 하는 방법으로는 제대로 복사 되지 않음
- compiler 입장에서 동적 할당을 받은 size 까지 알 수 없기 때문에, 기본 size 까지만 복사가 됨
- memcpy() 를 사용하여 값을 복사해야 함
이 글의 모든 사진과 내용의 출처는 홍정모 교수님께 있음을 알려드립니다.
http://blog.naver.com/atelierjpro
http://www.inflearn.com/course/following-c
'Language > C' 카테고리의 다른 글
[따배씨] 14.13 구조체의 배열을 사용하는 함수 (0) | 2021.07.04 |
---|---|
[따배씨] 14.12 익명 구조체 (0) | 2021.06.28 |
[따배씨] 14.10 복합 리터럴 (0) | 2021.06.26 |
[따배씨] 14.9 구조체와 할당 메모리 (0) | 2021.06.26 |
[따배씨] 14.8 구조체와 함수 연습문제 (0) | 2021.06.22 |
Comments