Android Afinal使用與總結

Afinal簡介
java

  • Afinal 是一個android的sqlite orm 和 ioc 框架。同時封裝了android中的http框架,使其更加簡單易用;android

  • 使用finalBitmap,無需考慮bitmap在android中加載的時候oom的問題和快速滑動的時候圖片加載位置錯位等問題。git

  • Afinal的宗旨是簡潔,快速。約定大於配置的方式。儘可能一行代碼完成全部事情。github


目前Afinal主要有四大模塊:ajax

FinalDB模塊:android中的orm框架,一行代碼就能夠進行增刪改查。支持一對多,多對一等查詢。
FinalActivity模塊:android中的ioc框架,徹底註解方式就能夠進行UI綁定和事件綁定。無需findViewById和setClickListener等。
FinalHttp模塊:經過httpclient進行封裝http數據請求,支持ajax方式加載。
算法

FinalBitmap模塊:經過FinalBitmap,imageview加載bitmap的時候無需考慮bitmap加載過程當中出現的oom和android容器快速滑動時候出現的圖片錯位等現象。FinalBitmap能夠配置線程加載線程數量,緩存大小,緩存路徑,加載顯示動畫等。FinalBitmap的內存管理使用lru算法,沒有使用弱引用(android2.3之後google已經不建議使用弱引用,android2.3後強行回收軟引用和弱引用,詳情查看android官方文檔),更好的管理bitmap內存。FinalBitmap能夠自定義下載器,用來擴展其餘協議顯示網絡圖片,好比ftp等。同時能夠自定義bitmap顯示器,在imageview顯示圖片的時候播放動畫等(默認是漸變更畫顯示)。sql


Afinal 更多信息能夠參考:https://github.com/yangfuhai/afinal數據庫


這裏我要使用的是它的FinalDB模塊,下面經過一個簡單Demo來展現一下。設計模式

Book實體定義以下:緩存

[java] view plaincopy在CODE上查看代碼片派生到個人代碼片

  1. package com.example.afinaltest.entity;  

  2.   

  3. import net.tsz.afinal.annotation.sqlite.Table;  

  4.   

  5. @Table (name="book")  

  6. public class Book {  

  7.     private int id;  

  8.     private String name;  

  9.     private String isbn;  

  10.     private float price;  

  11.       

  12.     public int getId() {  

  13.         return id;  

  14.     }  

  15.     public void setId(int id) {  

  16.         this.id = id;  

  17.     }  

  18.     public String getName() {  

  19.         return name;  

  20.     }  

  21.     public void setName(String name) {  

  22.         this.name = name;  

  23.     }  

  24.     public String getIsbn() {  

  25.         return isbn;  

  26.     }  

  27.     public void setIsbn(String isbn) {  

  28.         this.isbn = isbn;  

  29.     }  

  30.     public float getPrice() {  

  31.         return price;  

  32.     }  

  33.     public void setPrice(float price) {  

  34.         this.price = price;  

  35.     }  

  36.       

  37.     @Override  

  38.     public String toString() {  

  39.         return "Book [id=" + id + ", name=" + name + ", isbn=" + isbn  

  40.                 + ", price=" + price + "]";  

  41.     }  

  42.       

  43. }  


這個實體類要注意一點就是getter和setter是不能省略的,由於afinal的finalDb最終會調用setter去給實體類的屬性賦值。註解 @Table(name="book")表示咱們但願將Book實體映射到book表中,Book類的屬性會映射成對應表中的字段。


如下類中展現FinalDb的CRUD功能

