博客
关于我
Activity之间传递数据的三种方式详解
阅读量:652 次
发布时间:2019-03-15

本文共 1166 字,大约阅读时间需要 3 分钟。

Activity之间传递数据的三种方式

In Android开发中,在两个 Activity 之间传递数据的过程中,可以采用以下三种方法:

1. 使用 Bundle 启动数据传递对于简单数据类型

2. 使用 Serializable 分享对象数据

3. 使用 Parcelable 方便传输复杂对象

利用 Bundle 对象传递数据的实现方法如下:

// 点击按钮传递数据的方法public void button1(View v) {    // 创建意图    Intent intent = new Intent(this, Activity2.class);    // 获取文本输入    String s = editText1.getText().toString();    // 创建Bundle对象    Bundle bundle = new Bundle();    bundle.putString("info", s);    // 将Bundle添加到 Intent 中    intent.putExtra("box", bundle);    // 启动新的 Activity    startActivity(intent);}

接收数据的 Activity2 代码如下:

@Overrideprotected void onCreate(Bundle savedInstanceState) {    super.onCreate(savedInstanceState);    // 设置界面布局    setContentView(R.layout.activity2);    // 获取文本视图引用    TextView textView1 = (TextView) findViewById(R.id.textView1);    // 获取传递的数据    String s = null;    // 获取意图    Intent intent = getIntent();    // 从 Intent中获取 Bundle 对象    Bundle bundle = intent.getBundleExtra("box");    // 提取字符串数据    if (bundle != null) {        s = bundle.getString("info");    }    // 显示数据    textView1.setText(s);}

以上代码示例展示了如何通过 Bundle 对象将简单字符串数据从一个 Activity 转发到另一个 Activity。如果需要传输更复杂的对象,可以选择使用 Serializable 或 Parcelable。

转载地址:http://tkzmz.baihongyu.com/

你可能感兴趣的文章
MySql中 delimiter 详解
查看>>
MYSQL中 find_in_set() 函数用法详解
查看>>
MySQL中auto_increment有什么作用?(IT枫斗者)
查看>>
MySQL中B+Tree索引原理
查看>>
mysql中cast() 和convert()的用法讲解
查看>>
mysql中datetime与timestamp类型有什么区别
查看>>
MySQL中DQL语言的执行顺序
查看>>
mysql中floor函数的作用是什么?
查看>>
MySQL中group by 与 order by 一起使用排序问题
查看>>
mysql中having的用法
查看>>
MySQL中interactive_timeout和wait_timeout的区别
查看>>
mysql中int、bigint、smallint 和 tinyint的区别、char和varchar的区别详细介绍
查看>>
mysql中json_extract的使用方法
查看>>
mysql中json_extract的使用方法
查看>>
mysql中kill掉所有锁表的进程
查看>>
mysql中like % %模糊查询
查看>>
MySql中mvcc学习记录
查看>>
mysql中null和空字符串的区别与问题!
查看>>
MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
查看>>
MYSQL中TINYINT的取值范围
查看>>