你好,歡迎來到IOS教程網

 Ios教程網 >> IOS編程開發 >> IOS開發基礎 >> Java轉iOS

Java轉iOS

編輯:IOS開發基礎


What-did-u-learn-today.jpg

目錄
1.UITableView滑動卡頓的優化

2.右滑手勢返回

3.添加頁面統計

4.debug版和release版

5.關於頁面刷新

6.關於頁面布局

7.推薦博客

遇到問題和解決方案

本文是Java轉iOS-第一個項目總結(1)?的內容補充,分析遇到的一些問題和解決方案,分享一些收獲。

1.UITableView滑動卡頓的優化

因為 `UITableView`的cell中有很多圖片,在4/4s上滑動比較卡,最開始覺得是機器太老了,但是對比微信和QQ空間,發現還是我們的問題,所以後期進行了優化,通過xcode的性能監控,內存變化不大,但是cpu飙升的倆厲害,通過xcode的Time Profiler工具進行了監控(Product—Profile—Time Profiler),找到了執行比較慢的方法,原因是轉換圖片路徑的時候,調用自己的方法進行了log打印,造成滑動卡頓。

網上關於UITableView的性能優化的文章有很多,官方給了一個例子LazyTableImages介紹懶加載UITableview的Image,在滑動的時候,不加載圖片,停止滑動時再加載圖片,並把UIImage放在對象中,判斷對象中圖片不會空則顯示圖片,否則還是占位圖。例子中圖片都是app的icon,都是小圖,所以那樣做也沒問題。但是我們項目中的圖片都是大圖片,如果把圖片放在對象中,顯然不合適,所以當時pass了這個方案。

前幾天在Glow 技術團隊博客看到了UIScrollView 實踐經驗 

這篇博客,裡面講到了相同的技術,優化了滑動減速過程中也進行圖片加載,另外用到了SDWebImage,裡面判斷SDWebImage是否緩存過圖片,如果緩存過,從本地加載圖片,否則使用占位圖,應該是比較好的解決方案了

2.右滑手勢返回

iOS7自帶了這個功能,後來設計人員提出了優化建議,但我們的程序卻不能支持這個功能,原因程序返回操作的方法包含其它業務邏輯,比如返回後刷新上一頁面的數據,返回後是否顯示底部菜單。而系統的默認的右滑返回,只是做了頁面返回,並不會觸發自己的返回方法。

所以為了這個功能還是代碼進行了修改,更新上級頁面的操作放在本頁面數據刷新的地方。底部菜單只在首頁的幾個頁面顯示隱藏,其它去掉相關業務邏輯。因為改這個地方還和測試起了沖突,因為項目臨近收尾,修改可能會帶來問題,優化的功能可以放在後期。但是作為開發人員還是進行了修改,加班進行了測試。表面上看這是個優化,其實卻是問題暴漏。如果有新需求的可以不做,但是有問題卻應該盡早解決。

另外這個地方做個內容補充,頁面之間的逆向數據傳遞,可以用回調(block)、委托(delegate)和通知(notifacation),需要熟練掌握這幾個知識點以及實現方法,區分之間的差別。

3.添加頁面統計

友盟統計還是比較強大的,雖然項目沒有要求加相關功能,但是還是加了相關統計,需要在對應ViewController中的viewWillAppear和viewWillDisappear中加入一行代碼,傳入當前頁面的名字,最開始只加了幾個頁面,所以代碼是寫死的。全部頁面要加統計,需要對代碼進行了改進,封裝在自己BaseViewController中

-(void)beginLogPageView
{
    [MobClick beginLogPageView:NSStringFromClass([self class])];
}
-(void)endLogPageView;
{
    [MobClick endLogPageView:NSStringFromClass([self class])];
}

在子頁面中調用統計就比較簡單了

-(void)viewWillAppear:(BOOL)animated{
    [super viewWillAppear:animated];
    //添加頁面統計
    [self beginLogPageView];
}
-(void)viewWillDisappear:(BOOL)animated{
    [super viewWillDisappear:animated];
    //結束頁面統計
    [self endLogPageView];
}

Method Swizzling和 AOP實踐裡面提供了更高大上的解決方案,順便可以學習OC的runtime。 

