ab.com コミュニティ

ActiveBasicを通したコミュニケーション
現在時刻 - 2024年4月27日(土) 20:29

全ての表示時間は UTC+09:00 です




返信する
ユーザー名:
件名:
メッセージ本文:
メッセージを入力してください。60000 字まで入力できます。 

フォントサイズ:
フォントカラー
オプション:
BBCode: ON
[img]: ON
[flash]: OFF
[url]: ON
スマイリー: OFF
BBCode を無効にする
URL を自動的にパースしない
クイズ
お手数ですがカタカナで「エービー」と4文字を入力してください。:
答えを正確に入力してください。答えられるかどうかでスパムボットか否かを判定します。
   

トピックのレビュー - ポインタ配列を開放
作成者 メッセージ
  記事の件名:   引用付きで返信する
konisiさん ありがとうございました。^^
投稿記事 Posted: 2009年4月07日(火) 00:08
  記事の件名:   引用付きで返信する
コード:
For i=0 To 100-1
    list=calloc( ... )
Next
のように確保した場合は、
コード:
For i=0 To 100-1
    free(list)
Next
のように開放する必要があります。

別解として、
コード:
'注:エラー処理を書いてない。
Type A
    length As Long
    list As *VoidPtr
End Type

Sub callocA(ByRef a As A,listlength As Long)
    Dim i As Long
    a.length=listlength
    a.list=calloc(listlength*sizeof(VoidPtr))
    For i=0 To length-1
        a.list=calloc( ... )
    Next
End Sub

Sub freeA(ByRef a As A)
    Dim i As Long
    For i=0 To a.length-1
        free(a.list)
    Next
    free(a.list)
    a.length=0
End Sub
のようにすることは出来ますね。
投稿記事 Posted: 2009年4月07日(火) 00:01
  記事の件名:  ポインタ配列を開放  引用付きで返信する
初心者rikaeigo2です。
配列でポインタを100個確保したら開放もループで100個開放するんですか?
お願いします。m(__)m
投稿記事 Posted: 2009年4月05日(日) 22:37

全ての表示時間は UTC+09:00 です


ページ移動:  
Powered by phpBB® Forum Software © phpBB Limited
Japanese translation principally by ocean