Android Framework中的PolicyManager简介

2024-09-05 09:32

本文主要是介绍Android Framework中的PolicyManager简介,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

PolicyManager类位于framework\base\core\java\com\android\internal\policy目录中的PolicyManager.java文件中。PolicyManager主要用于创建Window类、LayoutInflater类和WindowManagerPolicy类,它扮演着简单工厂模式中的工厂类角色,而抽象产品角色由IPolicy接口实现,具体产品角色由Policy类实现。它们的关系如下图所示:

 加载中...

 

从下面三个类的代码可以看出,都使用了hide注解,因此,这三个类都是不对外公开的API,只限于Framework内部使用。

抽象产品类IPolicy实现如下(IPolicy.java):

[java]
 package com.android.internal.policy;
 
 import android.content.Context;
 import android.view.LayoutInflater;
 import android.view.Window;
 import android.view.WindowManagerPolicy;
 
 /**
  * {@hide}
  */
 
 /* The implementation of this interface must be called Policy and contained
  * within the com.android.internal.policy.impl package */
 public interface IPolicy {
     public Window makeNewWindow(Context context);
 
     public LayoutInflater makeNewLayoutInflater(Context context);
 
     public WindowManagerPolicy makeNewWindowManager();
 }
 package com.android.internal.policy;
 
import android.content.Context;
 import android.view.LayoutInflater;
 import android.view.Window;
 import android.view.WindowManagerPolicy;
 
/**
  * {@hide}
  */
 
/* The implementation of this interface must be called Policy and contained
  * within the com.android.internal.policy.impl package */
 public interface IPolicy {
     public Window makeNewWindow(Context context);
 
    public LayoutInflater makeNewLayoutInflater(Context context);
 
    public WindowManagerPolicy makeNewWindowManager();
 }
 
 具体产品类Policy实现如下(Policy.java):
 
[java]
 package com.android.internal.policy.impl;
 
 import android.content.Context;
 import android.util.Log;
 
 import com.android.internal.policy.IPolicy;
 import com.android.internal.policy.impl.PhoneLayoutInflater;
 import com.android.internal.policy.impl.PhoneWindow;
 import com.android.internal.policy.impl.PhoneWindowManager;
 
 /**
  * {@hide}
  */
 
 // Simple implementation of the policy interface that spawns the right 
 // set of objects 
 public class Policy implements IPolicy {
     private static final String TAG = "PhonePolicy";
 
     //需要在Policy类创建时预先加载的一些类 
     private static final String[] preload_classes = {
         "com.android.internal.policy.impl.PhoneLayoutInflater",
         "com.android.internal.policy.impl.PhoneWindow",
         "com.android.internal.policy.impl.PhoneWindow$1",
         "com.android.internal.policy.impl.PhoneWindow$ContextMenuCallback",
         "com.android.internal.policy.impl.PhoneWindow$DecorView",
         "com.android.internal.policy.impl.PhoneWindow$PanelFeatureState",
  "com.android.internal.policy.impl.PhoneWindow$PanelFeatureState$SavedState",
     };
 
     static {
         // 出于性能考虑,在Policy类加载时提前加载会用到的相关类 
         for (String s : preload_classes) {
             try {
         //加载指定类到Java虚拟机中,并执行类中的静态代码段 
                 Class.forName(s);
             } catch (ClassNotFoundException ex) {
                 Log.e(TAG, "Could not preload class for phone policy: " + s);
             }
         }
     }
 
     public PhoneWindow makeNewWindow(Context context) {
         return new PhoneWindow(context);
     }
 
     public PhoneLayoutInflater makeNewLayoutInflater(Context context) {
         return new PhoneLayoutInflater(context);
     }
 
     //PhoneWindowManager实现了WindowManagerPolicy接口     
     //这里返回值直接写成WindowManagerPolicy更合理些 
     public PhoneWindowManager makeNewWindowManager() {
         return new PhoneWindowManager();
     }
 }
 package com.android.internal.policy.impl;
 
import android.content.Context;
 import android.util.Log;
 
import com.android.internal.policy.IPolicy;
 import com.android.internal.policy.impl.PhoneLayoutInflater;
 import com.android.internal.policy.impl.PhoneWindow;
 import com.android.internal.policy.impl.PhoneWindowManager;
 