在Java領域中,Spring框架以IOC和AOP著稱,所以語言和涉及裡面都是想通的。雖然作為io是新手,但是我是懂AOP的_。

4.debug版和release版

之前自己對於debug版和release版沒有太多概念,只是知道平時開發的時候是debug版,當要發布的時候改成release版,看到一些宏定義,根據不同版本設置不同的宏,比如debug版的時候,NSLog可以輸出,release的時候不輸出。

前段時間,看到一篇Xcode宏定義選項以及Release版去NSLog的文章時,就想明白了,在xcode中可以設置宏,debug下有個默認設置 debug=1,所以

#if DEBUG    
#warning NSLogs will be shown
#else
#define NSLog(...) {}
#endif

應該就是判斷這個值 

在之前的JavaWeb項目中,我們會使用Maven進行項目管理,在Maven的pom.xml可以添加profiles,配置不同的版本,比如開發版,測試版,生產版,不同版本下有不同的配置文件,比如數據庫連接,log配置等,打包編譯項目時可以通過Maven選擇不同的版本。這樣的好處是切換版本的時候,不用修改相關帶代碼,避免出現不必要的錯誤。

轉iOS後一直在找相關的解決方案,後來才意識到這個就可以做到,只不過蘋果裡面只有debug版和release版,沒辦法自定義新的版本(或者是我還沒找到,請大神賜教),但是也可以進行相關配置,保證release版的配置都是正確的

另外補充一下,在C/C++中重復引用頭文件會出錯,所以頭文件引用的時候可以使用下面方法,自定義頭文件的引用名,xcode生成頭文件的時候也會默認加上這個

#ifndef xxxx
#define xxxx
#endif

所以就會引起一個疑問,自己平時在程序中如果不是這樣引用頭文件,是否會引起沖突,網上搜索給出答案。oc中不推薦#include引用頭文件,推薦使用#import就是可以解決這個問題的。

5.關於頁面刷新

一個頁面,可能包括下拉刷新,上拉加載更多,翻頁到最後時隱藏刷新,沒網下從緩存中加載數據等多種情況,所以頁面刷新的功能最好提前考慮到,否則這些功能在後期修改時會變得很麻煩,一不小心就容易出問題。比如翻頁到最後隱藏加載更多,然後下拉刷新的時候,可能需要把隱藏的控件給顯示出來。所以代碼要考慮好,設計好,封裝好。

6.關於頁面布局

現在的iOS教程,大部分講得都是故事板,但是在實際項目中,更多的還是用代碼。 

唐巧的博客StoryBoard–看上去很美中說明了原因,公司項目多是協同開發,一旦兩個人同時修改了故事板,基本上都會產生沖突,解決起來會非常麻煩,所以作為新手還是應該多學習純代碼開發。之前項目使用的就是代碼寫UI,獲得屏幕寬高,在不同控件之間算坐標,如果代碼不規范,控件的坐標和寬高是獨立的,如果一個控件發生變化,就會產生雪崩。

這裡推薦Masonry,也是github上非常有名的一個iOS組件,解決了自動布局寫約束麻煩且繁瑣的缺點,比較容易學習和令人接受。iOS還有個VFL語言,相比還是Masonry感覺更好。

這裡再推薦一個iOS組件--ReactiveCocoa,是一個kvo組件,用來做消息監聽,效果就是可以像Java寫事件監聽一樣寫OC代碼 。之前給一個UIButton綁定事件,需要調用addTarget綁定,然後再寫一個方法,或者監聽UITextFiled的變化,都要寫很多委托方法。使用ReactiveCocoa後,寫法就大變了,代碼看起來會整潔很多,而且顯得比較高大上一點。

現在新的項目中,添加使用了上面兩個組件。

7.推薦博客

唐巧的技術博客,最早因為不知道唐巧被同事鄙視了下,從他的博客中可以看到iOS的變化,作者也是從Java轉的iOS,博客也是通俗易懂,現在博主自己創業雖然不寫博客了,但是會發周報分享比較好博文和開源項目。

Glow 技術團隊博客,雖然裡面就幾篇博文,但都比較有用,而且是屬於進階提升型的。

  1. 上一頁:
  2. 下一頁:
蘋果刷機越獄教程| IOS教程問題解答| IOS技巧綜合| IOS7技巧| IOS8教程
Copyright © Ios教程網 All Rights Reserved