Android Init系统:引领设备启动的先锋

Android Init系统:引领设备启动的先锋

引言

Init系统是一个操作系统启动的必要组件,负责在启动时初始化所有系统资源、服务和应用程序。在Android设备中,Init系统起到了至关重要的作用,它是启动过程中的第一个进程,负责启动和管理其他所有进程和服务。此外,Init系统还具有系统资源配置、故障恢复和定制化等重要功能。

Init系统最初是由Unix系统引入的,在Linux操作系统中得到广泛应用。随着移动设备的普及,Android系统的出现使得Init系统得到了更广泛的应用。在不断的发展和演变中,Init系统从最初的简单脚本演变为现在的完整程序,其功能也逐渐丰富和完善。同时,随着硬件技术的不断进步和设备需求的不断增加,Init系统也面临着新的挑战和机遇。

下面,我们将详细介绍Init系统在Android设备中的具体作用和实现方式,以便更好地了解Init系统的演变和发展背景。

Init系统概览

A. Init的定义和功能

Init系统是一个用户空间进程,它在Android设备启动时负责初始化系统资源、服务和应用程序。它是系统启动过程中的第一个进程,负责启动和管理其他所有进程和服务。Init系统的主要功能包括:

  1. 启动和管理进程:根据配置文件中定义的启动级别,Init系统按照一定顺序启动各个进程和服务,并管理它们的生命周期。
  2. 配置系统资源:通过配置文件中的命令,Init系统可以对系统资源进行灵活的配置和分配,如内存、磁盘、网络等。
  3. 处理故障恢复:Init系统能够检测和处理系统故障,如文件系统错误、崩溃等,并尽可能恢复系统正常状态。
  4. 定制化和扩展性:Init系统支持设备定制化,通过修改配置文件或添加新的配置文件,满足不同设备的需求。
  5. 调试和日志记录:Init系统提供了调试工具和机制,方便开发者排查问题和优化性能。

B. 设备启动过程

在Android设备启动过程中,Init系统是第一个被启动的进程。当设备开机后,硬件会运行预启动程序,然后加载内核和根文件系统。接着,系统调用Init系统来开始启动过程。Init系统按照配置文件的定义,逐个启动各个进程和服务,直到系统完全启动。

设备启动过程的关键步骤和执行流程如下:

  1. 预启动阶段:硬件运行预启动程序,确保系统能够正确启动。
  2. 内核加载:加载内核和根文件系统到内存中。
  3. Init系统启动:调用Init系统作为第一个用户空间进程启动。
  4. 加载配置文件:Init系统读取并解析配置文件,如init.rc文件。
  5. 启动进程和服务:根据配置文件中定义的启动级别,Init系统依次启动各个进程和服务。
  6. 系统完全启动:所有进程和服务启动完成后,系统进入正常运行状态。

C. 配置文件

在Android设备中,Init系统的配置信息存储在一个或多个配置文件中,其中最主要的是init.rc文件。配置文件中包含一系列命令和参数,用于指示Init系统如何启动和管理系统进程和服务。常见的配置文件和其作用如下:

  1. init.rc:主要的配置文件,定义了启动级别、服务和进程的启动命令、属性和优先级等。
  2. ueventd.rc:配置设备事件处理规则,如设备插拔、网络连接等。
  3. fstab.*:不同设备上的分区挂载规则,如/system、/data等。
  4. selinux.rc:配置SELinux安全策略。

以下是一个示例init.rc文件的部分内容:

import /init.environ.rc
import /init.usb.rc

service servicemanager /system/bin/servicemanager
    class core
    user system
    group system
    onrestart restart zygote

以上提供了Init系统概览的相关内容,详细介绍了Init系统在Android设备中的定义、功能、设备启动过程和常用配置文件。这些信息可以帮助读者更好地理解和应用Init系统在Android设备中的作用。

启动级别与服务管理

A. 启动级别

