1-AI--Activity生命周期

简介: 1.ActivityLifeCycle:测试生命周期的Activity2.CommonActivity是一个普通的Activity3.DialogActivity是对话框型的Activityactivity生命周期.

1.ActivityLifeCycle:测试生命周期的Activity
2.CommonActivity是一个普通的Activity
3.DialogActivity是对话框型的Activity

activity生命周期.gif

一、Activity

1.ActivityLifeCycle.java
public class ActivityLifeCycle extends AppCompatActivity {
    private static final String TAG = "ActivityLifeCycle";
    @BindView(R.id.btn_task_activity)
    Button mBtnTaskActivity;
    @BindView(R.id.btn_dialog_activity)
    Button mBtnDialogActivity;

    @Override//Activity第一次创建时调用
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.ac_lifecycle);
        ButterKnife.bind(this);
        Log.e(TAG, "onCreate: ");

        Log.e("TASK_ID", "Task id is " + getTaskId());
    }

    @Override//Activity可见的时候调用
    protected void onStart() {
        super.onStart();
        Log.e(TAG, "onStart: ");

    }

    @Override//Activity位于栈顶,获取焦点时调用
    protected void onResume() {
        super.onResume();
        Log.e(TAG, "onResume: ");
    }


    @Override//Activity移除栈顶,失去焦点时调用
    protected void onPause() {
        super.onPause();
        Log.e(TAG, "onPause: ");
    }

    @Override//由停止状态变为运行状态之前调用
    protected void onRestart() {
        super.onRestart();
        Log.e(TAG, "onRestart: ");
    }

    @Override//Activity不可见的时候调用
    protected void onStop() {
        super.onStop();
        Log.e(TAG, "onStop: ");
    }

    @Override//Activity销毁的时候调用
    protected void onDestroy() {
        super.onDestroy();
        Log.e(TAG, "onDestroy: ");
    }

    @OnClick({R.id.btn_task_activity, R.id.btn_dialog_activity})
    public void onViewClicked(View view) {
        switch (view.getId()) {
            case R.id.btn_task_activity:
                //跳转到TaskActivity
                startActivity(new Intent(this, TaskActivity.class));
                break;
            case R.id.btn_dialog_activity:
                //跳转到DialogActivity
                startActivity(new Intent(this, DialogActivity.class));
                break;
        }
    }
}
2.CommonActivity.java
public class CommonActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.ac_task);
        ButterKnife.bind(this);
    }
}
3.DialogActivity
public class DialogActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.ac_dialog);
    }
}

二、生命周期测试结果:

1.打开:onCreate==>onStart==>onResume
E/ActivityLifeCycle: onCreate: 
E/ActivityLifeCycle: onStart: 
E/ActivityLifeCycle: onResume:
2.跳转普通Activity:onPause==>onStop
E/ActivityLifeCycle: onPause: 
E/ActivityLifeCycle: onStop: 
3.从跳转的Activity返回:onRestart==>onStart==>onResume
E/ActivityLifeCycle: onRestart: 
E/ActivityLifeCycle: onStart: 
E/ActivityLifeCycle: onResume: 
4.跳转到对话框Activity:onPause
 E/ActivityLifeCycle: onPause: 
5.从对话框Activity返回:onResume
E/ActivityLifeCycle: onResume: 
6.旋转屏幕(相当于关闭再开启):onPause==>onStop==>onDestroy==>onCreate==>onStart==>onResume
E/ActivityLifeCycle: onPause: 
E/ActivityLifeCycle: onStop: 
E/ActivityLifeCycle: onDestroy: 
E/ActivityLifeCycle: onCreate: 
E/ActivityLifeCycle: onStart: 
E/ActivityLifeCycle: onResume: 
7.关闭:onPause==>onStop==>onDestroy
E/ActivityLifeCycle: onPause: 
E/ActivityLifeCycle: onStop: 
E/ActivityLifeCycle: onDestroy: 

附录、布局:

1.ActivityLifeCycle布局:ac_lifecycle.xml
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent">


    <Button
        android:id="@+id/btn_task_activity"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="16dp"
        android:text="打开TaskActivity"
        android:textAllCaps="false"
        app:layout_constraintTop_toTopOf="parent"
        tools:layout_editor_absoluteX="30dp"/>

    <Button
        android:id="@+id/btn_dialog_activity"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="16dp"
        android:text="打开DialogActivity"
        android:textAllCaps="false"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.873"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"/>
