如何解决 malloc_error_break 错误?

5
我在 iOS 3.0 模拟器上遇到了这个错误,但在 3.1.3 和 3.2 模拟器上没有出现这个问题。
malloc_error_break 上创建符号断点后,在日志中看到了以下内容:
[Session started at 2010-02-13 19:15:22 +0700.]
2010-02-13 19:15:24.405 iPortals[21656:207] bool for 1
iPortals(21656,0xa0089500) malloc: *** error for object 0x285e000: pointer being freed was not allocated
*** set a breakpoint in malloc_error_break to debug
iPortals(21656,0xa0089500) malloc: *** error for object 0x2850000: pointer being freed was not allocated
*** set a breakpoint in malloc_error_break to debug
iPortals(21656,0xa0089500) malloc: *** error for object 0x286c000: pointer being freed was not allocated
*** set a breakpoint in malloc_error_break to debug
iPortals(21656,0xa0089500) malloc: *** error for object 0x287c000: pointer being freed was not allocated
*** set a breakpoint in malloc_error_break to debug

这里是我的代码。
@implementation WebViewController

@synthesize myWebView;
@synthesize AppDelegate;
@synthesize mybanner;
@synthesize request;

- (void)dealloc
{
    //NSLog(@"WebViewController has been dealloc");
    myWebView.delegate = nil;
    self.myWebView = nil;
    [self.myWebView release];
    [super setView:nil];


    [myWebView release];
    myWebView = nil;
    request = nil;

    [mybanner release];
    [super dealloc];
}

- (void)setView:(UIView *)aView
{
    //NSLog(@"setView:(UIView *)aView");
    if (aView == nil) {
        self.myWebView = nil;
    }    
    [super setView:aView];
}

- (void)action {
    AppDelegate = nil;
    AppDelegate = [[UIApplication sharedApplication] delegate];
    [[UIApplication sharedApplication] openURL:[NSURL URLWithString:AppDelegate.PushLink]];
}

- (void)didReceiveMemoryWarning {

    //NSLog(@"didReceiveMemoryWarning: view = %@, superview = %@", [self valueForKey:@"_view"], [[self valueForKey:@"_view"] superview]);
    [super didReceiveMemoryWarning]; // Releases the view if it doesn't have a superview
    // Release anything that's not essential, such as cached data
    [[NSURLCache sharedURLCache] removeAllCachedResponses];
}

