主頁 > 軟體設計 > NRF52832學習筆記(33)——低功耗實作

NRF52832學習筆記(33)——低功耗實作

2020-10-15 22:55:44 軟體設計

一、功耗模式

nRF52 上只有兩種電源模式:SYSTEM_ONSYSTEM_OFF

1.1 SYSTEM_ON低功耗模式

SYSTEM_ON:此狀態有持續延遲和低功率子模式,當系統空閑進入 System On 模式時,默認情況下將處于低功耗子模式,通常最低功耗為 1.9uA (nRF52832) 或 1.5uA(nRF52840),包括 LFCLK 和 RTC,這是連接事件之間的正常狀態,CPU 在計時器、外圍設備或pin中斷時重新啟動,

1.1.1 進入SYSTEM_ON模式

當 CPU 和外圍設備處于空閑狀態時,芯片進入默認的低功耗子模式,

在主函式最后面都會出現一個 for 回圈,這個回圈不停的重復運行其中的 idle_state_handle() 函式,

int main(void)
{
    ···
    ···
    for(;;)
    {
        idle_state_handle();
    }
}

打開 idle_state_handle() 函式,該函式是處理空閑狀態的函式,通過 if 陳述句,判斷除錯緩沖區沒有更多日志的時候,就進入 nrf_pwr_mgmt_run() 函式,這個函式就會進入到低功耗模式,直到下一個事件發生,

static void idle_state_handle(void)
{
    if(NRF_LOG_PROCESS() == false)  // 如果除錯緩沖區沒有更多日志
    {
        nrf_pwr_mgmt_run();
    }
}

打開 nrf_pwr_mgmt_run() 函式,BLE 狀態下,如果 CPU 處于空閑狀態就會進入 sd_app_evt_wait() 函式,這個函式是進入低功耗的關鍵,是協議堆疊提供的一個等待事件函式,

void nrf_pwr_mgmt_run(void)
{
    PWR_MGMT_FPU_SLEEP_PREPARE();  // 清除FDU例外,避免FDU中斷被掛起
    PWR_MGMT_SLEEP_LOCK_ACQUIRE();  // 鎖定臨界區
    PWR_MGMT_CPU_USAGE_MONITOR_SECTION_ENTER();  // 用戶監視段進入,監聽進入低功耗的時間
    PWR_MGMT_DEBUG_PIN_SET();  // 置位仿真引腳

    // Wait for an event.
#ifdef SOFTDEVICE_PRESENT  // 帶協議堆疊狀態下
    if (nrf_sdh_is_enabled())  // 如果協議堆疊被使能
    {
        ret_code_t ret_code = sd_app_evt_wait();  //呼叫協議堆疊等待函式
        ASSERT((ret_code == NRF_SUCCESS) || (ret_code == NRF_ERROR_SOFTDEVICE_NOT_ENABLED));
        UNUSED_VARIABLE(ret_code);
    }
    else
#endif // SOFTDEVICE_PRESENT  // 否則,不帶協議堆疊狀態
    {
        // Wait for an event.
        __WFE();
        // Clear the internal event register.
        __SEV();
        __WFE();
    }

    PWR_MGMT_DEBUG_PIN_CLEAR();  // 清除仿真引腳
    PWR_MGMT_CPU_USAGE_MONITOR_SECTION_EXIT();  // 用戶監視段退出
    PWR_MGMT_SLEEP_LOCK_RELEASE();  // 鎖定臨界區釋放
}

1.1.2 退出SYSTEM_ON模式

通過藍牙的事件觸發芯片脫離低功耗模式,進入運行狀態,

1.2 SYSTEM_OFF睡眠模式

SYSTEM_OFF:是深省電模式,作業電流為 300nA (nRF52832) 或 400nA (nRF52840),在該模式下,系統的內核和所有在運行的任務都會停止,也就是說時鐘也停止,相當于關機狀態,可以直接控制 POWER 相關暫存器使系統進入 System OFF 模式(NRF_POWER->SYSTEMOFF = 1; ),也可以通過API函式(sleep_mode_enter() 或 nrf_pwr_mgmt_run() 此函式執行 __WFE() 指令進入睡眠前清除所有事件),可以參考 SDK 中的 nrf_pwr_mgt 例子,系統進入 System OFF 模式會保留 GPIO 之前的狀態,包括 GPIO 的輸入/輸出、I2C 總線、SPI 總線等,所以在進入 System OFF 模式前應該將 GPIO 都釋放掉,使用 nrf_gpio_cfg_default(pin)釋放 GPIO,同時,如果有 I2C 或 SPI 等總線外設也需要釋放掉;可以通過復位、GPIO 中斷或 NFC 信號(增加100nA)進行喚醒 ,從 System OFF 模式中喚醒程式會發生復位,參考 832 product spec 檔案

