C言語のmallocとreallocの用途の練習をしています。
以下のようなコードで作業しています。
C
#include <stdio.h> #include <stdlib.h> #include <string.h> #include <malloc.h> struct php_struct { char* str; int size; }; int main () { struct php_struct php; int re_size; char* temp_str = NULL; FILE* fp; // (1)事前に確保するメモリ量 php.size = 1000000; // 1000000Byte,つまり1MB分のメモリを確保 temp_str = malloc(php.size * sizeof(char) + 1); if (temp_str != NULL) { php.str = temp_str; } else { printf("You could not get the memory which you specified."); exit(2); } // php.strにファイルから1MB分文字列を読み込む fp = fopen("test.public.pem", "rb"); fread(php.str, php.size, 1, fp); fclose(fp); printf("%s", php.str); printf("\r\n"); printf("気が変わったので確保したメモリを縮小させる"); printf("\r\n"); // (2)気が変わって確保したメモリを縮小 re_size = 30; temp_str = realloc(php.str, re_size * sizeof(char) + 1); if (temp_str != NULL) { // メモリを1MBから30Bへと縮小したはずのメモリ php.str = temp_str; } else { printf("You failed to shrink the memory."); exit(2); } // php.strにファイルから文字列を読み込む fp = fopen("test.public.pem", "rb"); fread(php.str, re_size, 1, fp); fclose(fp); printf("%s", php.str); }
上記のようなコードで
事前に、php_structという構造体の中にchar*のポインタ変数を用意して起き
(1)の箇所で1000000を宣言して
php.strという変数に1MB分のメモリを確保したアドレスを保持しました。
その後、適当なテキストファイル等から1MB分を読み込みphp.strに保持しました。
ただその後
(2)の箇所で気が変わりphp.strの値を30Bまでメモリを下げたくなりました。
C
temp_str = realloc(php.str, re_size * sizeof(char) + 1); if (temp_str != NULL) { // メモリを1MBから30Bへと縮小したはずのメモリ php.str = temp_str; } else { printf("You failed to shrink the memory."); exit(2); }
上記の箇所です。
その後、再度適当なファイルからふたたび30B分をとりだしたところ、
なぜか、(1)で確保した量と同じ分ファイルから取り出しているようなのです。。。
そして、(1)でのメモリ確保量を100KBとかに一桁下げると正しく、reallocでメモリを縮小できているようです。
どうにも私の知識量では腑に落ちないのでお聞きしました。
ご教授のほどよろしくお願いいたします。
まだ回答がついていません
会員登録して回答してみよう