2011-07-22 21 views
2

私は自分のApp Delegateに、LPProductオブジェクトの範囲を含むNSArrayを持っています。それらのそれぞれには、という値のCGFloatプロパティというLPColorオブジェクトの配列があります。一貫性のないオブジェクトのプロパティ

すべてのカスタマイズ可能なLPProductで配列を取得するために、私はというメソッドを作成しました。getCustomizableProductsもApp Delegateにあります。コードはここにある:

- (NSArray *)getCustomizableProducts 
{ 
    NSMutableArray *customizables = [[NSMutableArray alloc] initWithArray:[self products]]; 

    for (LPProduct *product in [self products]) 
    { 
     if (![product isCustomizable]) 
     { 
      [customizables removeObject:product]; 
     } 
    } 

    for (NSInteger i = 0; i < [customizables count]; i++) 
    { 
     for (NSInteger j = 0; j < [[[customizables objectAtIndex:i] colors] count]; j++) 
     { 
      NSLog(@"prices 1: %f", [[[[customizables objectAtIndex:i] colors] objectAtIndex:j] price]); 
     } 
    } 

    return (NSArray *) customizables; 
} 

のNSLogの結果は以下の通りです:

2011-07-22 14:06:44.463 La Portegna[2937:707] prices 1: 315.000000 
2011-07-22 14:06:44.470 La Portegna[2937:707] prices 1: 315.000000 
2011-07-22 14:06:44.472 La Portegna[2937:707] prices 1: 315.000000 
2011-07-22 14:06:44.473 La Portegna[2937:707] prices 1: 195.000000 
2011-07-22 14:06:44.475 La Portegna[2937:707] prices 1: 195.000000 
2011-07-22 14:06:44.477 La Portegna[2937:707] prices 1: 195.000000 
2011-07-22 14:06:44.478 La Portegna[2937:707] prices 1: 145.000000 
2011-07-22 14:06:44.482 La Portegna[2937:707] prices 1: 145.000000 
2011-07-22 14:06:44.484 La Portegna[2937:707] prices 1: 145.000000 
2011-07-22 14:06:44.489 La Portegna[2937:707] prices 1: 145.000000 
2011-07-22 14:06:44.492 La Portegna[2937:707] prices 1: 55.000000 
2011-07-22 14:06:44.495 La Portegna[2937:707] prices 1: 55.000000 
2011-07-22 14:06:44.498 La Portegna[2937:707] prices 1: 55.000000 
2011-07-22 14:06:44.501 La Portegna[2937:707] prices 1: 55.000000 
2011-07-22 14:06:44.504 La Portegna[2937:707] prices 1: 120.000000 
2011-07-22 14:06:44.507 La Portegna[2937:707] prices 1: 120.000000 
2011-07-22 14:06:44.510 La Portegna[2937:707] prices 1: 120.000000 
2011-07-22 14:06:44.513 La Portegna[2937:707] prices 1: 120.000000 
2011-07-22 14:06:44.516 La Portegna[2937:707] prices 1: 215.000000 
2011-07-22 14:06:44.519 La Portegna[2937:707] prices 1: 215.000000 
2011-07-22 14:06:44.521 La Portegna[2937:707] prices 1: 215.000000 
2011-07-22 14:06:44.524 La Portegna[2937:707] prices 1: 110.000000 
2011-07-22 14:06:44.527 La Portegna[2937:707] prices 1: 110.000000 
2011-07-22 14:06:44.530 La Portegna[2937:707] prices 1: 110.000000 
2011-07-22 14:06:44.533 La Portegna[2937:707] prices 1: 110.000000 
2011-07-22 14:06:44.536 La Portegna[2937:707] prices 1: 110.000000 
2011-07-22 14:06:44.539 La Portegna[2937:707] prices 1: 95.000000 
2011-07-22 14:06:44.542 La Portegna[2937:707] prices 1: 95.000000 
2011-07-22 14:06:44.545 La Portegna[2937:707] prices 1: 95.000000 
2011-07-22 14:06:44.548 La Portegna[2937:707] prices 1: 95.000000 
2011-07-22 14:06:44.550 La Portegna[2937:707] prices 1: 95.000000 
2011-07-22 14:06:44.553 La Portegna[2937:707] prices 1: 180.000000 
2011-07-22 14:06:44.556 La Portegna[2937:707] prices 1: 180.000000 
2011-07-22 14:06:44.559 La Portegna[2937:707] prices 1: 180.000000 
2011-07-22 14:06:44.561 La Portegna[2937:707] prices 1: 65.000000 
2011-07-22 14:06:44.564 La Portegna[2937:707] prices 1: 65.000000 
2011-07-22 14:06:44.568 La Portegna[2937:707] prices 1: 65.000000 
2011-07-22 14:06:44.571 La Portegna[2937:707] prices 1: 35.000000 
2011-07-22 14:06:44.573 La Portegna[2937:707] prices 1: 35.000000 
2011-07-22 14:06:44.576 La Portegna[2937:707] prices 1: 35.000000 
2011-07-22 14:06:44.579 La Portegna[2937:707] prices 1: 35.000000 
2011-07-22 14:06:44.582 La Portegna[2937:707] prices 1: 35.000000 
2011-07-22 14:06:44.585 La Portegna[2937:707] prices 1: 35.000000 
2011-07-22 14:06:44.588 La Portegna[2937:707] prices 1: 35.000000 