启动级别是Init系统中的一个重要概念,它定义了系统启动过程中各个进程和服务的启动顺序和优先级。通过配置文件中的启动级别,可以灵活地控制系统启动的顺序和依赖关系,确保系统能够正确地启动和运行。

在Android系统中,启动级别通过数字表示,数字越小表示优先级越高。以下是常见的几个启动级别:

  1. 启动级别0:用于关机,系统将进入关机状态。
  2. 启动级别1:用于单用户模式,只启动基本的系统进程和服务,不加载应用程序。
  3. 启动级别2:用于加载大多数系统服务,但不包括图形界面。
  4. 启动级别3:用于加载所有系统服务,包括图形界面。
  5. 启动级别4-9:可供用户自定义使用,可以根据需要配置启动级别。

配置启动级别的方式是通过init.rc配置文件中的"on"命令来指定,例如:

on early-boot
    start servicemanager
    start zygote

以上示例代码指定了在"early-boot"阶段启动"servicemanager"和"zygote"进程,表示这两个进程具有较高的启动优先级。

B. 服务管理

Init系统也负责管理和控制系统的各个服务。通过配置文件中的命令,可以定义服务的启动、停止和重启等操作。

  1. 启动服务:使用"start"命令可以启动指定的服务。例如:
service servicemanager /system/bin/servicemanager
    class core
    user system
    group system
    onrestart restart zygote

以上示例代码定义了一个名为"servicemanager"的服务,指定了其可执行文件路径、所属类别、用户和组等信息。当该服务启动时,会执行指定的可执行文件。

  1. 停止服务:使用"stop"命令可以停止指定的服务。例如:
on property:sys.boot_completed=1
    stop servicemanager

以上示例代码在系统完成启动后,停止名为"servicemanager"的服务。

  1. 重启服务:使用"restart"命令可以重启指定的服务。例如:
service zygote /system/bin/app_process64 -Xzygote /system/bin --zygote --start-system-server
    class main
    socket zygote stream 660 root system
    onrestart restart media

以上示例代码定义了一个名为"zygote"的服务,并指定了在该服务重启时要执行的操作,即重启"media"服务。

通过配置文件中的上述命令,Init系统可以有效地管理和控制系统的各个服务的启动、停止和重启等操作,保证系统的正常运行。

本章节介绍了Init系统中的启动级别和服务管理机制。启动级别通过数字表示,用于定义系统启动过程中各个进程和服务的启动顺序和优先级。配置文件中的命令可以实现对服务的启动、停止和重启等操作,确保系统的正常运行。通过灵活配置启动级别和服务管理,可以满足不同设备的需求,并提高系统的稳定性和性能。

以上是对启动级别与服务管理的简要介绍,希望能够帮助读者更好地理解和应用Init系统在Android设备中的作用。

初始化和资源配置

A. 硬件初始化

在设备启动时,Init系统负责对硬件进行初始化。这是设备正常运行的前提条件,如果硬件没有正确初始化,设备将无法启动或者无法正常工作。

硬件初始化的具体过程和方法因设备而异,通常需要依靠设备厂商提供的相应文档和代码来实现。一般来说,硬件初始化主要包括以下几个方面:

  1. 电源管理:初始化电源管理模块,确保各个组件能够正常供电。
  2. 外设初始化:初始化各种外设,例如显示屏、摄像头、传感器等。
  3. 存储初始化:初始化存储器,包括内部存储和外部存储。在Android系统中,还需要对存储器进行挂载和格式化等操作。
  4. 网络初始化:初始化网络模块,确保设备可以正常连接互联网和其他设备。
  5. 其他:根据设备的特殊需求进行其他初始化操作。

以下是一个简单的初始化示例代码,用于启动硬件加速:

on early-init
    write /sys/class/kgsl/kgsl-3d0/max_pwrlevel 1
    write /sys/class/kgsl/kgsl-3d0/default_pwrlevel 6
    start vendor.accelerator-hal-2-0

