a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 系統 > Android > 正文

解析activity之間數據傳遞方法的詳解

2020-04-11 12:21:21
字體:
來源:轉載
供稿:網友
1  基于消息的通信機制 Intent--------boudle,extra
用這種簡單的形式,一般而言傳遞一些簡單的類型是比較容易的,如int、string等
詳細介紹下Intent機制
Intent包含兩部分:
1 目的【action】-------要去到哪里去
2 內容【category、data】----------路上帶些什么,區分性數據和內容性數據
簡單數據傳遞:
復制代碼 代碼如下:

Intent intent = new Intent(LoginActivity.this, MainActivity.class);
intent.putExtra("flag", flag);
startActivity(intent);
/////////////////////////////////////////////////////////
String flag = "   ";
Intent intent1 = this.getIntent(); 
flag = intent1.getStringExtra("flag");
/////////////////////////////////////////////////////////

數據類型有限,遇到不可序列化的數據Bitmap,Inputstream,或者是LinkList鏈表等數據類型就不太好用了
2 利用static靜態數據,public static成員變量
我們千萬不要以為Davlik虛擬機的垃圾回收器會幫助我們回收不需要的內存垃圾。事實上,回收器并不可靠,
尤其是手機上,是更加的不可靠。 因此,除非我們要使自己的程序變得越來越糟糕,否則盡量遠離static。
注:如果經常使用static的Bitmap、Drawable等變量。可能就會拋出一個在Android系統中非常著名的異常(
以前budget這個單詞一直記不住什么意思,自從經常拋出這個異常后,這個單詞終于爛熟于心了,)
ERROR/AndroidRuntime(4958): Caused by: java.lang.OutOfMemoryError: bitmap size exceeds VM budget
注:如果經常使用static的Bitmap、Drawable等變量。可能就會拋出一個在Android系統中非常著名的異常(
以前budget這個單詞一直記不住什么意思,自從經常拋出這個異常后,這個單詞終于爛熟于心了,)
3 基于外部存儲的傳輸 ,File/Preference/Sqlite,如果要針對第三方應用需要Content provider
作為一個完成的應用程序,數據存儲操作是必不可少的。因此,Android系統一共提供了四種數據存儲方式。
分別是:SharePreference、SQLite、Content Provider和File。由于Android系統中,數據基本都是私有的的
,都是存放于“data/data/程序包名”目錄下,所以要實現數據共享,正確方式是使用Content Provider。
SQLite: SQLite是一個輕量級的數據庫,支持基本SQL語法,是常被采用的一種數據存儲方式。Android
為此數據庫提供了一個名為SQLiteDatabase的類,封裝了一些操作數據庫的API。
SharedPreference: 除SQLite數據庫外,另一種常用的數據存儲方式,其本質就是一個xml文件,常用于
存儲較簡單的參數設置。
File: 即常說的文件(I/O)存儲方法,常用語存儲大數量的數據,但是缺點是更新數據將是一件困難的
事情。
ContentProvider: ContentProvider是安卓平臺中,在不同應用程序之間實現數據共享的一種機制。一個
應用程序如果需要讓別的程序可以操作自己的數據,即可采用這種機制。并且此種方式忽略了底層的數據存儲
實現,ContentProvider提供了一種統一的通過Uri實現數據操作的方式。
詳細介紹使用過程
File 通過文件內容的讀取傳遞數據
Preference: SharedPreferences也是一種輕型的數據存儲方式,它的本質是基于XML文件存儲key-value鍵值
對數據,通常用來存儲一些簡單的配置信息
SharedPreferences對象本身只能獲取數據而不支持存儲和修改,存儲修改是通過Editor對象實現。實現
SharedPreferences存儲的步驟如下:
一、根據Context獲取SharedPreferences對象
二、利用edit()方法獲取Editor對象。
三、通過Editor對象存儲key-value鍵值對數據。
四、通過commit()方法提交數據。
復制代碼 代碼如下:

   SharedPreferences sp=getSharedPreferences("login",0);//login存儲文件名
   SharedPreferences.Editor se=sp.edit();;
   se.putString("server", logEdit.getText().toString());
   se.putString("port", portEdit.getText().toString());
   se.commit();
/////////////////////////////////////////////////////////////
  SharedPreferences ps=getSharedPreferences("login",0);//login是存儲文件 
  server=ps.getString("server", "");
  port=ps.getString("port", "");

  logEdit.setText(server);
  portEdit.setText(port);
/////////////////////////////////////////////////////////////
ContentProvider

其步驟為:
1. 在當前應用程序中定義一個ContentProvider。
2. 在當前應用程序的AndroidManifest.xml中注冊此ContentProvider
3. 其他應用程序通過ContentResolver和Uri來獲取此ContentProvider的數據。
在程序A中,繼承ContProvider類,并重寫其中的方法
復制代碼 代碼如下:

public class MyProvider extends ContentProvider{
     @Override
     public int delete(Uri uri, String selection, String[] selectionArgs) {
         // TODO Auto-generated method stub
         return 0;
     }

     @Override
     public String getType(Uri uri) {
         // TODO Auto-generated method stub
         return null;
     }

     @Override
     public Uri insert(Uri uri, ContentValues values) {
         return null;
     }

