몽상실현개발주의

[따배씨] 14.11 신축성 있는 배열 멤버 본문

Language/C

[따배씨] 14.11 신축성 있는 배열 멤버

migrationArc 2021. 6. 28. 09:19

[따배씨] 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

 

실리콘 밸리의 프로그래머 : 네이버 블로그

안녕하세요! 홍정모 블로그에 오신 것을 환영합니다. 주로 프로그래밍 관련 메모 용도로 사용합니다. 강의 수강하시는 분들은 홍정모 연구소 카페로 오세요.

blog.naver.com

http://www.inflearn.com/course/following-c

 

홍정모의 따라하며 배우는 C언어 - 인프런 | 강의

'따배씨++'의 성원에 힘입어 새롭게 개발된 C 언어로 시작하는 프로그래밍 입문 강의입니다. '따배씨'와 함께 프로그래밍 인생을 업그레이드 해보세요., 따라하며 배우는 C언어 '따배씨++'의 성원

www.inflearn.com

 

 

Comments