iPhone应用程序中令人困惑的双重免费错误消息/内存泄漏 [英] Confusing double free error message/memory leak in iPhone app

查看:101
本文介绍了iPhone应用程序中令人困惑的双重免费错误消息/内存泄漏的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

编辑-添加了.h文件

我很难找到导致双重释放错误的原因.

I'm having difficulty trying to find the cause of a double free error.

为解决问题而采取的步骤

Steps taken to solve

1)使用了僵尸工具.僵尸报告tid正在被双重释放

1) Used the Zombies tool. Zombies reports that tid is being double freed

2)在malloc_error_break上设置一个断点.这将以下代码段标识为错误的:

2) Set a breakpoint on malloc_error_break. This identifitied the following code segment as faulty:

 - (void)viewWillDisappear:(BOOL)animated
    {
        [super viewWillDisappear:animated];

        [connection release];

        [ldestination release];
        [ldeparts_from release];
        [ltime release];
        [lcs_id release]; /// It breaks here


        [carsharexml release];
    }

3)我浏览了一下代码,以查看以前在哪里找到[lcs_id release]-什么也没发现.

3) I looked through the code to see where I had [lcs_id release] before - I found nothing.

4)为了解决这个问题,我不顾一切地将[lcs_id release]注释掉.这停止了 double free错误消息,但是当我通过泄漏运行它时,它说这是导致内存泄漏的原因.

4) In a desperate attempt to solve it I commented out [lcs_id release]. This stopped the double free error messages but when I ran it through leaks it said that this was causing memory leaks.

我在做什么错了?

非常感谢.

下面是代码的完整副本:

Below is a complete copy of the code:

#import <UIKit/UIKit.h>
#import "MyManager.h"

@interface ListOfCarShares : UITableViewController <NSXMLParserDelegate>
{
    NSURLConnection *connection;
    NSMutableData *carsharexml;
    NSMutableArray *ldestination;
    NSMutableArray *ldeparts_from;
    NSMutableArray *lcs_id;
    NSMutableArray *ltime;
    NSMutableString *currentElement;

    NSMutableString *tdest;
    NSMutableString *tfrom;
    NSMutableString *ttime;
    NSMutableString *tid;



}

-(void)fetchcarshares;

@property (nonatomic, assign) IBOutlet UITableViewCell *maincell;


@end


//
//  ListOfCarShares.m
//  Warwick_Culture
//
//  Created by Me on 26/10/2011.
//  Copyright 2011 __MyCompanyName__. All rights reserved.
//

#import "ListOfCarShares.h"

@implementation ListOfCarShares

@synthesize maincell;

- (id)initWithStyle:(UITableViewStyle)style
{
    self = [super initWithStyle:style];
    if (self) {
        // Custom initialization
    }
    return self;
}



- (void)parser:(NSXMLParser *)parser
didStartElement:(NSString *)elementName
  namespaceURI:(NSString *)namespaceURI
 qualifiedName:(NSString *)qualifiedName
    attributes:(NSDictionary *)attributeDict
{
    currentElement = [[elementName copy] autorelease];
    if ([elementName isEqualToString:@"destination"]) 
    {

        //NSLog(@"found current conditions tag it reads %@",currentElement);
        tdest = [[NSMutableString alloc] init];
    }

    if ([elementName isEqualToString:@"departs_from"])
    {
        tfrom = [[NSMutableString alloc] init]; 
    }


    if ([elementName isEqualToString:@"time"])
    {
        ttime = [[NSMutableString alloc] init]; 
    }

    if ([elementName isEqualToString:@"cs_id"])
    {
        tid = [[NSMutableString alloc] init]; 
    }



}




- (void)parser:(NSXMLParser *)parser foundCharacters:(NSString *)string
{

    if ([currentElement isEqualToString:@"destination"])
    {

        [tdest appendString:string];
    }

    if ([currentElement isEqualToString:@"departs_from"])
    {

        [tfrom appendString:string];
    }

    if ([currentElement isEqualToString:@"time"])
    {

        [ttime appendString:string];
    }

    if ([currentElement isEqualToString:@"cs_id"])
    {

        [tid appendString:string];
    }

}

- (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName 
  namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName
{

    if ([currentElement isEqualToString:@"destination"])
    {

        [ldestination addObject:tdest];
        [tdest release];

    }

    if ([currentElement isEqualToString:@"departs_from"])
    {

        [ldeparts_from addObject:tfrom];
        [tfrom release];
    }

    if ([currentElement isEqualToString:@"time"])
    {

        [ltime addObject:ttime];
        [ttime release];
    }

    if ([currentElement isEqualToString:@"cs_id"])
    {

        [lcs_id addObject:tid];
        [tid release];
    }



}





- (void)didReceiveMemoryWarning
{

    [super didReceiveMemoryWarning];


}

#pragma mark - View lifecycle

- (void)viewDidLoad
{
    [super viewDidLoad];

    // Uncomment the following line to preserve selection between presentations.
    // self.clearsSelectionOnViewWillAppear = NO;

    // Uncomment the following line to display an Edit button in the navigation bar for this view controller.
    // self.navigationItem.rightBarButtonItem = self.editButtonItem;
}

- (void)viewDidUnload
{
    [super viewDidUnload];

}

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

    ldestination = [[NSMutableArray alloc] init];

    ldeparts_from = [[NSMutableArray alloc] init];
    ltime = [[NSMutableArray alloc] init];
    lcs_id = [[NSMutableArray alloc] init];
    carsharexml = [[NSMutableData alloc] init];

    [self fetchcarshares];
}

