纯血鸿蒙崛起,原生Android挑战?两大操作系统巅峰对决,智能设备未来谁主沉浮?

鸿蒙HarmonyOS和原生Android系统虽然在一些方面相似,但在架构、设计理念、API、开发工具等方面存在一些差异。鸿蒙系统的目标是跨设备、分布式的操作系统,强调多设备协同和资源共享,而Android则主要集中在智能手机和移动设备领域。

下面将从几个角度对比鸿蒙和原生Android,并结合具体项目代码做对比说明。

1. 架构差异

原生Android:
Android是基于Linux 内核的移动操作系统,应用的运行环境由AndroidRuntime(ART)提供支持。Android的应用程序通常运行在单个设备上,并且系统中各种服务和组件多为单设备本地服务。

在这里插入图片描述

鸿蒙HarmonyOS:
鸿蒙操作系统采用了分布式架构,能够让应用在多种设备上运行,设备之间通过分布式数据管理和设备协作进行无缝连接。鸿蒙的核心是 “Ark” 引擎,支持统一的开发框架,能够将应用在不同设备之间无缝迁移。

  • 多设备协同:鸿蒙的分布式能力允许应用跨设备运行,在不同设备之间共享资源,例如手机、平板、电视、甚至智能穿戴设备。

2. 开发语言与工具

原生Android:
Android主要使用Java和Kotlin作为开发语言,开发者可以使用AndroidStudio 开发Android应用。原生Android应用开发者会基于AndroidSDK 构建应用。

鸿蒙HarmonyOS:
鸿蒙系统主要使用 Java、Kotlin 和 C/C++ 作为开发语言,同时支持使用HarmonyOS特有的开发框架和 API。开发者可以使用 DevEco Studio 开发鸿蒙应用。

3. UI 构建差异

原生AndroidUI:
原生Android应用使用View和ViewGroup来构建用户界面。常见的布局有LinearLayout、RelativeLayout、ConstraintLayout等。

鸿蒙HarmonyOSUI:
鸿蒙系统提供了 Ability 和 ArkUI 来构建 UI。Ability是鸿蒙应用的核心组件,可以理解为一个类似于 Activity 的概念,ArkUI则是鸿蒙的 UI 开发框架。

与Android的 View 组件类似,鸿蒙 UI 中通过声明式的布局方式构建 UI,采用 Declarative UI 编程模式,类似于 Jetpack Compose。

4. 跨设备能力:

鸿蒙的一个重要特性是其分布式应用框架,允许应用跨设备无缝运行。通过 Ability 的定义,应用可以在多种设备间运行和协作。

示例:原生Android中的共享数据

在Android中,通常使用Intent和Bundle在应用间传递数据,或者通过ContentProvider共享数据。

// 通过 Intent 传递数据
val intent = Intent(this, OtherActivity::class.java)
intent.putExtra("key", "value")
startActivity(intent)

示例:鸿蒙HarmonyOS中的跨设备协作

在鸿蒙中,跨设备的数据传递和功能协作是通过 Ability 和 DistributedData 进行的。通过定义不同设备上的 Ability,应用能够在多个设备间无缝协作。

// 在鸿蒙中定义一个 BasicAbility(类似于Android的 Activity)
public class MainAbility extends Ability {@Overridepublic void onStart(Intent intent) {super.onStart(intent);// 设定主界面的布局setUIContent(ResourceTable.Layout_ability_main);}@Overridepublic void onStop() {super.onStop();}
}// 通过 DistributedData 在不同设备之间共享数据
public class DistributedDataDemo {private DistributedDatabase database;public void initialize() {// 获取 DistributedDatabase 实例database = DistributedDatabase.getInstance();}public void writeData() {// 写入数据到共享数据库database.put("key", "value");}public String readData() {// 从共享数据库读取数据return database.get("key");}
}

5. 生命周期管理

Android生命周期:
Android的生命周期管理基于Activity或Fragment的生命周期回调。比如,onCreate()、onStart()、onResume()等。

@Override
protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);
}@Override
protected void onResume() {super.onResume();// 页面恢复时的逻辑
}

鸿蒙生命周期:
在鸿蒙中,生命周期管理是基于Ability的。Ability类似于Android的Activity,但它具有更灵活的生命周期,允许在多个设备之间共享状态和信息。