以上代码使用"write"命令写入设备文件,启动硬件加速模块,提高设备的图形处理能力。

B. 资源配置

在设备启动后,Init系统还负责对系统资源进行配置和分配。资源包括内存、CPU、网络带宽等,这些资源需要被合理地分配和使用,以确保系统的稳定性和性能。

资源配置的方式通常是通过配置文件中的命令实现的。以下是一些常见的资源配置命令:

  1. 设置内存大小:使用"meminfo"命令可以设置系统内存的大小。例如:
on early-init
    write /sys/kernel/mm/ksm/run 1
    meminfo 1024M

以上代码将系统内存设置为1GB,并启用内存共享功能。

  1. CPU调度策略:使用"schedtune.boost"命令可以调整CPU调度策略,提高系统响应速度。例如:
service media {
    class main
    oneshot
    exec /system/bin/mediaserver
    schedtune.boost 1
}

以上代码启动mediaserver服务,并设置其CPU调度优先级为1。

  1. 网络带宽限制:使用"netctrl"命令可以限制特定应用程序的网络带宽使用量。例如:
service com.android.mms {
    class main
    user mms
    group mms
    capabilities NET_ADMIN
    exec /system/bin/app_process32 /system/priv-app/MmsService/MmsService.apk com.android.mms.service.MmsService
    netctrl nano -1 1000000
}

以上代码限制了MmsService应用程序的网络带宽使用量为1Mbps。

通过以上命令,Init系统可以对系统资源进行合理的配置和分配,提高系统的稳定性和性能,保障设备的正常运行。

本章节介绍了Init系统在设备启动时对硬件进行初始化的过程和方法,以及对系统资源的配置和分配方式。硬件初始化是设备正常运行的前提条件,资源配置则需要合理地分配和使用系统资源,以确保系统的稳定性和性能。通过灵活配置硬件初始化和资源配置,可以满足不同设备的需求,并提高系统的稳定性和性能。

故障恢复与调试

A. 故障恢复

在设备运行过程中,可能会发生各种故障,例如软件崩溃、硬件故障或者其他异常情况。Init系统在这些故障发生时,负责采取相应的措施进行恢复,以确保设备能够继续正常运行。

  1. 进程重启:当某个关键进程崩溃或异常退出时,Init系统可以根据事先配置的策略,自动重启该进程。这样可以避免因单个进程故障导致整个系统不可用。

以下是一个简单的示例代码,用于配置进程自动重启:

service myservice {
    class main
    user system
    group system
    oneshot
    exec /system/bin/myservice
    restart on-crash
}

以上代码定义了一个名为"myservice"的服务,当该服务所对应的进程崩溃时,Init系统会自动重新启动该进程。

  1. 硬件重置:在遇到硬件故障或异常情况时,Init系统可以通过硬件重置操作来尝试修复问题。例如,当设备检测到存储器错误时,Init系统可以通过重置存储器控制器来尝试解决问题。

以下是一个简单的示例代码,用于配置硬件重置:

on init
    trigger /dev/memtest {
        class core
        exec /system/bin/hwreset
    }

以上代码定义了一个名为"memtest"的触发器,在设备初始化时会执行"/system/bin/hwreset"命令来重置硬件。

B. 调试工具

在开发和调试过程中,Init系统也提供了一些常用的工具和技术,用于排查问题和优化性能。

  1. 日志记录:Init系统可以将关键信息和错误日志记录到日志文件中,以便开发人员查看和分析。通过查看日志,可以追踪问题源头并进行故障排除。

以下是一个示例代码,用于配置日志记录:

on init
    loglevel 5
    log -t INIT "Init system started"
    ...

以上代码设置日志级别为5,并在设备初始化时记录一条日志。

  1. 调试模式:Init系统支持调试模式,可以在启动时开启该模式,以便开发人员进行调试操作。调试模式可以打开更多详细的日志输出,并允许通过adb命令与Init系统进行交互。

