当前位置: 首页 > news >正文

Android 中获取稳定时间的方法

在Android中,获取不会因系统时间设置改变而跳变的时间通常需要使用基于设备启动时间的单调时钟。下面我将展示几种实现方式。

实现思路

1. 使用SystemClock.elapsedRealtime() - 基于设备启动时间,不受系统时间设置影响
2. 使用SystemClock.uptimeMillis() - 同样基于设备启动时间,但不包括深度睡眠时间
3. 使用System.nanoTime() - 高精度单调时间

示例代码实现

```xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:padding="20dp"
android:orientation="vertical"
android:gravity="center">

    <TextView
android:id="@+id/titleTextView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="稳定时间获取示例"
android:textSize="20sp"
android:textStyle="bold"
android:layout_marginBottom="30dp"/>

    <Button
android:id="@+id/elapsedRealtimeButton"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="获取elapsedRealtime"
android:layout_marginBottom="10dp"/>

    <Button
android:id="@+id/uptimeMillisButton"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="获取uptimeMillis"
android:layout_marginBottom="10dp"/>

    <Button
android:id="@+id/nanoTimeButton"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="获取nanoTime"
android:layout_marginBottom="30dp"/>

    <TextView
android:id="@+id/resultTextView"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="结果将显示在这里"
android:textSize="16sp"
android:gravity="center"
android:padding="10dp"
android:background="#f0f0f0"/>

</LinearLayout>
```

```java
import android.os.Bundle;
import android.os.SystemClock;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import androidx.appcompat.app.AppCompatActivity;

public class MainActivity extends AppCompatActivity {

    private TextView resultTextView;

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

        resultTextView = findViewById(R.id.resultTextView);
Button elapsedRealtimeButton = findViewById(R.id.elapsedRealtimeButton);
Button uptimeMillisButton = findViewById(R.id.uptimeMillisButton);
Button nanoTimeButton = findViewById(R.id.nanoTimeButton);

        elapsedRealtimeButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
long elapsedTime = SystemClock.elapsedRealtime();
resultTextView.setText("elapsedRealtime: " + elapsedTime + "ms\n" +
"格式化为时间: " + formatTime(elapsedTime));
}
});

        uptimeMillisButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
long uptime = SystemClock.uptimeMillis();
resultTextView.setText("uptimeMillis: " + uptime + "ms\n" +
"格式化为时间: " + formatTime(uptime));
}
});

        nanoTimeButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
long nanoTime = System.nanoTime();
resultTextView.setText("nanoTime: " + nanoTime + "ns\n" +
"转换为毫秒: " + (nanoTime / 1_000_000) + "ms");
}
});
}

    private String formatTime(long milliseconds) {
long seconds = milliseconds / 1000;
long minutes = seconds / 60;
long hours = minutes / 60;
long days = hours / 24;

        return String.format("%d天 %02d:%02d:%02d.%03d",
days, hours % 24, minutes % 60, seconds % 60, milliseconds % 1000);
}
}
```

关键说明

1. SystemClock.elapsedRealtime():
· 自设备启动以来经过的时间,包括深度睡眠时间
· 最适合测量时间间隔,不受系统时间设置影响
2. SystemClock.uptimeMillis():
· 自设备启动以来经过的时间,不包括深度睡眠时间
· 适合需要忽略设备睡眠时间的场景
3. System.nanoTime():
· 提供纳秒级精度的时间
· 通常用于性能测量和高精度计时

这些方法都提供了单调递增的时间值,不会因为用户更改系统时间或自动时间同步而跳变。

使用场景建议

· 测量时间间隔或耗时操作:使用elapsedRealtime()或uptimeMillis()
· 高精度性能测量:使用nanoTime()
· 需要跨设备重启保持时间跟踪:需要将时间持久化存储并与elapsedRealtime()结合使用

注意:如果需要跨设备重启保持时间跟踪,可以将设备启动时间与elapsedRealtime()结合使用,但这需要额外的实现。

http://www.dtcms.com/a/393514.html

相关文章:

  • mac编译ffmpeg
  • Deepsoil V7.1.10+Shake2000,最新版程序、教学视频、PDF使用手册
  • Apollo相机数据RTMP推流与播放指南
  • 使用Python扩展Unity编辑器
  • 【Android】自定义控件
  • 探索 Event 框架 6:高级特性与性能优化
  • JavaSE基础——第九章 枚举类注解
  • 云计算在金融领域中的应用
  • 【入门算法】前缀和:先预存再求和,以空间换时间
  • mac编译vst3sdk
  • Java 网络原理(二)--- TCP的机制 + IP协议 +以太网协议 + DNS
  • Python文件名编码处理深度解析:绕过编码问题的专业指南
  • 如何利用简单的浏览器插件Web Scraper爬取知乎评论数据
  • 鹿鼎记豪侠传:Rust 重塑 iOS 江湖(下)
  • 03.博客版-镜像
  • 云原生docker离线二进制安装
  • RabbitMQ 的配置文件位置及常见配置项
  • Visual Prompt Builder-AI 提示词可视化工具
  • 一文掌握Flask:从基础使用到高级应用
  • 23种设计模式之【责任链模式】-核心原理与 Java 实践
  • 执行 conda update -n base -c defaults conda 后仍提示需要升级
  • 学习日报 20250921|NIO
  • 【Linux操作系统】Linux基础指令和权限
  • 谷歌nano banana官方Prompt模板
  • 基于Python大数据的新闻推荐分析
  • ​​[硬件电路-315]:AD7606BSTZ如何测量失调电压?
  • 微服务-分布式追踪 / 监控工具大全
  • The Library: 2靶场渗透
  • 金融知识“厦”乡趣 平安产险厦门分公司启动2025年“金融教育宣传周”活动
  • C++学习笔记——模板初阶