1.2.1 進入SYSTEM_OFF模式

在進入 System Off 模式之前,用戶必須確保所有正在進行的 EasyDMA 通信已完成,進入深度睡眠之前一定要將使用 EasyDMA 的外設停掉,

BLE 程式代碼里通過兩種方式進入,一個是廣播超時后會進入無效廣播,再進入睡眠;另外就是通過按鍵按下呼叫睡眠模式進入函式進行進入,

  • 無效廣播后進入到睡眠模式
static void on_adv_evt(ble_adv_evt_t ble_adv_evt)
{
    uint32_t err_code;

    switch(ble_adv_evt)
    {
        case BLE_ADV_EVT_FAST:
            err_code = bsp_indication_set(BSP_INDICATE_ADVERTISING);
            APP_ERROR_CHECK(err_code);
            break;
        case BLE_ADV_EVT_IDLE:
            sleep_mode_enter();  // 進入睡眠模式
            break;
        default:
            break;
    }
}
  • 按鍵按下觸發 BSP_EVENT_SLEEP 事件進入睡眠模式
static void bsp_event_handler(bsp_event_t event)
{
    ret_code_t err_code;
    switch(event)
    {
        case BSP_EVENT_SLEEP:
            sleep_mode_enter();  // 進入睡眠模式
            break;
        ···
        ···
    }
}

打開 sleep_mode_enter() 函式,觀察到函式內部主要實作配置休眠指示燈、配置喚醒按鍵,進入 System Off 睡眠模式三個功能,進入 System Off 模式的關鍵在于呼叫協議堆疊 API 函式 sd_power_system_off(),這個函式可以在協議堆疊下起到暫存器操作 NRF_POWER->SYSTEMOFF=1 一樣的效果,呼叫了這個函式后,系統將進入到睡眠模式,

static void sleep_mode_enter(void)
{
    // 設定指示燈
    uint32_t err_code = bsp_indication_set(BSP_INDICATE_IDLE);
    APP_ERROR_CHECK(err_code);

    // 配置喚醒按鍵
    err_code = bsp_btn_ble_sleep_mode_prepare();
    APP_ERROR_CHECK(err_code);

    // 進入系統關閉模式(此功能不會回傳,喚醒將導致系統重置)
    err_code = sd_power_system_off();
    APP_ERROR_CHECK(err_code);
}

1.2.2 退出SYSTEM_OFF模式

在 System Off 模式下,可以通過以下信號之一喚醒設備:

  1. DETECT 信號,可由 GPIO 外設產生,
  2. ANADETECT 信號,可由 LPCOMP 外設模塊產生,
  3. SENSE 信號,可由 NFC 模塊產生 "wake-on-field"方式產生,
  4. 復位重啟

在 BLE 程式中,提供了其中一種按鍵喚醒方式,喚醒按鍵在 sleep_mode_enter() 函式的 bsp_btn_ble_sleep_mode_prepare() 中進行配置,

uint32_t bsp_btn_ble_sleep_mode_prepare(void)
{
    uint32_t err_code;
    // 配置喚醒按鍵
    err_code = bsp_wakeup_button_enable(BTN_ID_WAKEUP);
    RETURN_ON_ERROR_NOT_NOT_SUPPORTED(err_code);
    // 配置喚醒和剔除系結資訊按鍵
    err_code = bsp_wakeup_button_enable(BTN_ID_WAKEUP_BOND_DELETE);
    RETURN_ON_ERROR_NOT_NOT_SUPPORTED(err_code);

    return NRF_SUCCESS;
}

二、硬體上降低功耗

不同的內部穩壓器選擇,會造成不同的電路消耗,可以通過選擇不同的硬體電路配置,來選取下面兩種內部穩壓器:

  • 內部 LDO 穩壓器
  • 內部 DC/DC 穩壓器

