2014-09-23 137 views
1

我試圖運行我的應用程序,但是,每次我點擊配置文件鏈接時,我的應用程序崩潰,並在調試輸出中收到以下消息。請參閱下面的截圖。我正在運行Xcode 5.1。線程1:信號SIGABRT Xcode 5.1

[UIImageView setFile:]: unrecognized selector sent to instance 0x10b2ebe00 
2014-09-23 11:54:33.498 [1295:60b] *** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[UIImageView setFile:]: unrecognized selector sent to instance 0x10b2ebe00' 
*** First throw call stack: 
(
    0 CoreFoundation      0x0000000102a97495 __exceptionPreprocess + 165 
    1 libobjc.A.dylib      0x00000001027f699e objc_exception_throw + 43 
    2 CoreFoundation      0x0000000102b2865d -[NSObject(NSObject) doesNotRecognizeSelector:] + 205 
    3 CoreFoundation      0x0000000102a88d8d ___forwarding___ + 973 
    4 CoreFoundation      0x0000000102a88938 _CF_forwarding_prep_0 + 120 
    5 Uscout        0x00000001000084c9 -[ProfileViewController updateUserStatus] + 185 
    6 Uscout        0x0000000100008408 -[ProfileViewController viewWillAppear:] + 88 
    7 UIKit        0x000000010149cdb5 -[UIViewController _setViewAppearState:isAnimating:] + 422 
    8 UIKit        0x00000001014bac4d -[UINavigationController _startTransition:fromViewController:toViewController:] + 707 
    9 UIKit        0x00000001014bb787 -[UINavigationController _startDeferredTransitionIfNeeded:] + 547 
    10 UIKit        0x00000001014bc238 -[UINavigationController __viewWillLayoutSubviews] + 43 
    11 UIKit        0x00000001015d6895 -[UILayoutContainerView layoutSubviews] + 202 
    12 UIKit        0x0000000101403993 -[UIView(CALayerDelegate) layoutSublayersOfLayer:] + 354 
    13 QuartzCore       0x0000000100e9a802 -[CALayer layoutSublayers] + 151 
    14 QuartzCore       0x0000000100e8f369 _ZN2CA5Layer16layout_if_neededEPNS_11TransactionE + 363 
    15 QuartzCore       0x0000000100e8f1ea _ZN2CA5Layer28layout_and_display_if_neededEPNS_11TransactionE + 24 
    16 QuartzCore       0x0000000100e02fb8 _ZN2CA7Context18commit_transactionEPNS_11TransactionE + 252 
    17 QuartzCore       0x0000000100e04030 _ZN2CA11Transaction6commitEv + 394 
    18 UIKit        0x00000001013a2024 _UIApplicationHandleEventQueue + 10914 
    19 CoreFoundation      0x0000000102a26d21 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 17 
    20 CoreFoundation      0x0000000102a265f2 __CFRunLoopDoSources0 + 242 
    21 CoreFoundation      0x0000000102a4246f __CFRunLoopRun + 767 
    22 CoreFoundation      0x0000000102a41d83 CFRunLoopRunSpecific + 467 
    23 GraphicsServices     0x0000000102d5bf04 GSEventRunModal + 161 
    24 UIKit        0x00000001013a3e33 UIApplicationMain + 1010 
    25 Uscout        0x0000000100007073 main + 115 
    26 libdyld.dylib      0x0000000105c505fd start + 1 
    27 ???         0x0000000000000001 0x0 + 1 
) 
libc++abi.dylib: terminating with uncaught exception of type NSException 
(lldb) 

enter image description here

ProfileViewController.m

#import "ProfileViewController.h" 

@interface ProfileViewController() 
@property (weak, nonatomic) IBOutlet PFImageView *profileImageView; 
@property (weak, nonatomic) IBOutlet UILabel *userNameLabel; 
@property (weak, nonatomic) IBOutlet UILabel *followersNumberLabel; 
@property (weak, nonatomic) IBOutlet UILabel *followingNumberLabel; 


@end 


@implementation ProfileViewController 

- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil 
{ 
    self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil]; 
    if (self) { 
     // Custom initialization 
    } 
    return self; 
} 

- (void)viewDidLoad 
{ 
    [super viewDidLoad]; 
    // Do any additional setup after loading the view. 
} 

- (void)didReceiveMemoryWarning 
{ 
    [super didReceiveMemoryWarning]; 
    // Dispose of any resources that can be recreated. 
} 

- (void)viewWillAppear:(BOOL)animated { 
    [super viewWillAppear:animated]; 
    [self updateUserStatus]; 
} 

- (void)updateUserStatus { 
    PFUser *user = [PFUser currentUser]; 
    self.profileImageView.file = user[@"profilePicture"]; 
    [self.profileImageView loadInBackground]; 
    self.userNameLabel.text = user.username; 

    PFQuery *followingQuery = [PFQuery queryWithClassName:@"Activity"]; 
    [followingQuery whereKey:@"fromUser" equalTo:user]; 
    [followingQuery whereKey:@"type" equalTo:@"follow"]; 
    [followingQuery findObjectsInBackgroundWithBlock:^(NSArray *followingActivities, NSError *error) { 
     if (!error) { 
      self.followingNumberLabel.text = [[NSNumber numberWithInteger:followingActivities.count] stringValue]; 
     } 
    }]; 

    PFQuery *followerQuery = [PFQuery queryWithClassName:@"Activity"]; 
    [followerQuery whereKey:@"toUser" equalTo:user]; 
    [followerQuery whereKey:@"type" equalTo:@"follow"]; 
    [followerQuery findObjectsInBackgroundWithBlock:^(NSArray *followerActivities, NSError *error) { 
     if (!error) { 
      self.followersNumberLabel.text = [[NSNumber numberWithInteger:followerActivities.count] stringValue]; 
     } 
    }]; 
} 

- (IBAction)logout:(id)sender { 
} 




@end 
+0

你在哪裏調用'setFile'?你可以發佈一些代碼嗎? – 2014-09-23 16:10:26

+2

'updateUserStatus'方法中的某個地方,您在錯誤類型的對象('UIImageView')上調用'setFile:',或者使用指向已釋放的對象並用'UIImageView'代替的指針。 – 2014-09-23 16:11:42

+0

另外,在斷點導航器中設置Objective-C異常的斷點。它會導致應用程序停止在比main()例程更有趣的地方。 – 2014-09-23 16:13:05

回答

2

在你ProfileViewController,在updateUserStatus方法,您呼叫的對象,不知道它的方法setFile。即:一個UIImageView。確保您正在使用您打算調用該方法的對象。

UPDATE

我們去那裏:

self.profileImageView.file = user[@"profilePicture"];

一個UIImageView,這樣有profileImageView,沒有一個file屬性,所以你不能對它進行設置。仔細檢查設置文件的目標類別。

+0

謝謝。這個班是不正確的。我需要將其更改爲PFImageView。投票 – Annette 2014-09-23 17:25:06