     //在Create中初始化一個數據庫
     @Override
     public boolean onCreate() {
         SQLiteDatabase db = this.getContext().openOrCreateDatabase("test_db.db3",
Context.MODE_PRIVATE, null);
         db.execSQL("create table tab(_id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT NOT
NULL)");
         ContentValues values = new ContentValues();
         values.put("name", "test");
         db.insert("tab", "_id", values);
         db.close();
         return true;
     }

     //實現query方法
     @Override
     public Cursor query(Uri uri, String[] projection, String selection,
             String[] selectionArgs, String sortOrder) {
         SQLiteDatabase db = this.getContext().openOrCreateDatabase("test_db.db3",
Context.MODE_PRIVATE, null);
         Cursor c = db.query("tab", null, null, null, null, null,null);
         return c;
     }

     @Override
     public int update(Uri uri, ContentValues values, String selection,
             String[] selectionArgs) {
         // TODO Auto-generated method stub
         return 0;
     }
 }

 在其AndroidManifest.xml中聲明此ContentProvider,其中authorities屬性定義了此ContentProvider的Uri
標識。
<provider android:name=".MyProvider" android:authorities="com.test.MyProvider"/>
在應用程序B中,通過ContentResolver獲取程序A的ContentProvider中的數據。
復制代碼 代碼如下:

public class MainActivity extends Activity {
     @Override
     public void onCreate(Bundle savedInstanceState) {
         super.onCreate(savedInstanceState);
         setContentView(R.layout.main);

         //獲取上下文
         Context ctx = MainActivity.this;
         //獲取ContentResolver對象
         ContentResolver resolver = ctx.getContentResolver();
         //獲取Uri對象
         Uri uri = Uri.parse("content://com.test.MyProvider");
         //獲取數據
         Cursor c = resolver.query(uri, null, null, null, null);
         c.moveToFirst();
         for(int i=0; i<c.getCount(); i++){
             int index = c.getColumnIndexOrThrow("name");
             String src = c.getString(index);
             Log.d("", src);
             c.moveToNext();
         }
     }
 }

再觀察兩個應用程序的結構,A的程序結構,可以清楚看到其有一個名為“test_db.db3”的數據庫,B的程序結構,其并沒有任何數據庫用于存儲數據。由此圖,可以確定應用程序B中查詢出來的數據結果是來自于應用程序A。
以上就是ContentProvider的使用方式,這種存儲方式相比SQLite和SharedPreferences,其復雜性是顯而易見的,但是在處處可見“云”的今天,程序間的數據交互需求令ContentProvider存儲機制變成必不可少的一部分。
4 基于Ipc的通信機制
context與service之間的傳輸,如Activity與Service之間的通信
5 基于Application  Context
在一個activity初始化一個ArrayList<HashMap<Sting,Map>>對象,然后經過一個tableactivity,在傳遞到另
外一個activity,一開始直接考慮用putExtra,測試發現數據只能傳遞一次,就考慮用Application傳遞
Java里面通常是用一個static的變量(例如singleton之類的)來同步activity之間(程序里面類之間)的狀態。在android里面比較靠譜的做法是用application context來關聯這些狀態。
每個activity都是context,里面包含了運行時的狀態。同樣application也有一個context,android會保證這個context是唯一的實例。
復制代碼 代碼如下:

package net.blogjava.mobile1;
import android.app.Application;
import android.graphics.Bitmap;
public class MyApp extends Application
{
    private Bitmap mBitmap;
    public Bitmap getBitmap()
    {
        return mBitmap;
    }
    public void setBitmap(Bitmap bitmap)
    {
        this.mBitmap = bitmap;
    }

}
<application android:name=".MyApp" android:icon="@drawable/icon" android:label="@string/app_name">
</application>

獲得Bitmap對象的代碼:
復制代碼 代碼如下:

    ImageView imageview = (ImageView)findViewById(R.id.ivImageView);

    MyApp myApp = (MyApp)getApplication();

    imageview.setImageBitmap(myApp.getBitmap());

上面兩段代碼可以在任何的Service、Activity中使用。全局的
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 日韩免费视频一区二区 | 一区久久久 | 成人黄色免费网址 | 欧美精品一区二区三区四区五区 | 麻豆精品久久 | 免费看a| 日韩电影中文字幕 | 精品久久久成人 | 日韩欧美国产一区二区三区 | 日韩视频在线观看视频 | 成人水多啪啪片 | www.久久| 亚洲区视频在线 | 亚洲a级 | 日本一区二区三区免费观看 | 国产一区二区精品在线观看 | 一区二区三区回区在观看免费视频 | 国产视频一视频二 | 手机看片国产精品 | 国产玖玖 | 日本国产在线 | 亚洲综合二区 | 亚洲免费在线视频 | 在线视频日韩 | 欧洲精品一区二区 | 中文字幕一区二区在线观看 | 欧美日免费 | 欧美另类一区二区 | k8久久久一区二区三区 | 91欧美激情一区二区三区成人 | 欧美高清一区 | 欧美日韩久久精品 | 超碰av人人 | 三级视频网 | av下一页 | 欧美h| 日本黄色毛片 | 国产1区2区精品 | a中文字幕 | 色综合天天天天做夜夜夜夜做 | 日韩在线视频第一页 |