Ios 将PFUser对象存储在PFUser密钥中会导致崩溃

Ios 将PFUser对象存储在PFUser密钥中会导致崩溃,ios,objective-c,parse-platform,pfobject,pfuser,Ios,Objective C,Parse Platform,Pfobject,Pfuser,我已经花了一整天的时间试图找出我做错了什么,但是我完全不知道为什么这个应用程序总是崩溃 情况如下: 我已经建立了一个简单的项目,实现了所有必需的库和框架。我使用以下实例方法创建了几个解析用户: [self signUpUserWithName:@"nico" withPassword:@"123"]; [self signUpUserWithName:@"gabriel" withPassword:@"123"]; [self signUpUserWithName:@"bruno" withPa

我已经花了一整天的时间试图找出我做错了什么,但是我完全不知道为什么这个应用程序总是崩溃

情况如下:

我已经建立了一个简单的项目,实现了所有必需的库和框架。我使用以下实例方法创建了几个解析用户:

[self signUpUserWithName:@"nico" withPassword:@"123"];
[self signUpUserWithName:@"gabriel" withPassword:@"123"];
[self signUpUserWithName:@"bruno" withPassword:@"123"];
在这里您可以看到方法实现:

-(void)signUpUserWithName:(NSString *)username withPassword:(NSString *)password{

    PFUser* user = [PFUser user];
    user.password = password;
    user.username = username;



    [user signUpInBackgroundWithBlock:^(BOOL succeeded, NSError *error) {
        if(!error){
            NSLog(@"User created.");
        }
        else{
            NSLog(@"User couldn't be created.");
        }
    }];

}
这就像预期的那样,用户被创建,一切都很好。现在,我正在登录一个用户,并使用以下代码为当前用户创建一个PFUser对象:

  [PFUser logInWithUsername:@"user1" password:@"123"];


    //Fetching Current User
    PFUser* currentUser = [PFUser currentUser];
    if ([currentUser isAuthenticated]){
        NSLog(@"Authenticated");
    }
    else{
        NSLog(@"Not Authenticated");
    }
这也如预期的那样起作用。用户已登录,我收到一个经过身份验证的currentUser对象。现在,我尝试通过查询获取用户的对象,如果成功,则将结果对象分配给我当前用户的键“myfriends”(创建一对一关系)

这也如预期的那样起作用。如果我现在在Parse中打开数据浏览器,我可以看到一个指向user2对象的指针被分配给了“myfriends”

但如果我重新启动应用程序,就会发生崩溃。如果我为另一个PFUser的“myfriends”键分配了PFUser以外的内容,例如打开了一些数据的PFObject,则一切正常。没有撞车,很好。但如果我试图分配PFUser,它会崩溃,并显示以下消息:

2015-01-19 13:44:09.135 localizr[2320:281655] -[__NSCFBoolean _loadSensitiveUserDataFromKeychainItemWithName:]: unrecognized selector sent to instance 0x19967eb60
2015-01-19 13:44:09.136 localizr[2320:281655] *** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[__NSCFBoolean _loadSensitiveUserDataFromKeychainItemWithName:]: unrecognized selector sent to instance 0x19967eb60'
*** First throw call stack:
(0x188301e48 0x1989fc0e4 0x188308f14 0x188305cc4 0x18820ac1c 0x1000758a4 0x10006f97c 0x10007f25c 0x10007ecbc 0x10007ead4 0x10000d1f8 0x18cb223d0 0x18cd39230 0x18cd3b9b0 0x18cd3a048 0x190565640 0x1882ba124 0x1882b922c 0x1882b742c 0x1881e51f4 0x18cb1b78c 0x18cb16784 0x10000d4c4 0x19906aa08)
libc++abi.dylib: terminating with uncaught exception of type NSException
(lldb)
我做错了什么? 谢谢你的帮助

祝福 尼科

编辑: 以下是您要求的堆栈跟踪:

* thread #1: tid = 0xca4e, 0x0000000196d93270 libsystem_kernel.dylib`__pthread_kill + 8, queue = 'com.apple.main-thread', stop reason = signal SIGABRT
    frame #0: 0x0000000196d93270 libsystem_kernel.dylib`__pthread_kill + 8
    frame #1: 0x0000000196e31228 libsystem_pthread.dylib`pthread_kill + 112
    frame #2: 0x0000000196d0ab18 libsystem_c.dylib`abort + 112
    frame #3: 0x0000000195df1418 libc++abi.dylib`abort_message + 116
    frame #4: 0x0000000195e10b8c libc++abi.dylib`default_terminate_handler() + 304
    frame #5: 0x000000019660c3c0 libobjc.A.dylib`_objc_terminate() + 128
    frame #6: 0x0000000195e0dbb4 libc++abi.dylib`std::__terminate(void (*)()) + 16
    frame #7: 0x0000000195e0d73c libc++abi.dylib`__cxa_rethrow + 144
    frame #8: 0x000000019660c294 libobjc.A.dylib`objc_exception_rethrow + 44
    frame #9: 0x0000000185df52a4 CoreFoundation`CFRunLoopRunSpecific + 572
    frame #10: 0x000000018a72b78c UIKit`-[UIApplication _run] + 552
    frame #11: 0x000000018a726784 UIKit`UIApplicationMain + 1488
  * frame #12: 0x00000001001015d4 localizr`main(argc=1, argv=0x000000016fd03a68) + 116 at main.m:14
    frame #13: 0x0000000196c7aa08 libdyld.dylib`start + 4

我在应用程序中删除了导致相同问题的[Parse enableLocalDatastore]


似乎已解决。

此问题似乎已通过Parse iOS/OS X SDK的v1.6.3更新得到解决。虽然我遇到了同样的问题,但我还没有更新到新版本,所以我还不能说它是否真的有效


有关官方讨论和响应,请参阅。

崩溃时,符号化堆栈跟踪是什么样子的?(例如,如果您在调试器控制台中键入“bt”),虽然此链接可以回答问题,但最好在此处包含答案的基本部分,并提供链接以供参考。“如果链接页面发生更改,只有链接的答案可能会无效。”luke He总结道。这篇文章的重要部分说:“现在应该通过我们的iOS/OS X SDK的v1.6.3解决这个问题。感谢您的耐心等待。”我认为马吕斯的总结足够了,因为链接中也没有给出更多的细节——除了这个问题显然是由解析本地数据存储和解析Facebook UTIL之间的错误交互引起的事实——我不知道@Luke缺少了什么…@Marius yep。你完全正确。在更新到Parse v1.6.3之后,包括这一个在内的几个错误正在得到解决。谢谢
* thread #1: tid = 0xca4e, 0x0000000196d93270 libsystem_kernel.dylib`__pthread_kill + 8, queue = 'com.apple.main-thread', stop reason = signal SIGABRT
    frame #0: 0x0000000196d93270 libsystem_kernel.dylib`__pthread_kill + 8
    frame #1: 0x0000000196e31228 libsystem_pthread.dylib`pthread_kill + 112
    frame #2: 0x0000000196d0ab18 libsystem_c.dylib`abort + 112
    frame #3: 0x0000000195df1418 libc++abi.dylib`abort_message + 116
    frame #4: 0x0000000195e10b8c libc++abi.dylib`default_terminate_handler() + 304
    frame #5: 0x000000019660c3c0 libobjc.A.dylib`_objc_terminate() + 128
    frame #6: 0x0000000195e0dbb4 libc++abi.dylib`std::__terminate(void (*)()) + 16
    frame #7: 0x0000000195e0d73c libc++abi.dylib`__cxa_rethrow + 144
    frame #8: 0x000000019660c294 libobjc.A.dylib`objc_exception_rethrow + 44
    frame #9: 0x0000000185df52a4 CoreFoundation`CFRunLoopRunSpecific + 572
    frame #10: 0x000000018a72b78c UIKit`-[UIApplication _run] + 552
    frame #11: 0x000000018a726784 UIKit`UIApplicationMain + 1488
  * frame #12: 0x00000001001015d4 localizr`main(argc=1, argv=0x000000016fd03a68) + 116 at main.m:14
    frame #13: 0x0000000196c7aa08 libdyld.dylib`start + 4