[java] view plaincopy在CODE上查看代碼片派生到個人代碼片

  1. package com.example.afinaltest;  

  2.   

  3. import java.util.List;  

  4. import com.example.afinaltest.entity.Book;  

  5. import net.tsz.afinal.FinalDb;  

  6. import android.app.Activity;  

  7. import android.os.Bundle;  

  8. import android.view.View;  

  9. import android.view.View.OnClickListener;  

  10. import android.widget.Button;  

  11.   

  12. public class MainActivity extends Activity implements OnClickListener {  

  13.   

  14.     @Override  

  15.     protected void onCreate(Bundle savedInstanceState) {  

  16.         super.onCreate(savedInstanceState);  

  17.         setContentView(R.layout.activity_main);  

  18.           

  19.         findView();  

  20.     }  

  21.   

  22.     private void findView() {  

  23.           

  24.         Button bt_database = (Button) findViewById(R.id.bt_database);  

  25.         Button bt_insert = (Button) findViewById(R.id.bt_insert);  

  26.         Button bt_query = (Button) findViewById(R.id.bt_query);  

  27.         Button bt_update = (Button) findViewById(R.id.bt_update);  

  28.         Button bt_delete = (Button) findViewById(R.id.bt_delete);  

  29.           

  30.         bt_database.setOnClickListener(this);  

  31.         bt_insert.setOnClickListener(this);  

  32.         bt_query.setOnClickListener(this);  

  33.         bt_update.setOnClickListener(this);  

  34.         bt_delete.setOnClickListener(this);  

  35.     }  

  36.   

  37.     @Override  

  38.     public void onClick(View v) {  

  39.           

  40.         FinalDb finalDb = null;  

  41.         switch (v.getId()) {  

  42.         case R.id.bt_database:  

  43.               

  44.             finalDb = FinalDb.create(this"cart"); //建立數據庫  

  45.               

  46.             break;  

  47.         case R.id.bt_insert:  

  48.               

  49.             finalDb = FinalDb.create(this"cart");  

  50.               

  51.             Book book = new Book();//這裏須要注意的是User對象必須有id屬性,或者有經過@ID註解的屬性  

  52.             book.setName("設計模式");  

  53.             book.setIsbn("ISBN1000");  

  54.             book.setPrice(48.9f);  

  55.               

  56.             finalDb.save(book);  

  57.               

  58.             book = new Book();  

  59.             book.setName("大話設計模式");  

  60.             book.setIsbn("ISBN2000");  

  61.             book.setPrice(88.9f);  

  62.               

  63.             finalDb.save(book);  

  64.               

  65.             book = new Book();  

  66.             book.setName("研磨設計模式");  

  67.             book.setIsbn("ISBN3000");  

  68.             book.setPrice(58.9f);  

  69.               

  70.             finalDb.save(book);  

  71.               

  72.             book = new Book();  

  73.             book.setName("深刻Java虛擬機");  

  74.             book.setIsbn("ISBN4000");  

  75.             book.setPrice(78.5f);  

  76.               

  77.             finalDb.save(book);  

  78.               

  79.             break;  

  80.         case R.id.bt_query:  

  81.               

  82.             finalDb = FinalDb.create(this"cart");  

  83.             List<Book> list = finalDb.findAllByWhere(Book.class"name like '%設計模式'");  

  84.               

  85.             for(int i=0;list!=null && i<list.size();i++){  

  86.                 System.out.println(list.get(i));  

  87.             }  

  88.               

  89.             break;  

  90.               

  91.         case R.id.bt_update:  

  92.               

  93.             finalDb = FinalDb.create(this"cart");  

  94.               

  95.             Book entity = new Book();  

  96.             entity.setName("設計模式");  

  97.             entity.setIsbn("ISBN1000");  

  98.             entity.setPrice(108.9f);  

  99.               

  100. //          finalDb.update(entity);  

  101.             finalDb.update(entity, "name like '%設計模式'");  

  102.             break;  

  103.               

  104.         case R.id.bt_delete:  

  105.               

  106.             finalDb = FinalDb.create(this"cart");  

  107.               

  108. //          finalDb.delete(entity);  

  109.             finalDb.deleteById(Book.class1);  

  110. //          finalDb.deleteByWhere(Book.class, "name like '%設計模式'");  

  111.               

  112.             break;  

  113.         default:  

  114.             break;  

  115.         }  

  116.     }  

  117.   

  118. }  



FinalDB優勢
android中的orm框架,一行代碼就能夠進行增刪改查。支持一對多,多對一等查詢。


FinalDb的缺點

目前暫時不支持複合主鍵,而且對SQL語句的支持也很是有限,一些比較複雜的業務邏輯實現很是麻煩!



推薦github上一個開源項目 xUtils,它基於Afinal框架,進行了大量重構,使得xUtils支持大文件上傳,更全面的http請求協議支持(10種謂詞),擁有更加靈活的ORM,更多的事件註解支持且不受混淆影響

xUtilshttps://github.com/wyouflf/xUtils