</android.support.constraint.ConstraintLayout>
2.CommonActivity布局:ac_task.xml
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <Button
        android:id="@+id/btn_start_self"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="16dp"
        android:text="打开自己"
        android:textAllCaps="false"
        app:layout_constraintTop_toTopOf="parent"
        tools:layout_editor_absoluteX="30dp"/>

    <Button
        android:id="@+id/button_start_others"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="8dp"
        android:layout_marginStart="8dp"
        android:layout_marginTop="16dp"
        android:text="打开别人"
        app:layout_constraintStart_toEndOf="@+id/btn_start_self"
        app:layout_constraintTop_toTopOf="parent"/>
    
</android.support.constraint.ConstraintLayout>
3.DialogActivity布局:ac_dialog.xml
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <TextView
        android:id="@+id/textView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="A01_DialogActivity"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        tools:layout_editor_absoluteY="233dp"
        tools:ignore="MissingConstraints"/>

</android.support.constraint.ConstraintLayout>
4.DialogActivity对话框主题
<activity
    android:name=".DialogActivity"
    android:label="DialogActivity"
    android:theme="@style/Theme.AppCompat.Light.Dialog">
</activity>

后记、

1.声明:

[1]本文由张风捷特烈原创,转载请注明
[2]欢迎广大编程爱好者共同交流
[3]个人能力有限,如有不正之处欢迎大家批评指证,必定虚心改正
[4]你的喜欢与支持将是我最大的动力

2.连接传送门:

更多安卓技术欢迎访问:安卓技术栈
我的github地址:欢迎star
简书首发,腾讯云+社区同步更新
张风捷特烈个人网站,编程笔记请访问:http://www.toly1994.com

3.联系我

QQ:1981462002
邮箱:1981462002@qq.com
微信:zdl1994328

4.欢迎关注我的微信公众号,最新精彩文章,及时送达:
公众号.jpg
相关文章
|
18天前
|
人工智能 前端开发 JavaScript
【AI】命令行调用大模型
通过命令行调用AI大模型以提高效率,文章介绍了一个使用前端npm的方法。首先创建npm包项目,初始化配置,然后编写`constant.js`、`kiwi.js`和`main.js`三个文件,分别存放API密钥、调用接口和主逻辑。在`kiwi.js`中使用axios与大模型API交互,`main.js`接收命令行参数并输出结果。通过修改`package.json`设置入口文件,并使用`npm link`全局安装,实现命令行调用,如`moon 你好`。
54 0
|
18天前
|
人工智能 前端开发
【AI的未来 - AI Agent系列】【MetaGPT】6. 用ActionNode重写技术文档助手
【AI的未来 - AI Agent系列】【MetaGPT】6. 用ActionNode重写技术文档助手
46 0
|
18天前
|
人工智能 运维 自然语言处理
对话蚂蚁李建国:当前AI写代码相当于L2.5,实现L3后替代50%人类编程
超70%代码问题,单纯靠基座大模型是解决不了的;未来3-5年,人类50%编程工作可以被替代,有些环节甚至完全自动化。蚂蚁集团代码大模型CodeFuse负责人李建国说道。当下,AI代码生成领域正在野蛮式生长,巨头涌入,AI员工频频上线企业;首个AI程序员Devin被曝造假…… 面对风起云涌的代码生成变革,李建国给出了这样一个明确论断。
38 0
|
18天前
|
人工智能 API 决策智能
【AI的未来 - AI Agent系列】【MetaGPT】0. 你的第一个MetaGPT程序
【AI的未来 - AI Agent系列】【MetaGPT】0. 你的第一个MetaGPT程序
79 0
|
18天前
|
人工智能 缓存 前端开发
ai对话---多线程并发处理问题
ai对话---多线程并发处理问题
|
18天前
|
人工智能 Ubuntu PyTorch
极智AI | libtorch调用模型推理方法
大家好,我是极智视界,本文介绍一下 libtorch 调用模型推理方法。
110 0
|
7月前
|
机器学习/深度学习 数据采集 人工智能
甭提ChatGPT了,这个新的AI助手将永远改变人们的工作方式
甭提ChatGPT了,这个新的AI助手将永远改变人们的工作方式
|
9月前
|
人工智能 机器人 关系型数据库
创建专属AI机器人
继上次部署失败后,重新部署
135 22
|
10月前
|
人工智能 程序员 Python
让AI给你工作:真正的帮你写代码
让AI给你工作:真正的帮你写代码
311 0
|
10月前
|
人工智能 算法
AI改变生活
AI绘画是一种非常有趣和创新的技术,对于零基础的绘画爱好者来说,AI绘画提供了一个令人兴奋和灵感迸发的创作平台。操作下来AI绘画有着以下优势

热门文章

最新文章