0

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) 

NSDictionary 全体を示す最初の NSLog は、次のことを示しています。

{
    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
    );
} 

ID、名前、およびシーケンス値を取得する「フィルター」でノードごとに新しいオブジェクトを作成しようとしています

4

1 に答える 1

4

ステートメントが何を言っているのかを見たり、実際に例外が何であるかを知らなくても、コードで例外をスローする可能性NSLogのあるすべてのものを以下に示します。

for(NSString *key in dataDictionary) {

dataDictionaryこの行は、実際にはではなく、、 などNSDictionaryの他の非<NSFastEnumeration>JSON オブジェクトである場合にスローされる可能性があります。NSStringNSNumber

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

keyこの行は、実際にはNSStringではないため、 method を実装していない場合にスローされる可能性があります-isEqualToString:

        NSDictionary *filtersSubDict = [dataDictionary objectForKey:key];

この行は、高速に列挙可能な JSON オブジェクトである場合にスローされる可能性dataDictionaryがありますが、実際にはNSDictionary. (つまり、 である可能性がありNSArray、この行は「セレクター 'objectForKey:' を認識しません」という例外をスローします)。

        for (NSString *sfKey in filtersSubDict) {

上記のように、これは、またはでfiltersSubDictはない場合にスローされる可能性があります。NSArrayNSDictionary

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

filtersSubDictこれは、ではない場合にスローされる可能性NSDictionaryがありますが、代わりにNSArray(上記と同じ)です。

        }
    }
}

したがって、行にスローされている場合、それは実際には辞書ではなく、認識されないセレクター例外が発生しているfilterObject = ...可能性があります。filtersSubDict

于 2013-04-09T18:04:48.930 に答える