以下是一个示例代码,用于配置调试模式:

on init
    setprop init.debug 1
    ...

以上代码在设备初始化时设置了一个名为"init.debug"的属性,将调试模式开启。

通过以上的故障恢复和调试工具,开发人员可以更好地排查问题、进行故障恢复,并对Init系统进行性能优化。

本章节介绍了Init系统中的故障恢复机制和策略,以及常用的调试工具和技术。通过自动重启进程和硬件重置等故障恢复方法,Init系统确保设备在故障情况下能够继续正常运行。同时,通过日志记录和调试模式等工具和技术,开发人员可以更好地排查问题和优化性能。

定制化和扩展性

A. 设备定制化

Init系统在Android设备中的灵活性和可定制化能力非常重要,它可以根据不同设备的需求进行定制和配置,以确保设备能够满足特定的功能和性能要求。

  1. 启动流程定制:Init系统允许开发人员根据设备需求来定制启动流程。通过修改Init配置文件,可以添加或删除启动服务、修改进程优先级等操作,从而优化设备的启动速度和性能。

以下是一个示例代码,用于定制启动流程:

on init
    start myservice
    ...

以上代码定义了一个名为"myservice"的服务,在设备初始化时会启动该服务。

  1. 属性设置:Init系统支持属性设置,开发人员可以根据设备需要设置不同的属性值。这些属性可以被其他组件或进程读取,从而影响设备的行为和功能。

以下是一个示例代码,用于属性设置:

on init
    setprop myproperty 1
    ...

以上代码设置了一个名为"myproperty"的属性,值为1。

B. 扩展性与模块化

Init系统的设计具有良好的扩展性和模块化特性,这使得它能够支持新功能和硬件的集成。通过添加新的服务和触发器,开发人员可以扩展Init系统的功能,以满足不断变化的需求。

  1. 新服务添加:开发人员可以通过添加新的服务来扩展Init系统的功能。这些服务可以执行各种任务,例如启动应用程序、配置网络连接等。

以下是一个示例代码,用于添加新服务:

service mynewservice {
    class main
    user system
    group system
    oneshot
    exec /system/bin/mynewservice
}

以上代码定义了一个名为"mynewservice"的服务,可以执行"/system/bin/mynewservice"命令。

  1. 新触发器添加:除了服务,开发人员还可以添加新的触发器来扩展Init系统的功能。这些触发器可以根据特定事件的发生来执行相应的操作。

以下是一个示例代码,用于添加新触发器:

on property:myproperty=1
    trigger mytrigger {
        class core
        exec /system/bin/myaction
    }

以上代码定义了一个名为"mytrigger"的触发器,在属性"myproperty"的值为1时会执行"/system/bin/myaction"命令。

通过以上的设备定制化和扩展性特性,Init系统能够适应不同设备的需求,并支持新功能和硬件的集成。开发人员可以根据具体情况灵活配置Init系统,以满足设备的定制化需求。

本章节介绍了Init系统的定制化和扩展性能力。通过设备定制化和灵活的配置,Init系统可以满足不同设备的需求。同时,通过扩展新的服务和触发器,Init系统支持新功能和硬件的集成。这些特性使得Init系统成为Android设备中关键的组件之一。

未来发展趋势

A. 启动速度优化:概述Init系统在启动速度优化方面的挑战和趋势

启动速度是用户体验中至关重要的一部分,而Init系统在启动过程中扮演着关键角色。为了提高设备的启动速度,Init系统需要应对以下挑战并抓住未来的发展机遇。

  1. 并行化操作:随着硬件性能的提升,Init系统可以利用多核处理器的并行计算能力,同时执行多个任务,从而加快启动速度。通过将启动过程中的各个阶段进行并行化,如设备初始化、服务启动等,可以显著缩短启动时间。

示例代码:

on init
    start myservice1 &
    start myservice2 &
    start myservice3 &
    wait

