итерация через NSDictionary с подобъектами

У меня есть метод, который принимает NSDictionary:

-(id)initWithJSONDictionary:(NSDictionary *)dataDictionary{
     self = [super init];
     NSLog(@"********************************* %@ ",dataDictionary);
     for(NSString * key in dataDictionary){
         if([key isEqualToString:@"filters"]){
             NSDictionary * filtersSubDict = [dataDictionary objectForKey:key];
             for(NSString *sfKey in filtersSubDict){
                 NSLog(@"new filter: %@", sfKey );               
                 NSDictionary *filterObject = [filtersSubDict objectForKey:sfKey];
                 // this line is throwing some kind of thread exception
             }
          }
      }
      return self;
}

любая подсказка относительно того, почему строка с комментарием под ней вызывает исключение: ** Стек вызовов первого броска:

(0x1d04012 0x1141e7e 0x1d8f4bd 0x1cf3bbc 0x1cf394e 0x1052b 0x137fe 0x259b3 0x4a6853f 0x4a7a014 0x4a6a7d5 0x1caaaf5 0x1ca9f44 0x1ca9e1b 0x1c5e7e3 0x1c5e668 0x85ffc 0x27fd 0x2725)
libc++abi.dylib: terminate called throwing an exception
(lldb) 

Первый NSLog, показывающий весь NSDictionary, показывает это:

{
    errorCode = 0;
    filters =     (
                {
            id = 1001;
            name = "Base Lenses";
            sequence = 1;
        },
                {
            id = 1002;
            name = "Standard Anti-Reflective";
            sequence = 2;
        },
                {
            id = 1003;
            name = "Premium Anti-Reflective";
            sequence = 3;
        },
                {
            id = 1004;
            name = "Enhanced Scratch Resistance";
            sequence = 4;
        },
                {
            id = 1005;
            name = Sun;
            sequence = 5;
        },
                {
            id = 1006;
            name = Tint;
            sequence = 6;
        },
                {
            id = 1007;
            name = "Clear To Dark";
            sequence = 7;
        }
    );
    lenses =     {
        Glass =         (
                        {
                fsv = 1;
                inStore = 1;
                lom = 0;
                price = 465;
                style = "Glass Std AR";
                styleFilters =                 (
                    1002
                );
                type = "Single Vision";
                visionCorrection = singleVision;
            },
                        {
                fsv = 1;
                inStore = 0;
                lom = 1;
                price = 395;
                style = "Prem Plastic Std AR";
                styleFilters =                 (
                    1002
                );
                type = "SV HD";
                visionCorrection = singleVision;
            }
        );
        "Plastic/Hi-index" =         (
                        {
                fsv = 1;
                inStore = 1;
                lom = 0;
                price = 395;
                style = "Prem Plastic Std AR";
                styleFilters =                 (
                    1002,
                    1006
                );
                type = "SV HD";
                visionCorrection = singleVision;
            },
                        {
                fsv = 1;
                inStore = 0;
                lom = 1;
                price = 465;
                style = "Glass Std AR";
                styleFilters =                 (
                    1002,
                    1006
                );
                type = "SV HD";
                visionCorrection = singleVision;
            }
        );
        Polycarbonate =         (
                        {
                fsv = 1;
                inStore = 1;
                lom = 0;
                price = 395;
                style = "FeatherWates Classic";
                styleFilters =                 (
                    1001
                );
                type = "SV Wrap";
                visionCorrection = singleVision;
            },
                        {
                fsv = 1;
                inStore = 0;
                lom = 1;
                price = 495;
                style = "FeatherWates Classic";
                styleFilters =                 (
                    1001
                );
                type = "SV Wrap";
                visionCorrection = singleVision;
            }
        );
    };
    materials =     (
        Polycarbonate,
        "Plastic/Hi-index",
        Glass
    );
} 

Я пытаюсь создать новый объект для каждого узла в «фильтрах», получая значения идентификатора, имени и последовательности.


person erik    schedule 09.04.2013    source источник
comment
Этот стек вызовов бесполезен:/ Пожалуйста, символизируйте его.   -  person    schedule 09.04.2013
comment
Попробуйте перейти на вкладку точек останова и включить точку останова для всех исключений. Это сломает отладчик, когда он выдаст исключение, которое вы видите.   -  person thegrinner    schedule 09.04.2013
comment
Смотрите свой код после форматирования. Разве я не заслуживаю +10?   -  person Anoop Vaidya    schedule 09.04.2013
comment
Что-нибудь изменяет ваш словарь или какие-либо его листья в другом потоке?   -  person Marcus Adams    schedule 09.04.2013


Ответы (1)


Не видя, что говорит ваш оператор NSLog, и не зная, что на самом деле представляет собой ваше исключение, вот все вещи, которые могут вызвать исключение в вашем коде:

for(NSString *key in dataDictionary) {

Эта строка может вызвать исключение, если dataDictionary на самом деле не является NSDictionary, а является каким-то другим объектом JSON, отличным от <NSFastEnumeration>, например NSString, NSNumber и т. д.

    if([key isEqualToString:@"filters"]){

Эта строка может вызвать исключение, если key на самом деле не является NSString и, следовательно, не реализует метод -isEqualToString:.

        NSDictionary *filtersSubDict = [dataDictionary objectForKey:key];

Эта строка может выдать ошибку, если dataDictionary является быстроперечислимым объектом JSON, но на самом деле не является NSDictionary. (Другими словами, это может быть NSArray, и эта строка вызовет исключение «не распознает селектор ‘objectForKey:’»).

        for (NSString *sfKey in filtersSubDict) {

Как и выше, это может привести к ошибке, если filtersSubDict не является NSArray или NSDictionary.

            NSLog(@"new filter: %@", sfKey );
            NSDictionary *filterObject = [filtersSubDict objectForKey:sfKey];

Это может привести к ошибке, если filtersSubDict не является NSDictionary, а вместо этого является NSArray (как указано выше).

        }
    }
}

Поэтому, если он выдает строку filterObject = ..., то есть вероятность, что filtersSubDict на самом деле не словарь, и вы получаете исключение нераспознанного селектора.

person Dave DeLong    schedule 09.04.2013