FreeBSD C言語でメモリの確保(malloc)と開放(free)のトレースする方法
スポンサーリンク
FreeBSDでメモリの確保や開放の状況をトレースする方法について
紹介します。
FreeBSDのCプログラミングでのメモリの確保はmallocなどの関数を利用し、
開放には、freeを利用します。
メモリの確保と開放のトレースのために、 ktraceとkdump コマンドを利用します。
malloc_test.c
コンパイル方法
実行方法
上記のコマンドを実行すると ktrace.out というファイルが作成されます。
このファイルの内容を確認するには、kdumpコマンドを使います。
kdump のより malloc/free のトレース結果
このように ktrace/kdump コマンドを利用し、メモリの確保や開放の
トレースを行うことができます。
紹介します。
FreeBSDのCプログラミングでのメモリの確保はmallocなどの関数を利用し、
開放には、freeを利用します。
メモリの確保と開放のトレースのために、 ktraceとkdump コマンドを利用します。
malloc_test.c
#include <stdio.h> #include <stdlib.h> int main (int argc, char *argv[]) { int *p, *q; p = malloc ( sizeof (int) ); free (p); p = malloc ( sizeof (int) * 1024); printf ("%p\n", p); q = realloc ( p, sizeof (int) * 2048 * 1024); printf ("%p\n", q); free (q); exit (EXIT_SUCCESS); }
コンパイル方法
cc malloc_test.c
実行方法
%env MALLOC_OPTIONS='U' ktrace ./a.out 0x8102000 0x8200000
上記のコマンドを実行すると ktrace.out というファイルが作成されます。
このファイルの内容を確認するには、kdumpコマンドを使います。
kdump のより malloc/free のトレース結果
%kdump -tu -f ktrace.out 58917 a.out USER malloc_init() 58917 a.out USER 0x8102094 = malloc(4) 58917 a.out USER free(0x8102094) 58917 a.out USER 0x8102000 = malloc(4096) 58917 a.out USER 0x8103000 = malloc(4096) 58917 a.out USER 0x8200000 = realloc(0x8102000, 8388608) 58917 a.out USER free(0x8200000)
このように ktrace/kdump コマンドを利用し、メモリの確保や開放の
トレースを行うことができます。
- malloc/realloc については jman malloc を参照のこと。
- jman ktrace
- jman kdump
スポンサーリンク
スポンサーリンク
いつもシェア、ありがとうございます!
もっと情報を探しませんか?
関連記事
最近の記事
- パナソニック ジェットウォッシャードルツ EW-DJ61-Wのホースの修理
- LinuxセキュリティモジュールIntegrity Policy Enforcement
- アマゾンのEcho Show 5を買ったのでレビューします
- アマゾンのサイバーマンデーはAlexa Echo Show 5が安い
- Android スマートフォン OnePlus 7T と OnePlus 7の違い
- Android スマートフォン OnePlus 7 をAndroid10にアップデートしてみた
- クレジットカードのバーチャルカードの比較のまとめ
- 活動量計 Xiaomi Mi Band 4を買ってみたのでレビュー
- Android スマートフォン OnePlus 7 のレビュー
- AliExpressでスマートフォンを買い物してみた
- パソコンのホコリ対策 レンジフードフィルターと養生テープ
- 80PLUS GOLDのPC電源ユニットAntec NeoEco 750 Goldのレビュー
- イギリスの付加価値税 VAT は払い戻しを受けられる
- イギリスのロンドンでスーツケースなど荷物を預けられる場所は
- イギリスのロンドンで地下鉄やバスに乗るならオイスターカードを使おう
- イギリスのヒースロー空港からロンドン市内への行き方
- 航空便でほかの航空会社に乗り継ぎがある場合のオンラインチェックイン
- SFC会員がANA便ではなくベトナム航空のコードシェアを試して解ったこと
- ベトナムの入国審査でeチケットの掲示が必要だった話
- シアトルの交通ICカードはオルカカード(Orca)です
人気のページ
- Windows7 IME 辞書ツールで単語の登録に失敗しました
- C言語 popen()でコマンドを実行して出力を読み込む
- Windows7で休止状態にする方法
- CentOS MySQLの起動、停止、再起動
- loggerコマンドでsyslogにエラーを出力する方法
- パソコンパーツの買取をしてくれる店のまとめ
- Java Mapの使い方 get(),put(),remove(),size(),clear()
- 楽天のRポイントカードを作ってみた
- iPhone 5 から iPhone 6 に乗り換えたのでレビュー
- netstatコマンドのステータスの意味
スポンサーリンク
過去ログ
2020 : 01 02 03 04 05 06 07 08 09 10 11 122019 : 01 02 03 04 05 06 07 08 09 10 11 12
2018 : 01 02 03 04 05 06 07 08 09 10 11 12
2017 : 01 02 03 04 05 06 07 08 09 10 11 12
2016 : 01 02 03 04 05 06 07 08 09 10 11 12
2015 : 01 02 03 04 05 06 07 08 09 10 11 12
2014 : 01 02 03 04 05 06 07 08 09 10 11 12
2013 : 01 02 03 04 05 06 07 08 09 10 11 12
2012 : 01 02 03 04 05 06 07 08 09 10 11 12
2011 : 01 02 03 04 05 06 07 08 09 10 11 12
2010 : 01 02 03 04 05 06 07 08 09 10 11 12
2009 : 01 02 03 04 05 06 07 08 09 10 11 12
2008 : 01 02 03 04 05 06 07 08 09 10 11 12
2007 : 01 02 03 04 05 06 07 08 09 10 11 12
2006 : 01 02 03 04 05 06 07 08 09 10 11 12
2005 : 01 02 03 04 05 06 07 08 09 10 11 12
2004 : 01 02 03 04 05 06 07 08 09 10 11 12
2003 : 01 02 03 04 05 06 07 08 09 10 11 12