- (void)viewDidAppear:(BOOL)animated
{
    [super viewDidAppear:animated];
}

- (void)viewWillDisappear:(BOOL)animated
{
    [super viewWillDisappear:animated];

    [connection release];

    [ldestination release];
    [ldeparts_from release];
    [ltime release];
    [lcs_id release]; ///


    [carsharexml release];
}

- (void)viewDidDisappear:(BOOL)animated
{
    [super viewDidDisappear:animated];


}

- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation
{
    // Return YES for supported orientations
    return (interfaceOrientation == UIInterfaceOrientationPortrait);
}

#pragma mark - Table view data source

- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
{

    // Return the number of sections.
    return 1;
}

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
    // Return the number of rows in the section.
    return [ltime count];
}

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    //static NSString *CellIdentifier = @"Cell";

    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:nil];
    if (cell == nil) 
    {
        [[NSBundle mainBundle] loadNibNamed:@"carsharecell" owner:self options:nil];

    }

    // Configure the cell...
    cell=maincell;

    UILabel *from;
    UILabel *dest;
    UILabel *time;

    from = (UILabel *)[cell viewWithTag:4];
    dest = (UILabel *)[cell viewWithTag:5];
    time = (UILabel *)[cell viewWithTag:6];


    from.text=[ldeparts_from objectAtIndex:indexPath.row];
    dest.text=[ldestination objectAtIndex:indexPath.row];
    time.text=[ltime objectAtIndex:indexPath.row];


    return cell;
}

/*
// Override to support conditional editing of the table view.
- (BOOL)tableView:(UITableView *)tableView canEditRowAtIndexPath:(NSIndexPath *)indexPath
{
    // Return NO if you do not want the specified item to be editable.
    return YES;
}
*/

/*
// Override to support editing the table view.
- (void)tableView:(UITableView *)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath *)indexPath
{
    if (editingStyle == UITableViewCellEditingStyleDelete) {
        // Delete the row from the data source
        [tableView deleteRowsAtIndexPaths:[NSArray arrayWithObject:indexPath] withRowAnimation:UITableViewRowAnimationFade];
    }   
    else if (editingStyle == UITableViewCellEditingStyleInsert) {
        // Create a new instance of the appropriate class, insert it into the array, and add a new row to the table view
    }   
}
*/

/*
// Override to support rearranging the table view.
- (void)tableView:(UITableView *)tableView moveRowAtIndexPath:(NSIndexPath *)fromIndexPath toIndexPath:(NSIndexPath *)toIndexPath
{
}
*/

/*
// Override to support conditional rearranging of the table view.
- (BOOL)tableView:(UITableView *)tableView canMoveRowAtIndexPath:(NSIndexPath *)indexPath
{
    // Return NO if you do not want the item to be re-orderable.
    return YES;
}
*/

-(void)fetchcarshares
{

    MyManager *sharedManager = [MyManager sharedManager];




    NSString *urlString = [NSString stringWithFormat:@"http://url/get.php?username=%@&password=%@",sharedManager.user,sharedManager.passw];

    NSURL *url = [NSURL URLWithString:urlString];
    NSURLRequest *req = [NSURLRequest requestWithURL:url];

    connection = [[NSURLConnection alloc] initWithRequest:req delegate:self startImmediately:YES];


}

-(void) connection:(NSURLConnection *)conn didReceiveData:(NSData *)data
{
    [carsharexml appendData:data];
}


-(void) connectionDidFinishLoading:(NSURLConnection *)conn
{
    NSString *xmlcheck = [[NSString alloc] initWithData:carsharexml encoding:NSUTF8StringEncoding];

    NSLog(@"%@",xmlcheck);

    [xmlcheck release];






    NSXMLParser *parser = [[NSXMLParser alloc] initWithData: carsharexml];

    [parser setDelegate:self];

    [parser parse];

    [parser release];








    [[self tableView] reloadData];




}

-(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
    return 102;
}



#pragma mark - Table view delegate

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{

}

-(void)dealloc
{
    [super dealloc]; 
}

@end

推荐答案

尝试一下....

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

    ldestination = [[[NSMutableArray alloc] init]retain];

    ldeparts_from = [[[NSMutableArray alloc] init]retain];
    ltime = [[[NSMutableArray alloc] init]retain];
    lcs_id = [[[NSMutableArray alloc] init]retain];
    carsharexml = [[[NSMutableData alloc] init]retain];

    [self fetchcarshares];
 }

这篇关于iPhone应用程序中令人困惑的双重免费错误消息/内存泄漏的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