37

UILabel のようなものが xib ファイルにリンクされている場合、ビューの dealloc で解放する必要がありますか? 私が尋ねる理由は、私がそれを割り当てていないからです。例 (ヘッダー内):

IBOutlet UILabel *lblExample;

実装では:

....
[lblExample setText:@"whatever"];
....

-(void)dealloc{
    [lblExample release];//?????????
}
4

8 に答える 8

35

現在ベスト プラクティスと見なされている方法に従う場合は、set アクセサーでそれらを保持する必要があるため、アウトレット プロパティを解放する必要があります

@interface MyController : MySuperclass {
    Control *uiElement;
}
@property (nonatomic, retain) IBOutlet Control *uiElement;
@end


@implementation MyController

@synthesize uiElement;

- (void)dealloc {
    [uiElement release];
    [super dealloc];
}
@end

このアプローチの利点は、メモリ管理のセマンティクスが明示的かつ明確になり、すべての nib ファイルのすべてのプラットフォームで一貫して機能することです

注: 次のコメントは、3.0 より前の iOS にのみ適用されます。3.0 以降では、viewDidUnload のプロパティ値を単純に nil にする必要があります。

ただし、ここでの考慮事項の 1 つは、コントローラーがユーザー インターフェイスを破棄し、要求に応じて動的に再読み込みする可能性がある場合です (たとえば、要求に応じて nib ファイルからビューを読み込むビュー コントローラーがある場合、メモリ不足など)。 -- ビューが再び必要になった場合にリロードできることを期待して、それを解放します)。この状況では、メイン ビューを破棄するときに、他のアウトレットの所有権も放棄して、それらも割り当て解除できるようにする必要があります。setView:UIViewController の場合、次のようにオーバーライドすることでこの問題に対処できます。

- (void)setView:(UIView *)newView {
    if (newView == nil) {
        self.uiElement = nil;
    }
    [super setView:aView];
}

残念ながら、これはさらなる問題を引き起こします。UIViewController は現在、 (単に変数を直接解放するのではなく) アクセサーdeallocメソッドを使用してそのメソッドを実装しているため、メモリ警告への応答としてだけでなく、 で呼び出されます... これにより、 でクラッシュが発生します。setView:self.anOutlet = nildeallocdealloc

救済策は、アウトレット変数も in に設定されていることを確認することnilですdealloc

- (void)dealloc {
    // release outlets and set variables to nil
    [anOutlet release], anOutlet = nil;
    [super dealloc];
}
于 2008-10-10T15:41:00.363 に答える
4

Apple ドキュメントで探していたものを見つけました。つまり、オブジェクトを解放して保持するプロパティ (または @property、@synthesize のみ) として設定できますが、UILabels のようなものについてはその必要はありません。

http://developer.apple.com/iphone/library/documentation/Cocoa/Conceptual/LoadingResources/CocoaNibs/chapter_3_section_4.html#//apple_ref/doc/uid/10000051i-CH4-SW18

于 2008-09-15T06:47:20.910 に答える
3

[anOutlet release], anOutlet = nil;

setView: を正しく記述していれば、この部分はまったく不要です。

于 2009-02-20T01:26:52.467 に答える
1

dealloc で解放しないと、メモリ フットプリントが増加します。

詳細については、インストゥルメント ObjectAlloc グラフを参照してください。

于 2010-02-19T11:05:49.990 に答える
0

NibのメインビューのサブビューであるIBOutletは、オブジェクトの作成時に自動解放メッセージが送信されるため、解放する必要はありません。Deallocでリリースする必要があるIBOutletは、コントローラーや他のNSObjectなどのトップレベルオブジェクトのみです。これはすべて、上記にリンクされているAppleのドキュメントに記載されています。

于 2008-09-15T13:44:15.273 に答える
0

IBOutlet をプロパティとしてではなく単にインスタンス変数として設定する場合でも、それを解放する必要があります。これは、initWithNib 時にすべての IBOutlets にメモリが割り当てられるためです。したがって、これは、コードでメモリを保持または割り当てていなくても、解放する必要がある特別なケースの 1 つです。

于 2012-04-13T04:28:13.523 に答える
0

関連: Cocoa / Objective C で参照カウントを理解する

于 2008-09-15T03:58:02.033 に答える
0

IB でラベルを作成することにより、ある意味でラベルを割り当てます。

IB が行うことは、IBOutlets とそれらがどのように定義されているかを確認することです。IB が何らかのオブジェクトへの参照を割り当てるクラス変数がある場合、IB はそのオブジェクトに保持メッセージを送信します。

プロパティを使用している場合、IB は値を設定する必要があるプロパティを使用し、値を明示的に保持しません。したがって、通常は IBOutlet プロパティを保持としてマークします。

@property (nonatomic, retain) UILabel *lblExample;

したがって、エーテルの場合 (プロパティを使用するかどうかに関係なく)、dealloc で release を呼び出す必要があります。

于 2008-09-15T04:49:13.640 に答える