/**
  * {@hide}
  */
 
// Simple implementation of the policy interface that spawns the right
 // set of objects
 public class Policy implements IPolicy {
     private static final String TAG = "PhonePolicy";
 
    //需要在Policy类创建时预先加载的一些类
     private static final String[] preload_classes = {
         "com.android.internal.policy.impl.PhoneLayoutInflater",
         "com.android.internal.policy.impl.PhoneWindow",
         "com.android.internal.policy.impl.PhoneWindow$1",
         "com.android.internal.policy.impl.PhoneWindow$ContextMenuCallback",
         "com.android.internal.policy.impl.PhoneWindow$DecorView",
         "com.android.internal.policy.impl.PhoneWindow$PanelFeatureState",
  "com.android.internal.policy.impl.PhoneWindow$PanelFeatureState$SavedState",
     };
 
    static {
         // 出于性能考虑,在Policy类加载时提前加载会用到的相关类
         for (String s : preload_classes) {
             try {
      //加载指定类到Java虚拟机中,并执行类中的静态代码段
                 Class.forName(s);
             } catch (ClassNotFoundException ex) {
                 Log.e(TAG, "Could not preload class for phone policy: " + s);
             }
         }
     }
 
    public PhoneWindow makeNewWindow(Context context) {
         return new PhoneWindow(context);
     }
 
    public PhoneLayoutInflater makeNewLayoutInflater(Context context) {
         return new PhoneLayoutInflater(context);
     }
 
    //PhoneWindowManager实现了WindowManagerPolicy接口  
     //这里返回值直接写成WindowManagerPolicy更合理些
     public PhoneWindowManager makeNewWindowManager() {
         return new PhoneWindowManager();
     }
 }
 
 工厂类PolicyManager实现如下(PolicyManager.java):
 
[java]
 <pre class="java" name="code">package com.android.internal.policy;
 
 import android.content.Context;
 import android.view.LayoutInflater;
 import android.view.Window;
 import android.view.WindowManagerPolicy;
 
 import com.android.internal.policy.IPolicy;
 
 /**
  * {@hide}
  */
 
 public final class PolicyManager {
     private static final String POLICY_IMPL_CLASS_NAME =
         "com.android.internal.policy.impl.Policy";
 
     private static final IPolicy sPolicy;
 
     static {
        // 运行时动态装载IPolicy实现类 
         try {
            //加载Policy类的同时会执行其中的静态代码段 
             Class policyClass = Class.forName(POLICY_IMPL_CLASS_NAME);
             sPolicy = (IPolicy)policyClass.newInstance();
         } catch (ClassNotFoundException ex) {
             throw new RuntimeException(
                     POLICY_IMPL_CLASS_NAME + " could not be loaded", ex);
         } catch (InstantiationException ex) {
             throw new RuntimeException(
                     POLICY_IMPL_CLASS_NAME + " could not be instantiated", ex);
         } catch (IllegalAccessException ex) {
             throw new RuntimeException(
                     POLICY_IMPL_CLASS_NAME + " could not be instantiated", ex);
         }
     }
 
     // 构造函数私有,保证是单例类 
     private PolicyManager() {}
 
     // The static methods to spawn new policy-specific objects 
     public static Window makeNewWindow(Context context) {
         return sPolicy.makeNewWindow(context);
     }
 
     public static LayoutInflater makeNewLayoutInflater(Context context) {
         return sPolicy.makeNewLayoutInflater(context);
     }
 
     public static WindowManagerPolicy makeNewWindowManager() {
         return sPolicy.makeNewWindowManager();
     }
 }
 <pre class="java" name="code">package com.android.internal.policy;
 
import android.content.Context;
 import android.view.LayoutInflater;
 import android.view.Window;
 import android.view.WindowManagerPolicy;
 
import com.android.internal.policy.IPolicy;
 
/**
  * {@hide}
  */
 
public final class PolicyManager {
     private static final String POLICY_IMPL_CLASS_NAME =
         "com.android.internal.policy.impl.Policy";
 
    private static final IPolicy sPolicy;
 
