Callback strong Reference Cycle

47 Views Asked by At

Is the following creating a strong reference cycle? I have a feeling it is because I'm referencing self within callback.

- (void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary *)info {
    [picker dismissViewControllerAnimated:YES completion:^{
        UIImage *image = [self cropImageWithInfo:info];
        if (currentScreen == CurrentScreenApartment) {
            [self.profileViewModel.apartmentPhotos addObject:[RuntimePhoto runtimePhotoWithImage:image]];
        }
        else {
            [self.profileViewModel.userPhotos addObject:[RuntimePhoto runtimePhotoWithImage:image]];
        }
        dispatch_async(dispatch_get_main_queue(), ^{
            [self reloadPhotosCell];
        });
    }];
}
1

There are 1 best solutions below

0
On

You can use a weak variable of self:

- (void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary *)info {

    typeof(self) __weak weakSelf = self;

    [picker dismissViewControllerAnimated:YES completion:^{
        UIImage *image = [weakSelf cropImageWithInfo:info];
        if (currentScreen == CurrentScreenApartment) {
            [weakSelf.profileViewModel.apartmentPhotos addObject:[RuntimePhoto runtimePhotoWithImage:image]];
        }
        else {
            [weakSelf.profileViewModel.userPhotos addObject:[RuntimePhoto runtimePhotoWithImage:image]];
        }
        dispatch_async(dispatch_get_main_queue(), ^{
            [weakSelf reloadPhotosCell];
        });
    }];
}