LDO 是系統默認的穩壓器,而 DC/DC 穩壓器可用作 LDO 穩壓器的替代產品,與使用 LDO 穩壓器相比,使用 DC/DC 穩壓器具有更低的電流消耗,但 DC/DC 穩壓器需要連接外部 LC 濾波器:

其中關于 DC/DC 穩壓器所連接的 外部 LC 濾波器電路上的電感和電容引數,請參看芯片手冊 53 節 Reference circuitry 所提供的參考電路,

由于默認選擇的是內部 LDO 穩壓器,因此如果需要切換到使用內部 DC/DC 穩壓器,還需要在軟體上進行配置,

  • 首先需要在主函式 main.c 中,初始化 softDevice 協議堆疊前,執行 NRF_POWER->DCDCEN=1,或者在初始化softDevice 協議堆疊后,執行 sd_power_dcdc_mode_set(1)
  • sdk_config.h 組態檔中勾選 NRFX_POWER_ENABLED 使能選項,同時把選項下的 DC/DC 使能選項 NRFX_POWER_CONFIG_DEFAULT_DCDCEN 進行勾選,

    在選取電源電壓為 3.0 V ,廣播間隔為 500ms,發射功率為 0dbm 的情況下,選擇 DC/DC 穩壓方式的總平均功耗電流為 20uA,而選擇 LDO 穩壓方式的總平均電流在 32uA 左右,因此,選擇 DC/DC 穩壓方式可以大幅度的降低功耗,

三、軟體上降低功耗

3.1 廣播狀態下功耗優化

3.1.1 發射功率

設定發射功率具有 9 個發射等級,系統默認的發射功率是 0dbm,發射功率越大,發射距離就越遠,相應的電流消耗就越大,

3.1.2 廣播間隔時間

廣播間隔就是廣播包發出的頻率,廣播間隔越長,功耗越低,

3.1.3 廣播負載

藍牙的廣播包普通包長度在 31 位元組,掃描回應包也有 31 位元組,如果藍牙 5.0 下的第二廣播包長度更長,越長的廣播負載,會造成越大的電流消耗,

3.2 連接狀態下功耗優化

3.2.1 連接間隔和從機潛伏周期

連接間隔是保證主從機維持連接,相互發空包的時間間隔,連接間隔可以在 GAP 初始化中進行設定,當設定的連接間隔越長,設備的功耗越低,因此,可以在維持連接狀態下,保證資料正常通信的基礎下,設定盡可能長的連接間隔,

從機潛伏周期和連接間隔是同時進行配置的,從機潛伏周期允許藍牙設備一定次數的周期不對藍牙主機資料進行回復,在這個周期次數范圍內,藍牙主機即使沒有收到藍牙從機設備的回復確認資訊包,也會認為設備正常,這種方式也可以降低藍牙設備的功耗,

3.2.2 發射和接收的資料量

藍牙資料發送和接收的資料量大小,直觀的影響到了功耗,資料吞吐量越大,功耗越高,

3.3 系統及外設功耗優化

3.3.1 協議堆疊時鐘選擇

協議堆疊時鐘可以選擇外部低速時鐘和內部低速時鐘,選取外部低速時鐘具有更低的功耗,使能外部 32kHz 晶振,通常可以節省 1-2% 的電能,默認使用外部低速晶振,在 main.c 檔案,ble_stack_init() 函式中 nrf_sdh_enable_request() 找到

    nrf_clock_lf_cfg_t const clock_lf_cfg =
    {
        .source       = NRF_SDH_CLOCK_LF_SRC,
        .rc_ctiv      = NRF_SDH_CLOCK_LF_RC_CTIV,
        .rc_temp_ctiv = NRF_SDH_CLOCK_LF_RC_TEMP_CTIV,
        .accuracy     = NRF_SDH_CLOCK_LF_ACCURACY
    };

.source 配置脈沖時鐘源 NRF_SDH_CLOCK_LF_SRC,默認值為 1,即外部晶振,

// <0=> NRF_CLOCK_LF_SRC_RC     // 內部時鐘源
// <1=> NRF_CLOCK_LF_SRC_XTAL  // 外部晶振源
// <2=> NRF_CLOCK_LF_SRC_SYNTH  // 合成時鐘源

#ifndef NRF_SDH_CLOCK_LF_SRC
#define NRF_SDH_CLOCK_LF_SRC 1
#endif

