Natural

           

          UITableView滾動時crash

          照著網上的教程,吭哧吭哧寫好了一個tableView,Run起來,界面出現了。還來不及高興一下,一滾動,坑爹啊,直接crash掉了,退出。

          打開調試模式,再重現一次,Debugger Console顯示的結果是“Program received signal: "EXC_BAD_ACCESS"”.
          這個結果表示代碼中有數組越界或者哪里內存泄漏了。(網上教程不靠譜啊,完全照著教程敲代碼竟然都錯了)

          還好總共沒幾個方法,多加幾個斷點調試一下。
          問題出來了:當向下滾動,調用cellForRowAtIndexPath消息時,執行到第25行代碼tableData已經被回收了。

          問題分析:
          數組初始化放在viewDidLoad消息中,照著教程敲使用arrayWithObjects來創建。從語法上講,此方法是autorelease的,不需要我們手動去release。
          然而問題也出在這,當向下滾動時,不知為何在viewDidLoad初始化的數組都已經被回收了。

          修正方案:
          把viewDidLoad消息中數組創建方法都改為[[NSArray alloc] initWithObject: ……];方式創建,再在dealloc中釋放掉就OK了。

          推斷總結:
          此代碼的界面是用IB拉出來的,對于新人來說我們并不清楚它的view的創建細節。從執行效果來看,它在創建view時嵌套了個NSAutoreleasePool,向下滾動時已經把pool給release掉了,所以出現crash。

          得到教訓就是:使用IB創建界面時,那些自定義的對象盡量使用alloc/retain/copy方式創建,自己release。把內存管理寄托在自動釋放池中是不靠譜的,除非這個池是你自己創建并釋放的。


          源代碼如下
           1 
           2 - (void)viewDidLoad {
           3     [super viewDidLoad];    
           4     tableData = [NSArray  arrayWithObjects:@"香辣醬香骨",@"肉末燒豆腐",@"芙蓉蝦",@"紅燒帶魚",
           5                  @"粉蒸排骨",@"自來紅月餅",@"蛋黃蓮蓉月餅",@"南瓜奶酪蛋糕",
           6                  @"南瓜沙拉",@"五香毛豆",@"奶油冰淇淋",@"焦糖南瓜冰淇淋",nil];
           7     thumbnails =[NSArray arrayWithObjects:@"a.jpg",@"b.jpg",@"c.jpg",@"d.jpg",@"e.jpg",@"f.jpg",
           8                   @"g.jpg",@"h.jpg",@"i.jpg",@"j.jpg",@"k.jpg",@"l.jpg",nil];
           9     prepTime = [NSArray arrayWithObjects:@"10 min",@"5 min",@"5 min",@"10 min",@"8 min",@"30 min",
          10                   @"30 min",@"45 min",@"20 min",@"5 min",@"50 min",@"40 min",nil];
          11 }
          12 
          13 - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
          14     return [tableData count];
          15 }
          16 
          17 - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
          18     static NSString *simpleTableIdentifier = @"SimpleTableItem";
          19     SimpleTableCell *cell = (SimpleTableCell *)[tableView dequeueReusableCellWithIdentifier:simpleTableIdentifier];
          20     if(cell == nil){
          21         NSArray *nib = [[NSBundle mainBundle] loadNibNamed:@"SimpleTableCell" owner:self options:nil];
          22         cell = [nib objectAtIndex:0];
          23     }
          24     NSUInteger row = [indexPath row];
          25     cell.nameLabel.text = [tableData     objectAtIndex:row];
          26     cell.thumbnailImageView.image = [UIImage imageNamed:[thumbnails objectAtIndex:row]];
          27     cell.prepTimeLabel.text = [prepTime objectAtIndex:row];
          28     return cell;
          29 }
          30 
          31 - (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath {
          32     return 78;
          33 }
          34 
          35 - (void)dealloc {
          36     [super dealloc];
          37 }

          posted on 2012-09-07 11:33 此號已被刪 閱讀(1014) 評論(0)  編輯  收藏 所屬分類: Objective-C


          只有注冊用戶登錄后才能發表評論。


          網站導航:
           

          導航

          統計

          常用鏈接

          留言簿(8)

          隨筆分類(83)

          隨筆檔案(78)

          文章檔案(2)

          相冊

          收藏夾(7)

          最新隨筆

          搜索

          積分與排名

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 随州市| 合阳县| 团风县| 玉屏| 玉树县| 通城县| 昌吉市| 龙里县| 农安县| 上饶县| 汕头市| 光山县| 固始县| 吴川市| 舟曲县| 南部县| 开平市| 永州市| 宜丰县| 吕梁市| 榆中县| 即墨市| 葵青区| 阆中市| 东阿县| 肥乡县| 嘉禾县| 巴林左旗| 彭阳县| 安吉县| 深圳市| 兰坪| 阜阳市| 柳州市| 玛纳斯县| 绍兴市| 南康市| 定安县| 东方市| 佛坪县| 延川县|