以上代码使用并行化操作,同时启动了三个名为"myservice1"、"myservice2"和"myservice3"的服务,并通过"wait"命令等待它们全部完成。

  1. 延迟加载:Init系统可以通过延迟加载一些不必要立即启动的服务或组件,来减少启动过程中的负载和时间消耗。这样可以快速进入系统界面,而将某些服务的启动时间推迟到后台,提高整体启动速度。

示例代码:

on post-fs
    start myservice1
    ...

以上代码将服务"myservice1"的启动时间延迟到文件系统加载完成后。

B. 虚拟化与容器化:探索虚拟化和容器化对Init系统的未来发展带来的影响和机遇

虚拟化和容器化技术在操作系统领域得到了广泛应用,并为Init系统的未来发展带来了新的机遇和挑战。

  1. 虚拟化:虚拟化技术可以将物理资源抽象为虚拟资源,并通过虚拟机实例来管理和调度这些资源。对于Init系统而言,虚拟化技术可以提供更好的隔离性和资源管理能力,使不同应用或服务之间相互独立运行,提高系统的安全性和稳定性。

  2. 容器化:容器化技术可以将应用程序及其依赖项封装为一个独立的运行环境,从而实现应用程序的快速部署和扩展。对于Init系统而言,容器化技术可以简化应用程序的启动过程,并提供更好的资源利用率和灵活性。

示例代码:

on init
    start containerd
    ...

以上代码启动了一个名为"containerd"的容器引擎,用于管理和执行容器化应用程序。

通过虚拟化和容器化技术,Init系统可以更好地适应多样化的应用场景和需求,提高系统的可扩展性和灵活性。

本章节探讨了Init系统在未来发展趋势方面的两个关键问题:启动速度优化和虚拟化与容器化。通过并行化操作和延迟加载等方法,Init系统可以进一步提高设备的启动速度,提供更好的用户体验。同时,虚拟化和容器化技术为Init系统带来了新的机遇和挑战,包括更好的资源管理能力和灵活性。这些发展趋势将为Init系统的未来发展开辟更广阔的空间。

结论

A. 总结Init系统在Android设备启动中的关键作用

本文回顾了Init系统在Android设备启动过程中的关键作用。作为第一个用户空间进程,Init系统负责启动和管理其他系统组件和服务,协调各个阶段的初始化和配置工作。它承担了初始化硬件、加载驱动程序、启动服务和应用程序等重要任务,是Android系统启动过程的核心。

通过对启动序列的分析,我们可以看到Init系统在以下方面发挥了关键作用:

  1. 设备初始化和配置:Init系统负责初始化设备硬件,并加载适当的驱动程序和内核模块。它还负责设置系统参数和环境变量,为后续的启动过程做好准备。

示例代码:

on boot
    # 初始化硬件
    init_hardware
    
    # 加载驱动程序
    insmod driver.ko
    
    # 设置环境变量
    export PATH=/system/bin:$PATH
  1. 服务和应用程序的启动:Init系统负责启动系统服务和应用程序,使它们可以在设备启动完成后正常运行。它根据配置文件中定义的顺序和依赖关系,按照指定的方式启动各个服务和应用程序,并监控它们的运行状态。

示例代码:

on post-fs
    # 启动系统服务
    start servicemanager
    
    # 启动应用程序
    start com.android.launcher

B. 强调持续创新和合作的重要性,为提升Android设备启动体验做出贡献

为了不断提升Android设备的启动体验,持续创新和合作是至关重要的。Init系统开发者和Android社区应积极探索和采纳新的技术和方法,以满足用户对更快速、更顺畅启动体验的需求。

  1. 性能优化:借助硬件的不断演进和软件的优化,Init系统可以进一步提高启动速度和效率。通过并行化操作、延迟加载和异步处理等技术,可以显著缩短启动时间,让用户更快地进入系统界面。

  2. 虚拟化和容器化:虚拟化和容器化技术为Init系统的发展带来了新的机遇。通过利用虚拟化和容器化技术,可以实现更好的资源管理和隔离性,提高系统的安全性和稳定性。

  3. 开放合作:Init系统开发者和Android社区应积极参与开源项目,分享经验和资源,共同推动Init系统的发展。通过合作与交流,可以汇聚更多的智慧和力量,为改进Android设备的启动体验做出更大贡献。

