0

これが私のコードです:

NSMutableArray *ratings = [[NSMutableArray alloc] init];
    NSMutableDictionary *eachRating = [[NSMutableDictionary alloc] init];

    for (UIView *subview in self.rateServiceView.subviews) {

        if ([subview isKindOfClass:[RSTapRateView class]]) {

            RSTapRateView *rs = (RSTapRateView *)subview;
            [eachRating setObject:rs.rateId forKey:@"iRatingId"];
            [eachRating setObject:[NSNumber numberWithInt:rs.rating] forKey:@"iRate"];

            [ratings addObject:eachRating];

        }

    }

これらの値を取得する代わりに:

{
        iRate = 1;
        iRatingId = 1;
    },
        {
        iRate = 5;
        iRatingId = 2;
    },
        {
        iRate = 2;
        iRatingId = 3;
    }

私はこれらの値を取得しています:

{
        iRate = 2;
        iRatingId = 3;
    },
        {
        iRate = 2;
        iRatingId = 3;
    },
        {
        iRate = 2;
        iRatingId = 3;
    }

各反復の結果をログに記録すると、最後のオブジェクトが既存のすべてのオブジェクトを置き換え、それ自体に新しいオブジェクトを追加します。

4

3 に答える 3

2

次の行を移動します。

    NSMutableDictionary *eachRating = [[NSMutableDictionary alloc] init];

この行の下まで:

    for (UIView *subview in self.rateServiceView.subviews) {

そうすることで、配列に追加する新しい " eachRating" ディクショナリを作成できます。ratings

于 2013-08-19T08:34:03.800 に答える
1

はい、これは、同じキーに異なる値を割り当てているため、そのキーの古い値が新しい値に置き換えられるためです。

したがって、コードを次のように変更します。

  NSMutableArray *ratings = [[NSMutableArray alloc] init];
    for (UIView *subview in self.rateServiceView.subviews){

        if ([subview isKindOfClass:[RSTapRateView class]]) {

            NSMutableDictionary *eachRating = [[NSMutableDictionary alloc] init];


            RSTapRateView *rs = (RSTapRateView *)subview;
            [eachRating setObject:rs.rateId forKey:@"iRatingId"];
            [eachRating setObject:[NSNumber numberWithInt:rs.rating] forKey:@"iRate"];

            [ratings addObject:eachRating];

        }

    }
于 2013-08-19T08:33:51.500 に答える
0

このループの後に個々の辞書のさらなる可変性を必要としない場合は、次のように書くことで、もう少しモダンでコンパクトにすることができます:

NSMutableArray *ratings = [[NSMutableArray alloc] init];

for (UIView *subview in self.rateServiceView.subviews) {

    if ([subview isKindOfClass:[RSTapRateView class]]) {

        RSTapRateView *rs = (RSTapRateView *)subview;
        [ratings addObject:@{@"iRatingId":rs.rateId, @"iRate":@(rs.rating)}];

    }

}
于 2013-08-19T08:40:43.437 に答える