C言語のmallocとreallocの用途の練習をしています。
以下のようなコードで作業しています。
C
1 2#include <stdio.h> 3#include <stdlib.h> 4#include <string.h> 5#include <malloc.h> 6 7struct php_struct { 8 char* str; 9 int size; 10}; 11 12int main () { 13 struct php_struct php; 14 int re_size; 15 char* temp_str = NULL; 16 FILE* fp; 17 18 // (1)事前に確保するメモリ量 19 php.size = 1000000; 20 21 // 1000000Byte,つまり1MB分のメモリを確保 22 temp_str = malloc(php.size * sizeof(char) + 1); 23 if (temp_str != NULL) { 24 php.str = temp_str; 25 } else { 26 printf("You could not get the memory which you specified."); 27 exit(2); 28 } 29 // php.strにファイルから1MB分文字列を読み込む 30 fp = fopen("test.public.pem", "rb"); 31 fread(php.str, php.size, 1, fp); 32 fclose(fp); 33 printf("%s", php.str); 34 35 36 printf("\r\n"); 37 printf("気が変わったので確保したメモリを縮小させる"); 38 printf("\r\n"); 39 40 // (2)気が変わって確保したメモリを縮小 41 re_size = 30; 42 temp_str = realloc(php.str, re_size * sizeof(char) + 1); 43 if (temp_str != NULL) { 44 // メモリを1MBから30Bへと縮小したはずのメモリ 45 php.str = temp_str; 46 } else { 47 printf("You failed to shrink the memory."); 48 exit(2); 49 } 50 // php.strにファイルから文字列を読み込む 51 fp = fopen("test.public.pem", "rb"); 52 fread(php.str, re_size, 1, fp); 53 fclose(fp); 54 printf("%s", php.str); 55}
上記のようなコードで
事前に、php_structという構造体の中にchar*のポインタ変数を用意して起き
(1)の箇所で1000000を宣言して
php.strという変数に1MB分のメモリを確保したアドレスを保持しました。
その後、適当なテキストファイル等から1MB分を読み込みphp.strに保持しました。
ただその後
(2)の箇所で気が変わりphp.strの値を30Bまでメモリを下げたくなりました。
C
1temp_str = realloc(php.str, re_size * sizeof(char) + 1); 2 if (temp_str != NULL) { 3 // メモリを1MBから30Bへと縮小したはずのメモリ 4 php.str = temp_str; 5 } else { 6 printf("You failed to shrink the memory."); 7 exit(2); 8 }
上記の箇所です。
その後、再度適当なファイルからふたたび30B分をとりだしたところ、
なぜか、(1)で確保した量と同じ分ファイルから取り出しているようなのです。。。
そして、(1)でのメモリ確保量を100KBとかに一桁下げると正しく、reallocでメモリを縮小できているようです。
どうにも私の知識量では腑に落ちないのでお聞きしました。
ご教授のほどよろしくお願いいたします。
回答4件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2017/08/16 08:38
2017/08/16 09:19