通过本文的探讨,我们深入了解了Init系统在Android设备启动中的关键作用,并强调了持续创新和合作的重要性。不断优化Init系统的性能、探索新的技术和方法,将为提升Android设备的启动体验作出积极的贡献。我们期待未来Init系统能够继续发展壮大,为用户带来更好的启动体验。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

C++分数计算器

C分数计算器各种分数计算类型都能计算 代码:https://mbd.pub/o/bread/ZZeZk5hx 一 目的 (1)定义一个整数类。 定义一个分数类,由整数类派生。能对分数进行各种计算和输入/输出。可进行分数的加、减、乘和除法等四则运算。 流程…

YOLOv8 区域计数 | 入侵检测 | 人员闯入

大家好,昨天的 YOLOv8 新增加了一个功能,区域计数,用这个功能我们能实现很多的任务, 比如入侵检测,流量统计,人员闯入等,使用方式也非常的方便,但是一定要使用最新版的 YOLOv8 代码(2023/12/03更新的代码)。 低版本是不具备这个功能的,上面是演示效果。 使用非常的方…

Leetcode2661. 找出叠涂元素

Every day a Leetcode 题目来源:2661. 找出叠涂元素 解法1:哈希 题目很绕,理解题意后就很简单。 由于矩阵 mat 中每一个元素都不同,并且都在数组 arr 中,所以首先我们用一个哈希表 hash 来存储 mat 中每一个元素的…

C语言中的动态内存管理

在C语言中,动态内存管理是通过一系列的标准库函数来实现的,这些函数包括malloc, free, calloc 和 realloc。它们允许程序在运行时动态地分配和释放内存,这是管理复杂数据结构(如链表、树等)时非常有用的功能。 为什么…

软件生命周期四个阶段SDLC

软件产品生命周期:指软件产品研发全部过程、活动和任务的结构框架。 产品的生命周期一般包括四个阶段:引入期、成长期、成熟期和衰退期,在不同的阶段中,市场对产品的反应不同,其销售特点不同,因而产品管理的…

【强化学习算法】Q-learning原理及实现

实现代码github仓库:RL-BaselineCode 代码库将持续更新,希望得到您的支持⭐,让我们一起进步! 文章目录 1. 原理讲解1.1 Q值更新公式1.2 ε-greedy随机方法 2. 算法实现2.1 算法简要流程2.2 游戏场景2.3 算法实现 3. 参考文章 1. 原…

数据挖掘实战-基于word2vec的短文本情感分析

🤵‍♂️ 个人主页:艾派森的个人主页 ✍🏻作者简介:Python学习者 🐋 希望大家多多支持,我们一起进步!😄 如果文章对你有帮助的话, 欢迎评论 💬点赞&#x1f4…

专业爬虫框架 -- scrapy初识及基本应用

scrapy基本介绍 Scrapy一个开源和协作的框架,其最初是为了页面抓取 (更确切来说, 网络抓取 )所设计的,使用它可以以快速、简单、可扩展的方式从网站中提取所需的数据。 但目前Scrapy的用途十分广泛,可用于如数据挖掘、监测和自动化测试等领域…

HCIP —— 双点重发布 + 路由策略 实验

目录 实验拓扑: 实验要求: 实验配置: 1.配置IP地址 2.配置动态路由协议 —— RIP 、 OSPF R1 RIP R4 OSPF R2 配置RIP、OSPF 双向重发布 R3配置RIP、OSPF 双向重发布 3.查询路由表学习情况 4.使用路由策略控制选路 R2 R3 5.检…

