2011-02-25 64 views
-1

我只需要確認我正在做XML解析權。我在這裏做錯了什麼:XML解析NSXMLParser - 我需要代碼審查

@interface RootViewController : UITableViewController <NSXMLParserDelegate> 
{ 
    NSXMLParser *parser;  
    NSMutableArray *ordersList; 

    BOOL orderIdFound; 
    BOOL itemNameFound; 
    BOOL priceFound; 
    BOOL orderDateFound; 
    BOOL deliveryDateFound; 

    Order *orderObject; 
} 

@property (nonatomic, retain) NSMutableArray *ordersList; 
@property (nonatomic, retain) NSXMLParser *parser; 
@property (nonatomic, retain) Order *orderObject; 

@end 


@implementation RootViewController 

@synthesize ordersList; 
@synthesize parser; 
@synthesize orderObject; 

- (void)viewDidLoad 
{ 
    [super viewDidLoad]; 

    ordersList = [[NSMutableArray alloc]init]; 

    // Reading local XML file 
    NSString *xmlFilePath = [[NSBundle mainBundle] pathForResource:@"orders" ofType:@"xml"]; 

    NSData *data = [[NSData alloc]initWithContentsOfFile:xmlFilePath]; 
    parser = [[NSXMLParser alloc]initWithData:data]; 
    parser.delegate = self; 
    [parser setShouldResolveExternalEntities:YES]; 
    [parser parse]; 
} 

- (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qualifiedName attributes:(NSDictionary *)attributeDict 
{  
    if ([elementName isEqualToString:@"OrderId"]) 
    {   
     orderIdFound = YES; 
     if(orderObject == nil) 
     { 
      orderObject = [[Order alloc]init]; 
     } 
     else 
     { 
      [ordersList addObject:orderObject]; 

      [orderObject release]; 
      orderObject = nil; 
      orderObject = [[Order alloc]init]; 
     } 
    } 
    if ([elementName isEqualToString:@"ItemName"]) 
    { 
     itemNameFound = YES; 
    } 
    if ([elementName isEqualToString:@"Price"]) 
    { 
     priceFound = YES; 
    } 
    if ([elementName isEqualToString:@"OrderDate"]) 
    { 
     orderDateFound = YES; 
    } 
    if ([elementName isEqualToString:@"DeliveryDate"]) 
    { 
     deliveryDateFound = YES; 
    } 
} 

- (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName 
{  
    if([elementName isEqualToString:@"OrderId"]) 
    { 
     orderIdFound = NO;  
    } 
    if([elementName isEqualToString:@"ItemName"]) 
    { 
     itemNameFound = NO;  
    } 
    if([elementName isEqualToString:@"Price"]) 
    { 
     priceFound = NO;   
    } 
    if([elementName isEqualToString:@"OrderDate"]) 
    { 
     orderDateFound = NO;   
    } 
    if([elementName isEqualToString:@"DeliveryDate"]) 
    { 
     deliveryDateFound = NO; 
    } 
} 

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

    if(orderIdFound == YES) 
    { 
     orderObject.OrderId = [string integerValue]; 
     NSLog(@"orderId :: %i", orderObject.OrderId); 

    } 
    if(itemNameFound == YES) 
    {  
     orderObject.ItemName = string; 
     NSLog(@"itemName :: %@", orderObject.ItemName); 
    } 
    if(priceFound == YES) 
    {  
     orderObject.Price = [string integerValue]; 
     NSLog(@"price :: %i", orderObject.Price); 
    } 
    if(orderDateFound == YES) 
    {  
     orderObject.OrderDate = string; 
     NSLog(@"orderDate :: %@", orderObject.OrderDate); 
    } 
    if(deliveryDateFound == YES) 
    {  
     orderObject.DeliveryDate = string; 
     NSLog(@"deliveryDate :: %@", orderObject.DeliveryDate); 
    } 
} 
+0

當你運行代碼時你有問題嗎?它似乎工作? – occulus 2011-02-25 09:37:12

回答

2

它看起來總體上沒問題,只是你正在泄漏內存。任何分配,新增,複製或保留的調用都需要與一個版本(例如dealloc)進行平衡。

另外,我建議不要在視圖控制器中進行XML解析。 XML解析是一個單獨的問題,適合於分解爲單獨的類。

+1

你忘記了保留需要釋放的呼叫了。 – Jasarien 2011-02-25 09:43:54

+0

謝謝,更正。 – occulus 2011-02-25 09:46:32

+0

謝謝,我將在dealloc中釋放解析器和其他對象。一般我是這個代碼最關注的「如果(orderObject ==無) { orderObject = [訂單分配]初始化];} 其他 { [ordersList ADDOBJECT:orderObject]; [orderObject發佈]; orderObject = nil; orderObject = [[Order alloc] init]; }「 我將把這個移動到單獨的類:)謝謝 – 1110 2011-02-25 09:48:33