項目中用到的那些方便流行的庫-強烈推薦

簡介

  • 本文主要對咱們項目中的使用過的一些庫流行庫作些介紹,後期再對其中的一些庫,如RxJava,RxAndroid,retrofit ,androidannotations,react-native,作細節的分析,到時候再附上使用的demo。html

  • 本文中提到的庫,都是目前流行的,並且使用量比較大,是很是好用的庫,強烈推薦~java

Rx系列

  • ReactiveX是ReactiveExtensions的縮寫,簡寫爲Rx,Rx是一個編程模型,目標是提供一致的編程接口,幫助開發者更方便的處理異步數據流,Rx庫支持 .NET、JavaScript和C++,java,RxJava就是對java語言的支持。

RxJava:

  • 觀察者模式、響應式編程、函數式風格、簡化代碼,更輕鬆的使用併發,開發必備神器~~~react

  • github源碼android

  • 官方文檔
  • Rxjava文檔中文版
  • rxjava使用
  • Awesome-RxJava :關於rxjava相關內容集錦
  • 給 Android 開發者的 RxJava 詳解
  • rxjava相關git

  • android studio中引入,build.grade的dependencies中引用舉例:github

  • 1 dependencies {
    2       compile 'io.reactivex:rxjava:1.0.y-SNAPSHOT'
    3   }

    RxAndroid:

    • 在RxJava的基礎上擴展了一些Android的功能
    • 除了下面提到的RxBinding,RxLifecycle,還有不少別的擴展庫,有興趣的小夥伴能夠本身看看, wiki 裏面都有
    • github源碼
    • wiki :裏面介紹了不少其餘Android的基於rx的庫
    • 使用demo
    • 簡單示例:web

    •  1 Observable.create(new Observable.OnSubscribe<ArrayList<MyItem>>() {
       2 
       3               @Override
       4               public void call(Subscriber<? super ArrayList<MyItem>> subscriber) {
       5                   //通常爲耗時操做,網絡獲取數據或者讀取數據庫等
       6                   ArrayList<MyItem> localData = MyDbManager.getDbDatas();
       7                   subscriber.onNext(localData); //數據獲取以後,返回獲取的數據
       8                   subscriber.onCompleted();
       9               }
      10           })
      11                   .subscribeOn(Schedulers.io()) //獲取數據在io線程中
      12                   .observeOn(AndroidSchedulers.mainThread()) //獲得數據以後,在主線程更新界面和數據
      13                   .subscribe(new Observer<ArrayList<MyItem>>() {
      14                       @Override
      15                       public void onCompleted() {
      16 
      17                       }
      18 
      19                       @Override
      20                       public void onError(Throwable e) {
      21 
      22                       }
      23 
      24                       @Override
      25                       public void onNext(ArrayList<MyItem> items) {
      26                           //獲得數據,do something
      27                       }
      28                   });

      RxBinding:數據庫

      • Android控件的事件綁定,處理控件的異步調用,使用很是方便
      • github源碼
      • 簡單示例:
      • //防止多擊,500ms內算一次點擊
          RxView.clicks(view)
              .throttleFirst(500, TimeUnit.MILLISECONDS)
              .subscribe(new Action1<Void>() {
                  @Override
                  public void call(Void aVoid) {
                      //點擊事件處理
                  }
              });

        RxLifecycle:編程

        • 綁定生命,例如,使用Retrofit請求網絡的時候,能夠直接綁定生命週期,在界面退出時,取消請求。
        • github源碼
        • 簡單示例
        • 1 //僞代碼
          2   Observable.compose(this.<MyData>bindToLifecycle()) //activity中
          3   Observable..compose(this.<MyData>bindUntilEvent(FragmentEvent.DETACH)) //Fragment中

          網絡系列

          網絡請求比較流行的幾個開源庫,咱們項目中基本都用上了,此處作一些簡單介紹。我的最喜歡retrofit,結合Rxjava,RxAndroid簡直完美~windows

          okhttp:

          retrofit:

          • Retrofit與okhttp共同出自於 Square ,retrofit對okhttp作了一層封裝,真正的網絡請求,默認使用的是okhttp。結合RxJava,RxAndroid,代碼清晰明瞭.
          • github源碼
          • 官網
          • wiki

          volley:

          • 2013年Google I/O大會上推出了一個網絡通訊框架—— Volley.
          • 公司有一個項目中用的是這個網絡請求框架,不過發現一個bug,退出activity時取消網絡請求,下次進入,可能會出現本次請求沒有走success和failure的回調,是由於以前的cancel引發的bug,不知道如今有沒有解決這個bug.
          • 源碼
          • 下載源碼:
          • 1 git clone https://android.googlesource.com/platform/frameworks/volley

            圖片系列

            • 圖片加載這塊,無論使用哪一個庫或者本身寫,用起來多簡單,都建議多一次封裝,寫個ImageUtils,將全部的圖片加載放在這裏面,這樣之後若是有問題,或者須要替換別的圖片庫,會方便不少,代碼也更易管理。

            Picasso

            • 一樣是square門下的,是較輕量級圖片緩存庫,自己沒有作本地緩存,交給了網絡庫 okhttp 去實現。簡單好用~
            • github源碼
            • 官網
            • 簡單示例
            • 1 Picasso.with(context).load(uri).placeholder(R.drawable.placeholder).into(view);

              glide

              • 不只支持圖片緩存,還支持 Gif、WebP、縮略圖、視頻。
              • github源碼
              • wiki
              • 簡單示例
              • 1 Glide.with(context).load(uri).placeholder(R.drawable.placeholder).into(view);

                fresco

                其餘

                react-native

                LeakCanary

                • 有時候OOM只是表象,更深層次的緣由多是內存泄漏,什麼是內存泄漏?直白點說就是該內存空間使用完以後沒有被回收,內存泄漏嚴重會致使內存很快被耗盡,從而致使OOM,最後程序crash~~~
                • LeakCanary能夠檢測內存泄漏,讓內存泄漏無所遁形。使用後,在debug模式下,若是出現內存泄漏,則會彈出通知,告訴你哪裏出現了泄漏,很是好用~
                • github源碼
                • LeakCanary使用說明
                • LeakCanary中文使用說明
                • build.gradle 中加入引用,不一樣的編譯使用不一樣的引用.目前已經到1.4版本了,具體見 github
                • 1 dependencies {
                  2       debugCompile 'com.squareup.leakcanary:leakcanary-android:1.3.1'
                  3       forTestCompile 'com.squareup.leakcanary:leakcanary-android:1.3.1'
                  4       releaseCompile 'com.squareup.leakcanary:leakcanary-android-no-op:1.3.1'
                  5   }

                  簡單示例:

                •  1 public class MyApplication extends MultiDexApplication {
                   2 
                   3       private RefWatcher mRefWatcher;
                   4 
                   5       @Override
                   6       public void onCreate() {
                   7           super.onCreate();
                   8            // init memory leak detection
                   9           mRefWatcher = LeakCanary.install(this);
                  10       }
                  11 
                  12       public static RefWatcher getRefWatcher(Context context) {
                  13           MyApplication application = (MyApplication) context.getApplicationContext();
                  14           return application.mRefWatcher;
                  15       }
                  16   }
                  17 
                  18   //監控你想要監控的對象。以此爲例:
                  19   public class BaseFragment extends RxFragment {
                  20       @Override
                  21       public void onDestroy() {
                  22           super.onDestroy();
                  23           if (getActivity() != null) {
                  24               RefWatcher refWatcher = ZYApplication.getRefWatcher(getActivity());
                  25               refWatcher.watch(this);
                  26           }
                  27       }
                  28   }

                  EventBus

                  • EventBus用於發佈/訂閱事件。能夠替代Intent,Handler,BroadCast在Activity,Fragment,線程等之間的消息傳遞.代碼簡潔優雅,將發送者和接收者解耦。例如:登陸功能,登陸成功以後發送一個消息,須要刷新或關閉的界面,接受這個消息,作本身想作的事情~
                  • github源碼
                  • 簡單示例:

                     1 public class AccountEvent {
                     2       private User user;//你想要傳遞的數據
                     3       public AccountEvent(User user) {
                     4           this.user = user;
                     5       }
                     6 
                     7       public User getUser() {
                     8           return user;
                     9       }
                    10 
                    11       public void setUser(User user) {
                    12           this.user = user;
                    13       }
                    14   }
                    15 
                    16   public class LoginActivity {
                    17       public loginSuccess(User user) {
                    18           EventBus.getDefault().post(new AccountEvent(user));//發消息
                    19       }
                    20   }
                    21 
                    22   public class MyFragment{
                    23       @Override
                    24       public void onCreate(Bundle savedInstanceState) {
                    25           super.onCreate(savedInstanceState);
                    26           EventBus.getDefault().register(this);
                    27       }
                    28 
                    29       @Override
                    30       public void onDestroy() {
                    31           super.onDestroy();
                    32           EventBus.getDefault().unregister(this);
                    33       }
                    34 
                    35       public void onEvent(AccountEvent event) {//接受消息
                    36           //do something 
                    37       }
                    38   }

                    androidannotations

                    • 註解,一方面能夠減小代碼量,不再用findViewById了,另外一方面,代碼清晰明瞭,優雅的不得了啊,哈哈~
                    • 經常使用的比較好的註解庫有兩個,一個是androidannotations,另外一個是 butterknife,butterknife很火,是JakeWharton大神的做品,火是必須的~
                    • 可是咱們的項目中用的是androidannotations,由於androidannotations不是利用的反射技術,性能相對好點,它是在本地自動生成一個新的類(如你在MyActivity中使用了註解,則它會自動生成一個MyActivity_ 類),真正執行的是它自動生成的這個類,並且在manifest中須要註冊的也是此MyActivity_,而不是MyActivity,你也能夠打開這個類,看看裏面的實現,有bug也比較好解決。
                    • 官網
                    • github源碼
                    • wiki :androidannotations的wiki很是詳細,有問題的小夥伴們,能夠好好地看看這個。
                    • 簡單示例

                       1 @EActivity(R.layout.activity_my)
                       2   public class MyActivity extends BaseActivity {
                       3       @StringRes(R.string.my_string)
                       4       String mMyString;
                       5 
                       6       @ViewById(R.id.tv)
                       7       TextView mTV;
                       8 
                       9       @Extra()
                      10       int mCount;
                      11 
                      12       @Pref
                      13       UserPreference_ mUserPreference;
                      14 
                      15       @AfterViews
                      16       void initialize() {
                      17       //初始化數據
                      18       }
                      19 
                      20       @Click(R.id.finish_iv)
                      21       void finish() {
                      22           //do something
                      23       }
                      24 
                      25       public void loginSuccess(){
                      26           mUserPreference.edit().hasLogin().put(true).apply();
                      27       }
                      28   }
                      29 
                      30   @SharedPref(value = SharedPref.Scope.UNIQUE) //做用域:整個應用均可以使用
                      31   public interface UserPreference {
                      32       @DefaultBoolean(false)
                      33       boolean hasLogin();
                      34   }

                       

  • 來自:http://www.jianshu.com/p/6db1a5e84d67
相關文章
相關標籤/搜索