    static {
        // 运行时动态装载IPolicy实现类
         try {
            //加载Policy类的同时会执行其中的静态代码段
             Class policyClass = Class.forName(POLICY_IMPL_CLASS_NAME);
             sPolicy = (IPolicy)policyClass.newInstance();
         } catch (ClassNotFoundException ex) {
             throw new RuntimeException(
                     POLICY_IMPL_CLASS_NAME + " could not be loaded", ex);
         } catch (InstantiationException ex) {
             throw new RuntimeException(
                     POLICY_IMPL_CLASS_NAME + " could not be instantiated", ex);
         } catch (IllegalAccessException ex) {
             throw new RuntimeException(
                     POLICY_IMPL_CLASS_NAME + " could not be instantiated", ex);
         }
     }
 
    // 构造函数私有,保证是单例类
     private PolicyManager() {}
 
    // The static methods to spawn new policy-specific objects
     public static Window makeNewWindow(Context context) {
         return sPolicy.makeNewWindow(context);
     }
 
    public static LayoutInflater makeNewLayoutInflater(Context context) {
         return sPolicy.makeNewLayoutInflater(context);
     }
 
    public static WindowManagerPolicy makeNewWindowManager() {
         return sPolicy.makeNewWindowManager();
     }
 }
 

这篇关于Android Framework中的PolicyManager简介的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1138575

相关文章

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

Android ClassLoader加载机制详解

《AndroidClassLoader加载机制详解》Android的ClassLoader负责加载.dex文件,基于双亲委派模型,支持热修复和插件化,需注意类冲突、内存泄漏和兼容性问题,本文给大家介... 目录一、ClassLoader概述1.1 类加载的基本概念1.2 android与Java Class

Qt QCustomPlot库简介(最新推荐)

《QtQCustomPlot库简介(最新推荐)》QCustomPlot是一款基于Qt的高性能C++绘图库,专为二维数据可视化设计,它具有轻量级、实时处理百万级数据和多图层支持等特点,适用于科学计算、... 目录核心特性概览核心组件解析1.绘图核心 (QCustomPlot类)2.数据容器 (QCPDataC

Android DataBinding 与 MVVM使用详解

《AndroidDataBinding与MVVM使用详解》本文介绍AndroidDataBinding库,其通过绑定UI组件与数据源实现自动更新,支持双向绑定和逻辑运算,减少模板代码,结合MV... 目录一、DataBinding 核心概念二、配置与基础使用1. 启用 DataBinding 2. 基础布局

解决Entity Framework中自增主键的问题

《解决EntityFramework中自增主键的问题》:本文主要介绍解决EntityFramework中自增主键的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录Entity Framework中自增主键问题解决办法1解决办法2解决办法3总结Entity Fram

Android ViewBinding使用流程

《AndroidViewBinding使用流程》AndroidViewBinding是Jetpack组件,替代findViewById,提供类型安全、空安全和编译时检查,代码简洁且性能优化,相比Da... 目录一、核心概念二、ViewBinding优点三、使用流程1. 启用 ViewBinding (模块级

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

rust 中的 EBNF简介举例

《rust中的EBNF简介举例》:本文主要介绍rust中的EBNF简介举例,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 什么是 EBNF?2. 核心概念3. EBNF 语法符号详解4. 如何阅读 EBNF 规则5. 示例示例 1:简单的电子邮件地址

Android NDK版本迭代与FFmpeg交叉编译完全指南

《AndroidNDK版本迭代与FFmpeg交叉编译完全指南》在Android开发中,使用NDK进行原生代码开发是一项常见需求,特别是当我们需要集成FFmpeg这样的多媒体处理库时,本文将深入分析A... 目录一、android NDK版本迭代分界线二、FFmpeg交叉编译关键注意事项三、完整编译脚本示例四

Android与iOS设备MAC地址生成原理及Java实现详解

《Android与iOS设备MAC地址生成原理及Java实现详解》在无线网络通信中,MAC(MediaAccessControl)地址是设备的唯一网络标识符,本文主要介绍了Android与iOS设备M... 目录引言1. MAC地址基础1.1 MAC地址的组成1.2 MAC地址的分类2. android与I