【Google2023】利用TiDE进行长期预测实战(时间序列密集编码器)

一、本文介绍 大家好,最近在搞论文所以在研究各种论文的思想,这篇文章给大家带来的是TiDE模型由Goggle在2023.8年发布,其主要的核心思想是:基于多层感知机(MLP)构建的编码器-解码器架构,核心创…

GEE:梯度卷积

作者:CSDN @ _养乐多_ 本文将介绍在 Google Earth Engine(GEE)平台上,进行梯度卷积操作的代码框架、核心函数和多种卷积核,比如 Roberts、Prewitt、Sobel、各向同性算子、Compass算子、拉普拉斯算子、不同方向线性检测算子等。 结果如下图所示, 文章目录 一、常用的梯度…

实现一个简单的网络通信下(udp)

时间过去好久了,先回忆一下上一篇博客的代码!! 目前来看,我们客户端发一条消息,我服务器收到这一条消息之后呢,服务器也知道了是谁给我发来的消息,紧接这就把这条消息放进buffer当中&#xff0c…

POJ 3734 Blocks 动态规划(矩阵的幂)

一、题目大意 我们要给排成一行的区块涂颜色,可以选择红、绿、蓝、黄四种,要求红和绿的块都必须是偶数个,求出最终的涂色方式,对10007取余。 二、解题思路 我们设三个数列A,B和C: 1、A代表红色和绿色都…

百度收录批量查询工具,免费SEO优化排名工具

拥有一个在搜索引擎中得到良好收录的网站对于个人和企业都至关重要。而百度,作为中国最大的搜索引擎,其收录情况直接影响着网站的曝光度和流量。 百度搜索引擎是中文用户获取信息的重要途径之一。而在这个竞争激烈的网络环境中,了解自己网站…

QT 中 QTimer 类 备查

基础 // 指定了父对象, 创建的堆内存可以自动析构 QTimer::QTimer(QObject *parent nullptr);// 根据指定的时间间隔启动或者重启定时器, 需要调用 setInterval() 设置时间间隔 void QTimer::start();// 启动或重新启动定时器,超时间隔为msec毫秒。 void QTimer::…

游泳馆会员服务预约管理系统预约小程序效果如何

游泳馆在各地每天都有大量用户前往,夏季室外、冬季室内也是学习游泳技术和休闲娱乐的好地方,而消费者大多是年轻人和家长带的孩子,这部分群体更显年轻化,因此在如今互联网环境下,传统商家需要进一步赋能客户消费路径。…

共识问题:区块链如何确认记账权?

区块链可以说是最近几年最热的技术领域之一,区块链起源于中本聪的比特币,作为比特币的底层技术,本质上是一个去中心化的数据库,其特点是去中心化、公开透明,作为分布式账本技术,每个节点都可以参与数据库的…

力扣 --- 最长公共前缀

题目描述: 编写一个函数来查找字符串数组中的最长公共前缀。 如果不存在公共前缀,返回空字符串 ""。 示例 1: 输入:strs ["flower","flow","flight"] 输出:"fl"…

蓝桥杯物联网竞赛_STM32L071_8_ADC扩展模块

原理图: 扩展模块原理图: RP1和RP2分别对应着AIN1和AIN2,扭动它们,其对应滑动变阻器阻值也会变化 实验板接口原理图: 对应实验板接口PB1和PB0 即AN1对应PB1, AN2对应PB0 CubMx配置: ADC通道IN8和IN9才对…

Spring MVC学习随笔-控制器(Controller)开发详解:控制器跳转与作用域(二)视图模板、静态资源访问

学习视频:孙哥说SpringMVC:结合Thymeleaf,重塑你的MVC世界!|前所未有的Web开发探索之旅 衔接上文Spring MVC学习随笔-控制器(Controller)开发详解:控制器跳转与作用域(一) SpingMVC中…