3.3.2 關閉日志列印

  • main.c 檔案,main() 函式中注釋掉 log_init()
  • 在 sdk_config.h 檔案中關閉 UART 日志記錄,選擇支持 RTT,除非jlink除錯器已連接,否則 RTT 不會使用電流,

3.3.3 UART/UARTE

首先 UART 模塊本身只需要 55uA 的作業電流,同時會自動打開高頻時鐘電路,也需要消耗 250uA 左右電流,如果使能了 UARTE 的 EasyDMA,那么 DMA 還需要消耗額外的 2mA 電流,這樣 UARTE 作業消耗的電流會很高,因此在 UART 沒有資料傳輸的時候建議將 UART 關掉,以節省功耗,

  • 注:為了達到低功耗和實時性雙重目的,在設計 UART 通信的時候,我們經常會額外再加 2 個 GPIO 口用來通知對方 UART 要傳送資料了,
  • 關閉 UART 的 API 為:nrf_drv_uart_uninit() 或者 app_uart_close()

3.3.4 SPI/TWI

在不使用的時候建議采用 uninit 函式進行關閉,這部分的外設也消耗電流,需要使用的時候進行 init 初始化開啟,

  • SPI 開啟和關閉:nrf_drv_spi_initnrf_drv_spi_uninit
  • TWI 開啟和關閉:nrf_drv_twi_enablenrf_drv_twi_disable

3.3.5 SAADC

在不使用的時候建議采用 uninit 函式進行關閉,需要使用的時候進行 init 初始化開啟,

  • ADC 開啟和關閉:nrfx_saadc_initnrfx_saadc_uninit
  • 如果你發現 uninit ADC 后,功耗還是很高,建議打開這個宏 NRFX_SAADC_CONFIG_LP_MODE,再試一下,功耗有可能就降下來了,
  • 官方SAADC低功耗例子 https://github.com/NordicPlayground/nRF52-ADC-examples/tree/master/saadc_low_power

3.3.6 GPIOE

GPIOE 事件模式下具有兩鐘模式:高精度模式(hi_accuracy 為 true)和低精度模式(hi_accuracy 為 false),高精度模式 IN event 中斷比低精度模式 Port event 中斷消耗更多的電流 10~20uA,如果只是檢測 IO 口電平,建議使用低精度模式,也就是所有的輸入信號都使用一個中斷申請,庫函式呼叫配置:
GPIOTE_CONFIG_IN_SENSE_HITOLO(false);

3.3.7 Timer

Timer0/1/2/3/4,Timer 的作業電流大概為 5~50uA 左右(nRF51功耗會更高),對低功耗應用來說,已經非常大了,如果你的定時精度要求不高,而且是毫秒的倍數,那么強烈建議你使用 RTC 來實作定時功能,協議堆疊下為 app_timer 軟體定時器,app_timer 的功耗只有 0.2uA 左右,

3.3.8 FPU

由于 nRF52x 系列處理器不同于 nRF51 系列,其內核為 ARM Cortex M4 處理器,ARM Cortex M4 處理器 帶 FPU 浮點運算單元,每當程式要執行浮點運算的時候,內核就會自動把 FPU 打開i,FPU 將消耗 7mA 以上的電流,此種情況下,進入 idle 模式之前必須手動關閉 FPU,手動關閉 FPU 代碼如下所示:

/* Clear FPSCR register and clear pending FPU interrupts. This code is base on

         * nRF5x_release_notes.txt in documentation folder. It is necessary part of code when

         * application using power saving mode and after handling FPU errors in polling mode.

*/

__set_FPSCR(__get_FPSCR() & ~(FPU_EXCEPTION_MASK));

(void) __get_FPSCR();

NVIC_ClearPendingIRQ(FPU_IRQn);

在新版本 SDK 中 idle_state_handle() 已經加了處理

四、電量消耗預估

https://devzone.nordicsemi.com/power/


? 由 Leung 寫于 2020 年 10 月 14 日

? 參考:青風電子社區
    板子功耗高的原因有哪些
    nRF52 Power優化降低70%以上耗電量

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/173286.html

標籤:其他

上一篇:工業互聯網平臺的“業務作業系統”

下一篇:在Express中獲取表單GET請求引數和POST請求體資料

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more