Fragment 通信

博客介绍了Fragment中多种通信技术,如eventBus、rxBus、handler、static、广播和接口等,分析了它们各自的优缺点。指出接口是最优方案,但存在代码冗余问题,提出可写一个万能接口共用,并提及了接口实现的基类、方法类、管理类及调用方式。

首先列举一下Fragment中可以实现通信的技术:

万金油 eventBus rxBus:

优点:方便,快捷,简单

缺陷:

1.反射,性能打折,效率低

2.代码维护困难

3.数据无法返回,单向传送

 

handler

缺点:

1.耦合

2.无法获取activity的返回结果

3.内存泄漏

 

static

静态变量,内存消耗

 

广播

缺陷:

1.性能差,延迟

2.通信体系,较重,一个发生,多个接受

3.传播的数据有限

4.代码冗余

 

接口(最优方案)

简单、效率高,方便,解耦合

缺点:

代码冗余,每个需要通信的fragment,都需要定义自己独一无二的接口。

那最合适的通信方法,可以写一个万能接口,共用。

下面把代码贴出来:

首先先定义一个基类

/**
 * 万能接口之-----基类
 */

public class Function {

    //方法名字
    public String functionName;

    //传递方法名字
    public Function(String functionName){
        this.functionName = functionName;
    }

}

其次方法类

/**
 * 万能接口之-----有参数,无返回值的方法(这里我只实现了一个方法类型)
 */

public abstract class FunctionHasParamNoResult<P> extends Function {

    public FunctionHasParamNoResult(String functionName) {
        super(functionName);
    }

    public abstract void function(P p);
}

最后是管理类

/**
 * 万能接口之-----接口管理类
 */

public class FunctionManager {

    private static FunctionManager instance;

    /**
     * 容器,用来存储方法名字 key 对应的方法名 value 对应的是 参数返回对象
     */
    //这里只实现了一种容器 就是有参数,无返回。故只有一种容器
    private Map<String, FunctionHasParamNoResult> mNasparamNoResultMap;

    /**
     * 构造方法
     */
    private FunctionManager() {
        mNasparamNoResultMap = new HashMap<>();
    }

    public static FunctionManager getInstance() {
        if (instance == null) {
            instance = new FunctionManager();
        }
        return instance;
    }


    /***
     * 添加有参数无返回值的方法
     * @param function
     */
    public void addFunction(FunctionHasParamNoResult function) {
        mNasparamNoResultMap.put(function.functionName, function);
    }


    /***
     * 调用有参数无返回值的方法
     * @param functionName
     * @param p
     * @param <P>
     */
    public <P> void invokeFunction(String functionName, P p) {
        //判断方法名是否为空,若为空跳出此方法
        if (TextUtils.isEmpty(functionName)) {
            return;
        }
        //判断 (有参数无返回值)的容器是否为空
        if (mNasparamNoResultMap != null) {
            //根据方法名查询容器中对应的数据
            FunctionHasParamNoResult f = mNasparamNoResultMap.get(functionName);
            if (f != null) {
                //调用回调传值
                f.function(p);
            } else {
                try {
                    throw new Exception("方法不存在");
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        }
    }

}

调用:(A->B:key对应方法名,valule对应传递的值)

A:FunctionManager.getInstance().invokeFunction("key","vaule");

 

B:FunctionManager.getInstance().addFunction(new FunctionHasParamNoResult("key") {
    @Override
    public void function(Object o) {
        Log.e("arguments", "万能的接口:"+o.toString());
    }
});

 

 

 

 

 

 

 

 

 

### AndroidFragment 之间的通信方法 #### 使用 Activity 作为中介 一种常见的方式是让两个 `Fragment` 过共同的 `Activity` 来交换信息。这常涉及到定义一个回调接口,由宿主 `Activity` 实现该接口,并将其传递给各个 `Fragment`。当某个 `Fragment` 需要发送消息时,它调用此接口中的相应方法;而接收方则可以在其生命周期内的适当时刻监听到来自 `Activity` 的知并作出响应[^1]。 ```java // 定义接口 public interface OnDataPass { void onDataPass(String data); } // 在第一个Fragment中设置数据传输 @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { ((MainActivity)getActivity()).onDataPass("Some Data"); } ``` #### 利用接口实现解耦合设计 为了提高灵活性和可维护性,推荐采用面向接口的设计模式。具体来说就是在 `Fragment` 内部过 `getActivity()` 获取到的是实现了特定接口的对象而非具体的 `Activity` 类型对象。这样做的好处是可以使代码更加模块化,便于测试以及未来可能发生的架构调整[^3]。 #### 新推出的 Fragment Result API 随着 AndroidX 库的发展,官方推出了新的 `Fragment Result API` 及 `ActivityResultContracts` 来简化跨组件的数据交互过程。这种方式不仅限于 `Fragment` 间的讯,也可以应用于启动其他类型的组件(如相机应用)后的结果返回场景。对于简单的键值对形式的小量数据共享尤为适用[^4]。 ```kotlin // 发送者fragment注册请求码与bundle setFragmentResult( "requestKey", bundleOf("key" to "value") ) // 接收者fragment观察指定请求的结果变化 setFragmentResultListener("requestKey") { _, bundle -> val result = bundle.getString("key") // 处理接收到的数据... } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值