その後、他のUIViewControllerで、のviewDidLoadで、私はそのようなgetCustomizableProducts呼び出す:

- (void)viewDidLoad 
{ 
    [super viewDidLoad]; 

    // Do any additional setup after loading the view from its nib. 
    [[self navigationController] setNavigationBarHidden:YES]; 

    La_PortegnaAppDelegate *appDelegate = (La_PortegnaAppDelegate *) [[UIApplication sharedApplication] delegate]; 

    [self setAll:[appDelegate getCustomizableProducts]]; 

    for (NSInteger i = 0; i < [[self all] count]; i++) 
    { 
     for (NSInteger j = 0; j < [[[[self all] objectAtIndex:i] colors] count]; j++) 
     { 
      NSLog(@"prices 2: %f", [[[[[self all] objectAtIndex:i] colors] objectAtIndex:j] price]); 
     } 
    } 

    [self setProducts:[[NSMutableArray alloc] init]]; 

    [self getCollection:0]; 

    [self printCollection]; 
} 

しかし、NSLogの結果は期待通りではありません:

2011-07-22 14:06:44.590 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.593 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.596 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.600 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.602 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.605 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.608 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.611 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.614 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.617 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.620 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.622 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.625 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.628 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.631 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.634 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.637 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.640 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.643 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.646 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.649 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.652 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.654 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.657 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.660 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.663 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.666 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.669 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.672 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.675 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.678 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.681 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.683 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.686 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.689 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.692 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.695 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.697 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.701 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.704 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.707 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.709 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.712 La Portegna[2937:707] prices 2: 0.000000 
2011-07-22 14:06:44.715 La Portegna[2937:707] prices 2: 0.000000 

はNSArrayとして宣言されています。

誰でも私が間違っていることを言うことができますか?なぜ価格は突然消えますか?

ありがとうございます、よろしくお願い致します!

+0

NSLogでi&jも印刷してください。私はそれが役に立つと思う。 –

答えて

0

allが正しく設定されていないようです。代理人から返されたものと、allに格納されているものを確認し、問題を特定します。

- (void)viewDidLoad 
{ 
    [super viewDidLoad]; 

    // Do any additional setup after loading the view from its nib. 
    [[self navigationController] setNavigationBarHidden:YES]; 

    La_PortegnaAppDelegate *appDelegate = (La_PortegnaAppDelegate *) [[UIApplication sharedApplication] delegate]; 

    NSLog(@"customizables: %@",[appDelegate getCustomizableProducts]); // <-- add this 
    [self setAll:[appDelegate getCustomizableProducts]]; 
    NSLog(@"all: %@", [self all]);          // <-- and this 

    for (NSInteger i = 0; i < [[self all] count]; i++) 
    { 
     for (NSInteger j = 0; j < [[[[self all] objectAtIndex:i] colors] count]; j++) 
     { 
      NSLog(@"prices 2: %f", [[[[[self all] objectAtIndex:i] colors] objectAtIndex:j] price]); 
     } 
    } 

    [self setProducts:[[NSMutableArray alloc] init]]; 

    [self getCollection:0]; 

    [self printCollection]; 
} 

getCustomizableProductsメソッドでもメモリリークが発生しています。最後の行を

に変更することを検討してください。
return (NSArray *)[customizables autorelease]; 
+0

ありがとう、@アレックス、私はすでにメモリリークを解決しました。 私の問題については、問題はありませんでした。価格属性をCGFloatとして認識していないのはNSLogのラインでした。この行のLPColorにキャストすると、正しい値が表示されます。 –

関連する問題