- (void)viewDidLoad
{
    [super viewDidLoad];
    //NSLog(@"viewDidLoad: view = %@", self.view);
    self.title = NSLocalizedString(@"iPortals", @"");


    //UIBarButtonItem *customItem = [[UIBarButtonItem alloc] initWithTitle:@"Item" style:UIBarButtonItemStyleBordered   target:self action:@selector(action];
    //self.navigationController.toolbar setItems: = [[UIBarButtonItem alloc] initWithTitle:@"[...]" style:UIBarButtonItemStyleBordered target:self action:@selector(action)];

    /*
    UIBarButtonItem *emailButton = [[UIBarButtonItem alloc]
                                    initWithImage:[UIImage imageNamed:@"icon.png"]
                                    style:UIBarButtonItemStylePlain target:self
                                    action:@selector(action)];
    self.toolbarItems = [NSArray arrayWithObjects:emailButton, nil];
    [emailButton release];
    //*/
    AppDelegate = nil;
    AppDelegate = [[UIApplication sharedApplication] delegate];

    //NSLog(@"777777777 %@",AppDelegate.PushLink);
    /*
    CGRect webFrame = [[UIScreen mainScreen] applicationFrame];
    webFrame.origin.y += kTopMargin + 5.0;  // leave from the URL input field and its label
    webFrame.size.height = 400;
    //webFrame.size.height -= 40.0;
    self.myWebView = nil;

    //*/
    //self.myWebView = [[[UIWebView alloc] initWithFrame:webFrame] autorelease];

    self.myWebView.backgroundColor = [UIColor grayColor];
    self.myWebView.scalesPageToFit = YES;
    self.myWebView.autoresizingMask = (UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight);
    self.myWebView.delegate = self;

    [self.view addSubview: self.myWebView];
    self.mybanner.backgroundColor = [UIColor clearColor];
    [self.view addSubview: self.mybanner];

    /*
    CGRect textFieldFrame = CGRectMake(kLeftMargin, kTweenMargin,
                                       self.view.bounds.size.width - (kLeftMargin * 2.0), kTextFieldHeight);
    UITextField *urlField = [[UITextField alloc] initWithFrame:textFieldFrame];
    urlField.borderStyle = UITextBorderStyleBezel;
    urlField.textColor = [UIColor blackColor];
    urlField.delegate = self;
    urlField.placeholder = @"<enter a URL>";
    urlField.text = AppDelegate.PushLink;
    urlField.backgroundColor = [UIColor whiteColor];
    urlField.autoresizingMask = UIViewAutoresizingFlexibleWidth;
    urlField.returnKeyType = UIReturnKeyGo;
    urlField.keyboardType = UIKeyboardTypeURL;  // this makes the keyboard more friendly for typing URLs
    urlField.autocapitalizationType = UITextAutocapitalizationTypeNone; // don't capitalize
    urlField.autocorrectionType = UITextAutocorrectionTypeNo;   // we don't like autocompletion while typing
    urlField.clearButtonMode = UITextFieldViewModeAlways;
    [urlField setAccessibilityLabel:NSLocalizedString(@"URLTextField", @"")];
    [self.view addSubview:urlField];
    [urlField release];
     */

    request = nil;
    request = [NSURLRequest requestWithURL:[NSURL URLWithString:AppDelegate.PushLink]
                               cachePolicy:NSURLRequestUseProtocolCachePolicy
                           timeoutInterval:60.0];
    [self.myWebView loadRequest:request];
}

// called after the view controller's view is released and set to nil.
// For example, a memory warning which causes the view to be purged. Not invoked as a result of -dealloc.
// So release any properties that are loaded in viewDidLoad or can be recreated lazily.
//
- (void)viewDidUnload
{
    [super viewDidUnload];

    // release and set to nil

    [self.myWebView release];
    self.myWebView = nil;

}

-(BOOL)canBecomeFirstResponder {
    //NSLog(@"canBecomeFirstResponder ");
    return YES;
}

-(void)viewDidAppear:(BOOL)animated {
    //NSLog(@"viewDidAppear ");

    [self becomeFirstResponder];
}

- (void)motionBegan:(UIEventSubtype)motion withEvent:(UIEvent *)event {
    //NSLog(@"overrideoverrideoverrideoverrideoverrideoverrideoverrideoverride ");
    if ( event.subtype == UIEventSubtypeMotionShake )
    {
        // Put in code here to handle shake
        AppDelegate = nil;
        AppDelegate = [[UIApplication sharedApplication] delegate];
        [AppDelegate ToggleNavigationBar];
        [AppDelegate playsound:1];
        [self setAdHide:AppDelegate.toggle];

    }
}

- (void)setAdHide:(BOOL)hide {

    [UIView beginAnimations:nil context:NULL];
    [UIView setAnimationDuration:0.6];
    if (!hide) {
        if (current == UIInterfaceOrientationLandscapeLeft || current == UIInterfaceOrientationLandscapeRight) {
            [mybanner setFrame:CGRectMake(0, 272, mybanner.frame.size.width, mybanner.frame.size.height)];
        }
        else {
            [mybanner setFrame:CGRectMake(0, 432, mybanner.frame.size.width, mybanner.frame.size.height)];
        }
    }
    else {
        [self restoreAd];
    }
    [UIView commitAnimations];

}

- (void)restoreAd {
    [UIView beginAnimations:nil context:NULL];
    [UIView setAnimationDuration:0.6];
    [mybanner setFrame:CGRectMake(0, 0, mybanner.frame.size.width, mybanner.frame.size.height)];    
    [UIView commitAnimations];
}

#pragma mark -
#pragma mark UIViewController delegate methods

