OGeek|极客世界-中国程序员成长平台

标题: ios - Objective-C - 因保留周期而丢失 [打印本页]

作者: 菜鸟教程小白    时间: 2022-12-13 05:07
标题: ios - Objective-C - 因保留周期而丢失

在解雇我的 VC 时,我注意到我没有从内存中释放所有内容。我对如何找到我的保留周期感到非常迷茫。我正在使用 NSTimer 和 NSNotificationCenter,但我确保在退出之前使和 removeObservers 无效,并且我确保使用弱委托(delegate)。

我的保留周期还会发生在哪里?在动画 block 中?像这样?

 [UIView animateWithDuration:.1 delay:0 options:UIViewAnimationOptionCurveEaseInOut animations:^{
                self.setListTableViewVertConst.constant = 0;
                self.setListTableViewHeightConst.constant = 264;
            } completion:^(BOOL finished) {

            }];

在使用 GCD 时,我确保使用 weakSelf。

__weak typeof(self) weakSelf = self;
            dispatch_async(dispatch_get_main_queue(), ^{
                [weakSelf.remotePasswordTextField resignFirstResponder];
            });

感谢您的帮助。

编辑:

-(void)prepareForSegueUIStoryboardSegue *)segue senderid)sender
{
    //Send the room code to be displayed on the respective view controllers. 
    if ([segue.identifier isEqualToString"toSetListRoomVC"]) {
        SetListRoomViewController *setListVC = segue.destinationViewController;
        setListVC.roomCode = self.roomCodeTextField.text;
    }

}

viewWIllApear

[super viewWillAppear:YES];


    self.socket = [[SocketKeeperSingleton sharedInstance]socket];
    self.socketID = [[SocketKeeperSingleton sharedInstance]socketID];

    NSString *roomCodeAsHost = [[SocketKeeperSingleton sharedInstance]hostRoomCode];
    /////////HOST/////////
    if ([[SocketKeeperSingleton sharedInstance]isHost]) {

        [[NSNotificationCenter defaultCenter] addObserver:self
                                                 selectorselector(receiveHostSongAddedNotification
                                                     name:kQueueAdd
                                                   object:nil];

        [[NSNotificationCenter defaultCenter] addObserver:self
                                                 selectorselector(receiveUserJoinedNotification
                                                     name:kUserJoined
                                                   object:nil];

        NSLog(@"User is the host of this room");
        self.isHost = YES;
        [self viewForNoCurrentArtistAsHost];
        self.roomCodeLabel.text = roomCodeAsHost;

        if (!self.hostQueue) {
            self.hostQueue = [[NSMutableArray alloc]init];
        }
        if (!self.hostCurrentArtist) {
            self.hostCurrentArtist = [[NSMutableDictionary alloc]init];
        }

        if (!self.player) {
            self.player = [[AVPlayer alloc]init];
        }
        if (!self.timer) {
            self.timer = [[NSTimer alloc]init];
        }
    }

    ///////NOT HOST///////
    else {
        // Add a notifcation observer and postNotification name for updating the tracks.
        [[NSNotificationCenter defaultCenter] addObserver:self
                                                 selectorselector(receiveQueueUpdatedNotification
                                                     name:kQueueUpdated
                                                   object:nil];

        //Add a notifcation observer and postNotification name for updating current artist.
        [[NSNotificationCenter defaultCenter] addObserver:self
                                                 selectorselector(receiveCurrentArtistUpdateNotification
                                                     name:kCurrentArtistUpdate
                                                   object:nil];

        [[NSNotificationCenter defaultCenter] addObserver:self
                                                 selectorselector(receiveOnDisconnectNotification
                                                     name:kOnDisconnect
                                                   object:nil];

        [[NSNotificationCenter defaultCenter] addObserver:self
                                                 selectorselector(receiveHostDisconnectNotification
                                                     name:kHostDisconnect
                                                   object:nil];


        //Add some animations upon load up. Purple glow and tableview animation.
        double delay = .4;
        [self purpleGlowAnimationFromBottomWithDelay:&delay];
        [self.tableView reloadSections:[NSIndexSet indexSetWithIndex:0] withRowAnimation:UITableViewRowAnimationBottom];

        //Set Current artist, if there is one.
        NSDictionary *currentArtist = [[SocketKeeperSingleton sharedInstance]currentArtist];
        [self setCurrentArtistFromCurrentArtist:currentArtist];


        //Set the current tracks, if there is one.
        NSArray *setListTracks = [[SocketKeeperSingleton sharedInstance]setListTracks];
        if (setListTracks) {
            self.tracks = setListTracks;
        }
    }
}

tableVIEWs

-(NSInteger)tableViewUITableView *)tableView numberOfRowsInSectionNSInteger)section
{
    if (tableView.tag == 1) {
        if (self.isHost) {
            return [self.hostQueue count];
        }
        else return [self.tracks count];
    }
    else return [self.searchTracks count];
}

-(NSInteger)numberOfSectionsInTableViewUITableView *)tableView
{
    return 1;
}



Best Answer-推荐答案


我注意到您在某些评论中使用了“popOut”一词,因此我假设您使用的是导航 Controller 。

如果是这种情况,您的 View Controller 将被嵌入它的导航 Controller 保留,并且不会被释放。导航 Controller 需要保存对您的 VC 的引用(请参阅 UINavigationController.viewControllers),以便在您弹出层次结构中的顶部/下一个 VC 时它可以返回到它。

这是预期的行为。

关于ios - Objective-C - 因保留周期而丢失,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28270768/






欢迎光临 OGeek|极客世界-中国程序员成长平台 (http://ogeek.cn/) Powered by Discuz! X3.4