// 在鸿蒙中定义 Ability 生命周期
public class MainAbility extends Ability {@Overridepublic void onStart(Intent intent) {super.onStart(intent);// 初始化界面setUIContent(ResourceTable.Layout_ability_main);}@Overridepublic void onActive() {super.onActive();// 能够访问到界面和用户交互的逻辑}@Overridepublic void onStop() {super.onStop();// 页面停止时的清理操作}
}

6. 应用发布和权限管理

Android权限管理:
Android应用权限在AndroidManifest.xml中进行声明。在运行时,某些权限还需要用户授权。

<uses-permissionAndroid:name="android.permission.ACCESS_FINE_LOCATION" />

鸿蒙 权限管理:
鸿蒙系统的权限管理相对更加简化,通过 DevEco Studio 提供的权限管理工具来声明和管理应用的权限。

<permission name="ohos.permission.LOCATION" />

7. 应用分发和多设备协同

鸿蒙的分发机制更加侧重于跨设备协作。鸿蒙应用不仅能够在智能手机上运行,还可以跨平板、电视、车机、穿戴设备等多个设备平台运行。通过分布式技术,鸿蒙系统能够实现同一应用在不同设备之间的无缝协作。

项目举例
下面结合一个简单的示例项目,展示如何使用鸿蒙HarmonyOS和原生Android实现相似的功能。我们将构建一个简单的应用,用户可以在一个设备(如手机)上输入数据,并将该数据同步到另一个设备(如平板或智能电视)。这将展示 鸿蒙的跨设备能力 和Android中跨设备的传统方式。

- 在一个设备上输入文本。
- 通过网络或本地存储同步文本数据到另一个设备(例如,平板)。
- 我们会分别实现Android和HarmonyOS版本,进行对比。

一、 鸿蒙HarmonyOS实现

鸿蒙系统的主要特性之一是 Ability(类似于Android中的Activity),而它的分布式特性让应用可以在多个设备之间协作。鸿蒙使用 DistributedData 来共享数据。

(1) 创建一个鸿蒙应用
在鸿蒙中,分布式应用通常涉及 Ability、DistributedDatabase、Data同步 等概念。我们将创建一个跨设备同步数据的简单例子。

第1步:创建一个新的 Ability(类似于Android的 Activity)

package com.example.harmonyapp;import ohos.aafwk.ability.Ability;
import ohos.aafwk.content.Intent;
import ohos.agp.components.EditText;
import ohos.agp.components.Button;
import ohos.data.DatabaseHelper;
import ohos.data.resultset.ResultSet;
import ohos.data.dataability.DataAbilityHelper;
import ohos.data.dataability.DataAbilityPredicates;
import ohos.data.dataability.DataAbilityOperation;
import ohos.data.dataability.DataAbilityOperation.OperationType;public class MainAbility extends Ability {private EditText inputText;private Button saveButton;@Overridepublic void onStart(Intent intent) {super.onStart(intent);setUIContent(ResourceTable.Layout_ability_main);inputText = (EditText) findComponentById(ResourceTable.Id_input_text);saveButton = (Button) findComponentById(ResourceTable.Id_save_button);// Save button click listenersaveButton.setClickedListener(component -> {String text = inputText.getText();saveDataToSharedDatabase(text);});}private void saveDataToSharedDatabase(String text) {// 使用 DistributedData 保存数据,跨设备共享DataAbilityHelper dataAbilityHelper = DataAbilityHelper.creator(this);DataAbilityOperation operation = new DataAbilityOperation.Builder().withUri("dataability://com.example.harmonyapp.data/records").withValue("text", text).withOperationType(OperationType.INSERT).build();dataAbilityHelper.executeBatch(new DataAbilityOperation[] { operation });}
}

第2步:使用 DistributedData 进行数据同步

在鸿蒙系统中,数据可以通过 DistributedData 跨设备共享。例如,使用DataAbility实现跨设备数据同步。通过创建DataAbilityHelper,我们可以实现不同设备间的数据共享。

package com.example.harmonyapp.data;import ohos.data.dataability.DataAbility;
import ohos.data.dataability.DataAbilityPredicates;
import ohos.data.resultset.ResultSet;
import ohos.data.dataability.DataAbilityHelper;public class MyDataAbility extends DataAbility {@Overridepublic ResultSet query(Uri uri, String[] projection, DataAbilityPredicates predicates) {// 查询数据DataAbilityHelper helper = DataAbilityHelper.creator(this);return helper.query(uri, projection, predicates);}@Overridepublic int insert(Uri uri, ValuesBucket value) {// 插入数据DataAbilityHelper helper = DataAbilityHelper.creator(this);return helper.insert(uri, value);}
}

第3步:在布局文件中设置 UI

<!-- ability_main.xml -->
<LinearLayout xmlns:ohos="http://schemas.huawei.com/res/ohos"ohos:orientation="vertical"ohos:width="match_parent"ohos:height="match_parent"><EditTextohos:id="$+id:input_text"ohos:hint="Enter some text"ohos:height="60vp"ohos:width="match_parent"ohos:layout_marginTop="50vp" /><Buttonohos:id="$+id:save_button"ohos:text="Save"ohos:width="match_parent"ohos:height="60vp"ohos:layout_marginTop="20vp" />
</LinearLayout>

二、原生Android实现

在Android中,我们可以使用SharedPreferences或ContentProvider来跨设备共享数据。为了简单起见,我们将使用SharedPreferences,并通过Firebase Realtime Database来同步数据到云端,使得其他设备可以读取和更新数据。

第1步:创建一个Activity

package com.example.androidapp;importAndroid.os.Bundle;
importAndroid.view.View;
importAndroid.widget.Button;
importAndroid.widget.EditText;
importAndroidx.appcompat.app.AppCompatActivity;
import com.google.firebase.database.DatabaseReference;
import com.google.firebase.database.FirebaseDatabase;public class MainActivity extends AppCompatActivity {private EditText inputText;private Button saveButton;private DatabaseReference databaseReference;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);inputText = findViewById(R.id.input_text);saveButton = findViewById(R.id.save_button);// 初始化 Firebase 数据库databaseReference = FirebaseDatabase.getInstance().getReference("sharedData");saveButton.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {String text = inputText.getText().toString();saveDataToFirebase(text);}});}private void saveDataToFirebase(String text) {// 将数据保存到 Firebase 实时数据库databaseReference.setValue(text);}
}

第2步:在布局文件中设置 UI

<!-- activity_main.xml -->
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"Android:orientation="vertical"Android:layout_width="match_parent"Android:layout_height="match_parent"><EditTextAndroid:id="@+id/input_text"Android:hint="Enter some text"Android:layout_width="match_parent"Android:layout_height="wrap_content"Android:layout_marginTop="50dp" /><ButtonAndroid:id="@+id/save_button"Android:text="Save"Android:layout_width="match_parent"Android:layout_height="wrap_content"Android:layout_marginTop="20dp" />
</LinearLayout>

第3步:使用 Firebase Realtime Database

  1. 在 Firebase Console 中创建一个项目,并获取 Google Services JSON 配置文件。
  2. 在 build.gradle 中添加 Firebase 依赖:
dependencies {implementation 'com.google.firebase:firebase-database:20.0.0'
}
  1. 使用 Firebase 实时数据库同步数据。

三、 对比分析

  1. 跨设备能力:
  • 鸿蒙:通过DistributedData和Ability实现跨设备协作和数据共享,鸿蒙系统的分布式架构使得应用可以在多个设备之间同步数据并实现无缝协作。
    -Android:通常通过云服务(如 Firebase)或ContentProvider实现跨设备的数据同步。在这个示例中,我们使用 Firebase Realtime Database 来同步数据,适用于多个Android设备之间。
  1. UI 构建:
  • 鸿蒙:使用类似Activity的 Ability 来管理生命周期和 UI 组件。布局采用类似 XML 的声明式方式。
    -Android:通过Activity和传统的View组件管理 UI。布局采用 XML 描述。
  1. 数据存储和共享:
  • 鸿蒙:使用 DistributedData 和 DataAbility 来处理跨设备的数据同步。
    -Android:使用SharedPreferences或Firebase等云端服务实现跨设备的数据同步。
  1. 开发工具:
  • 鸿蒙:使用 DevEco Studio 开发,支持多种设备的协同开发。
    -Android:使用AndroidStudio 开发,主要面向Android设备。

在这里插入图片描述

总结

通过这个示例,我们可以看到鸿蒙与Android在处理跨设备协同和数据同步时的差异。鸿蒙的分布式架构使得在多设备间同步数据变得更加容易,而Android则通过云服务(如 Firebase)实现跨设备的数据共享。在实际项目中,鸿蒙系统的分布式能力为开发跨设备协同的应用提供了更强大的支持,而Android更依赖于云服务来实现类似的功能。

- 架构差异:鸿蒙采用了分布式架构,支持多设备协作,而Android是单一设备的系统架构。
- 开发工具与语言:Android使用AndroidStudio 和 Java/Kotlin,而鸿蒙使用 DevEco Studio 和 Java/Kotlin(以及更多 C/C++ 支持)。
- UI 构建差异:Android使用传统的View和ViewGroup,而鸿蒙采用声明式 UI(类似 Jetpack Compose)。
- 跨设备能力:鸿蒙有强大的跨设备能力,通过 Ability 和 DistributedData 让应用在不同设备间协同工作,而Android通常局限于单一设备环境。
- 生命周期管理:虽然Android和鸿蒙都有类似Activity(或Ability)的生命周期管理机制,但鸿蒙更加关注跨设备和分布式生命周期的管理。

鸿蒙系统的最大特点是其跨设备协同能力和分布式应用框架,适合需要在多个设备上运行和协同工作的应用场景。Android适合单一设备的应用开发,且在移动端生态中已非常成熟。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/62836.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

计算机网络:传输层、应用层、网络安全、视频/音频/无线网络、下一代因特网

目录 &#xff08;五&#xff09;传输层 1&#xff0e;传输层寻址与端口 2&#xff0e;无连接服务与面向连接服务 3. 传输连接的建立与释放 4. UDP 的优点 5. UDP 和 TCP 报文段报头格式 6. TCP 的流量控制 7&#xff0e;TCP 的拥塞控制 8. TCP 传送连接的管理 &#…

【前端开发】HTML+CSS网页,可以拿来当作业(免费开源)

HTML代码 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content_lizhongyu"widthdevice-width, initial-scale1.0"><title>小兔鲜儿-新鲜、惠民、快捷<…

CV(4)--边缘提取和相机模型

前言 仅记录学习过程&#xff0c;有问题欢迎讨论 边缘提取&#xff08;涉及语义分割&#xff09;&#xff1a; 图象的边缘是指图象局部区域亮度变化显著的部分,也有正负之分&#xff0c;暗到亮为正 求边缘的幅度&#xff1a;sobel&#xff0c;Canny算子 图像分高频分量和低…

智能技术引领未来:自动图像标注的创新应用与发展

&#x1f351;个人主页&#xff1a;Jupiter. &#x1f680; 所属专栏&#xff1a;传知代码 欢迎大家点赞收藏评论&#x1f60a; 目录 概述算法原理核心逻辑效果演示使用方式参考文献 参考文献&#xff1a;需要本文的详细复现过程的项目源码、数据和预训练好的模型可从该地址处获…

C语言-排序

常见的排序算法分为以下四种&#xff0c;插入排序&#xff0c;选择排序&#xff0c;交换排序&#xff0c;归并排序。 一、插入排序 (一)直接插入排序 直接插入排序&#xff0c;将一段数组看做被分成已排序序列和未排序序列&#xff0c;排序过程是从未排序序列的元素开始&…

【Java笔记】LinkedList 底层结构

一、LinkedList 的全面说明 LinkedList底层实现了双向链表和双端队列特点可以添加任意元素(元素可以重复)&#xff0c;包括null线程不安全&#xff0c;没有实现同步 二、LinkedList 的底层操作机制 三、LinkedList的增删改查案例 public class LinkedListCRUD { public stati…

网管平台(基础篇):路由器的介绍与管理

路由器简介 路由器&#xff08;Router&#xff09;是一种计算机网络设备&#xff0c;它的主要作用是将数据通过打包&#xff0c;并按照一定的路径选择算法&#xff0c;将网络传送至目的地。路由器能够连接两个或更多个网络&#xff0c;并根据信道的情况自动选择和设定路由&…

排序算法(2):选择排序

问题 排序 [30, 24, 5, 58, 18, 36, 12, 42, 39] 选择排序 选择排序每次从待排序序列中选出最小&#xff08;或最大&#xff09;的元素&#xff0c;将其放到序列的起始位置&#xff0c;然后&#xff0c;再从剩余未排序元素中继续寻找最小&#xff08;或最大&#xff09;元素…

Tongweb8命令行使用收集(by lqw)

文章目录 声明对应版本修改thanos用户密码部署应用到默认实例节点相关操作新增节点(一般一个服务器ip只能装一个节点)启动节点(需确认节点没有运行)停止节点删除节点节点新增应用节点查看应用节点启动应用节点停止应用节点卸载应用(谨慎操作,卸载后应用就没有了,建议备份后…

Artec Leo3D扫描仪在重型机械设备定制中的应用【沪敖3D】

挑战&#xff1a;一家加拿大制造商需要有效的方法&#xff0c;为富于变化且难度较高的逆向工程&#xff0c;快速、安全、准确地完成重型机械几何采集。 解决方案&#xff1a;Artec Leo, Artec Studio, Geomagic for SOLIDWORKS 效果&#xff1a;Artec Leo三维扫描代替过去的手动…

题海拾贝:力扣 141.环形链表

Hello大家好&#xff01;很高兴我们又见面啦&#xff01;给生活添点passion&#xff0c;开始今天的编程之路&#xff01; 我的博客&#xff1a;<但凡. 我的专栏&#xff1a;《编程之路》、《数据结构与算法之美》、《题海拾贝》 欢迎点赞&#xff0c;关注&#xff01; 1、题…

Vite快速构建Vue教程

步骤 1: 初始化项目目录 创建一个名为 projects 的文件夹&#xff0c;作为存放所有 Vite 项目的根目录。这个文件夹将容纳多个独立的 Vite 项目。 步骤 2: 创建 Vite 项目 右键点击 projects 文件夹并选择“在此处打开终端”或使用您偏好的代码编辑器&#xff08;如 VSCode&…

深入理解 CSS 文本换行: overflow-wrap 和 word-break

前言 正常情况下&#xff0c;在固定宽度的盒子中的中文会自动换行。但是&#xff0c;当遇到非常长的英文单词或者很长的 URL 时&#xff0c;文本可能就不会自动换行&#xff0c;而会溢出所在容器。幸运的是&#xff0c;CSS 为我们提供了一些和文本换行相关的属性&#xff1b;今…

HarmonyOS 5.0应用开发——属性动画

【高心星出品】 文章目录 属性动画animateTo属性动画animation属性动画 属性动画 属性接口&#xff08;以下简称属性&#xff09;包含尺寸属性、布局属性、位置属性等多种类型&#xff0c;用于控制组件的行为。针对当前界面上的组件&#xff0c;其部分属性&#xff08;如位置属…

《探索视频数字人:开启未来视界的钥匙》

一、引言 1.1视频数字人技术的崛起 在当今科技飞速发展的时代&#xff0c;视频数字人技术如一颗璀璨的新星&#xff0c;正逐渐成为各领域瞩目的焦点。它的出现&#xff0c;犹如一场科技风暴&#xff0c;彻底改变了传统的视频制作方式&#xff0c;为各个行业带来了前所未有的机…

免费下载 | 2024算网融合技术与产业白皮书

《2024算网融合技术与产业白皮书&#xff08;2023年&#xff09;》的核心内容概括如下&#xff1a; 算网融合发展概述&#xff1a; 各国细化算网战略&#xff0c;指引行业应用创新升级。 算网融合市场快速增长&#xff0c;算力互联成为投资新热点。 算网融合产业模式逐渐成型…

基于卷积神经网络的图像二分类检测模型训练与推理实现教程 | 幽络源

前言 对于本教程&#xff0c;说白了&#xff0c;就是期望能通过一个程序判断一张图片是否为某个物体&#xff0c;或者说判断一张图片是否为某个缺陷。因为本教程是针对二分类问题&#xff0c;因此主要处理 是 与 不是 的问题&#xff0c;比如我的模型是判断一张图片是否为苹果…

RabbitMQ个人理解与基本使用

目录 一. 作用&#xff1a; 二. RabbitMQ的5中队列模式&#xff1a; 1. 简单模式 2. Work模式 3. 发布/订阅模式 4. 路由模式 5. 主题模式 三. 消息持久化&#xff1a; 消息过期时间 ACK应答 四. 同步接收和异步接收&#xff1a; 应用场景 五. 基本使用 &#xff…

前端怎么预览pdf

1.背景 后台返回了一个在线的pdf地址&#xff0c;需要我这边去做一个pdf的预览&#xff08;需求1&#xff09;&#xff0c;并且支持配置是否可以下载&#xff08;需求2&#xff09;&#xff0c;需要在当前页就能预览&#xff08;需求3&#xff09;。之前我写过一篇预览pdf的文…

滑动窗口算法专题

滑动窗口简介 滑动窗口就是利用单调性&#xff0c;配合同向双指针来优化暴力枚举的一种算法。 该算法主要有四个步骤 1. 先进进窗口 2. 判断条件&#xff0c;后续根据条件来判断是出窗口还是进窗口 3. 出窗口 4.更新结果&#xff0c;更新结果这个步骤是不确定的&#xff0c…