- (void)viewWillAppear:(BOOL)animated
{
    self.myWebView.delegate = nil;
    self.myWebView.delegate = self; // setup the delegate as the web view is shown
}

- (void)viewWillDisappear:(BOOL)animated
{
    //[self.myWebView removeFromSuperview];
    [self.myWebView stopLoading];   // in case the web view is still loading its content
    self.myWebView.delegate = nil;  // disconnect the delegate as the webview is hidden
    [UIApplication sharedApplication].networkActivityIndicatorVisible = NO;

}

- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation 
{
    current = interfaceOrientation;
    [self restoreAd];
    return ((interfaceOrientation == UIInterfaceOrientationLandscapeLeft) || (interfaceOrientation == UIDeviceOrientationPortrait) ||
            (interfaceOrientation == UIInterfaceOrientationLandscapeRight));
}

// this helps dismiss the keyboard when the "Done" button is clicked
- (BOOL)textFieldShouldReturn:(UITextField *)textField
{
    [textField resignFirstResponder];
    [self.myWebView loadRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:[textField text]]]];

    return YES;
}


#pragma mark -
#pragma mark UIWebViewDelegate

- (void)webViewDidStartLoad:(UIWebView *)webView
{

    // starting the load, show the activity indicator in the status bar
    [UIApplication sharedApplication].networkActivityIndicatorVisible = YES;
}

- (void)webViewDidFinishLoad:(UIWebView *)webView
{
    // finished loading, hide the activity indicator in the status bar
    [UIApplication sharedApplication].networkActivityIndicatorVisible = NO;

}

- (void)webView:(UIWebView *)webView didFailLoadWithError:(NSError *)error
{

    // load error, hide the activity indicator in the status bar
    [UIApplication sharedApplication].networkActivityIndicatorVisible = NO;

    // report the error inside the webview
    //NSString* errorString = [NSString stringWithFormat:
    //                       @"<html><center><font size=+5 color='red'>An error occurred:<br>%@</font></center></html>",
    //                       error.localizedDescription];
    //[self.myWebView loadHTMLString:errorString baseURL:nil];
    //URLCacheAlertWithError(error);
}

@end
4个回答

4

请按照日志消息中的建议操作:在malloc_error_break处设置断点。当断点触发时,在Xcode中查看回溯(或在gdb命令行上使用bt命令),并查看您调用free或使用free的API的位置。

有时可以使用Xcode静态分析器发现内存使用问题-从Xcode构建菜单中选择“Build and Analyze”。


这是“有时候”这一部分发挥作用的时候。 - user23743
Graham Lee,让我们看一下我的图片。 我也不明白错误的原因。 - RAGOpoR

4

您似乎一直尝试释放指针。在dealloc方法中仅调用[blah release];并在viewDidUnload方法中将指针赋值为nil。不要在两种方法中都这样做。

- (void)dealloc
{
    [self.myWebView release];
    [mybanner release];
    [super dealloc];
}

- (void)viewDidUnload
{
    [super viewDidUnload];
    self.myWebView = nil;

}

您似乎还缺少一些变量。


但是为什么当我旋转设备时它显示错误日志,你能告诉我吗? - RAGOpoR
在清理了dealloc和viewDidUnload方法之后,它是否仍然会这样做? - willcodejavaforfood
是的,我已经清理过了,但当我旋转设备时,它又报告错误了。在模拟器3.1.3和3.2中没有报告任何错误。 - RAGOpoR

1

这似乎完全不相关,但是对于类似的错误,对我有效的方法是修复磁盘权限。

  • 打开磁盘工具应用程序 -> 修复磁盘权限
  • 重新启动计算机

我从 Mac 终端-打开终端时出现“指针被释放未分配”的错误 中得到了这个建议。

此外,我意识到这个问题已经有6年了,所以对原始提问者来说可能没有用。但我希望这个答案能帮助其他遇到类似错误的人。


1

令人惊奇的是,解决我的问题的方法是关闭并重新启动调试设备。哦,苹果...


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接