91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

為什么有時(shí)候會(huì)寫(xiě)出爛代碼

深圳東裕光大 ? 來(lái)源:Hollis ? 作者:Hollis ? 2021-08-27 10:23 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

本文的內(nèi)容是最近我剛剛遇到的一個(gè)問(wèn)題,問(wèn)題代碼是我自己寫(xiě)的,也是我自己寫(xiě)單元測(cè)試的時(shí)候發(fā)現(xiàn)的,也是我自己修復(fù)的,修復(fù)完之后,我反思了一下:這樣的問(wèn)題代碼,我實(shí)習(xí)的時(shí)候都寫(xiě)不出來(lái)。

可是為什么我就寫(xiě)出來(lái)了呢?其實(shí)還是因?yàn)橛行┲R(shí)沒(méi)那么扎實(shí)了~就容易被忽略了,于是我在團(tuán)隊(duì)群里面強(qiáng)調(diào)了一下這個(gè)問(wèn)題:

所以,本文主要是關(guān)于BeanUtils工具的屬性拷貝以及深拷貝、淺拷貝等問(wèn)題的。好了開(kāi)始正文,介紹下問(wèn)題代碼是什么,為什么有問(wèn)題,又符合修改?

在日常開(kāi)發(fā)中,我們經(jīng)常需要給對(duì)象進(jìn)行賦值,通常會(huì)調(diào)用其set/get方法,有些時(shí)候,如果我們要轉(zhuǎn)換的兩個(gè)對(duì)象之間屬性大致相同,會(huì)考慮使用屬性拷貝工具進(jìn)行。

如我們經(jīng)常在代碼中會(huì)對(duì)一個(gè)數(shù)據(jù)結(jié)構(gòu)封裝成DO、SDO、DTO、VO等,而這些Bean中的大部分屬性都是一樣的,所以使用屬性拷貝類(lèi)工具可以幫助我們節(jié)省大量的set和get操作。

市面上有很多類(lèi)似的工具類(lèi),比較常用的有

1、Spring BeanUtils

2、Cglib BeanCopier

3、Apache BeanUtils

4、Apache PropertyUtils

5、Dozer

6、MapStucts

這里面我比較建議大家使用的是MapStructs。

最近我們有個(gè)新項(xiàng)目,要?jiǎng)?chuàng)建一個(gè)新的應(yīng)用,因?yàn)槲易约悍治鲞^(guò)這些工具的效率,也去看過(guò)他們的實(shí)現(xiàn)原理,比較下來(lái)之后,我覺(jué)得MapStruct是最適合我們的,于是就在代碼中引入了這個(gè)框架。

另外,因?yàn)镾pring的BeanUtils用起來(lái)也比較方便,所以,代碼中對(duì)于需要beanCopy的地方主要在使用這兩個(gè)框架。

我們一般是這樣的,如果是DO和DTO/Entity之間的轉(zhuǎn)換,我們統(tǒng)一使用MapStruct,因?yàn)樗梢灾付▎为?dú)的Mapper,可以自定義一些策略。

如果是同對(duì)象之間的拷貝(如用一個(gè)DO創(chuàng)建一個(gè)新的DO),或者完全不相關(guān)的兩個(gè)對(duì)象轉(zhuǎn)換,則使用Spring的BeanUtils。

剛開(kāi)始都沒(méi)什么問(wèn)題,但是后面我在寫(xiě)單測(cè)的時(shí)候,發(fā)現(xiàn)了一個(gè)問(wèn)題。

問(wèn)題

先來(lái)看看我們是在什么地方用的Spring的BeanUtils

我們的業(yè)務(wù)邏輯中,需要對(duì)訂單信息進(jìn)行修改,在更改時(shí),不僅要更新訂單的上面的屬性信息,還需要?jiǎng)?chuàng)建一條變更流水。

而變更流水中同時(shí)記錄了變更前和變更后的數(shù)據(jù),所以就有了以下代碼:

//從數(shù)據(jù)庫(kù)中查詢(xún)出當(dāng)前訂單,并加鎖 OrderDetail orderDetail = orderDetailDao.queryForLock(); //copy一個(gè)新的訂單模型 OrderDetail newOrderDetail = new OrderDetail();

BeanUtils.copyProperties(orderDetail, newOrderDetail);//對(duì)新的訂單模型進(jìn)行修改邏輯操作

newOrderDetail.update(); //使用修改前的訂單模型和修改后的訂單模型組裝出訂單變更流水

OrderDetailStream orderDetailStream = new OrderDetailStream(); orderDetailStream.create(orderDetail, newOrderDetail);

大致邏輯是這樣的,因?yàn)閯?chuàng)建訂單變更流水的時(shí)候,需要一個(gè)改變前的訂單和改變后的訂單。所以我們想到了要new一個(gè)新的訂單模型,然后操作新的訂單模型,避免對(duì)舊的有影響。

但是,就是這個(gè)BeanUtils.copyProperties的過(guò)程其實(shí)是有問(wèn)題的。

因?yàn)锽eanUtils在進(jìn)行屬性copy的時(shí)候,本質(zhì)上是淺拷貝,而不是深拷貝。

淺拷貝?深拷貝?

什么是淺拷貝和深拷貝?來(lái)看下概念。

1、淺拷貝:對(duì)基本數(shù)據(jù)類(lèi)型進(jìn)行值傳遞,對(duì)引用數(shù)據(jù)類(lèi)型進(jìn)行引用傳遞般的拷貝,此為淺拷貝。

2、深拷貝:對(duì)基本數(shù)據(jù)類(lèi)型進(jìn)行值傳遞,對(duì)引用數(shù)據(jù)類(lèi)型,創(chuàng)建一個(gè)新的對(duì)象,并復(fù)制其內(nèi)容,此為深拷貝。

我們舉個(gè)實(shí)際例子,來(lái)看下為啥我說(shuō)BeanUtils.copyProperties的過(guò)程是淺拷貝。

先來(lái)定義兩個(gè)類(lèi):

public class Address { private String province; private String city; private String area; //省略構(gòu)造函數(shù)和setter/getter } class User { private String name; private String password; private Address address; //省略構(gòu)造函數(shù)和setter/getter }

然后寫(xiě)一段測(cè)試代碼:

User user = new User(“Hollis”, “hollischuang”); user.setAddress(new Address(“zhejiang”, “hangzhou”, “binjiang”)); User newUser = new User(); BeanUtils.copyProperties(user, newUser); System.out.println(user.getAddress() == newUser.getAddress());

以上代碼輸出結(jié)果為:true

即,我們BeanUtils.copyProperties拷貝出來(lái)的newUser中的address對(duì)象和原來(lái)的user中的address對(duì)象是同一個(gè)對(duì)象。

可以嘗試著修改下newUser中的address對(duì)象:

newUser.getAddress().setCity(“shanghai”); System.out.println(JSON.toJSONString(user)); System.out.println(JSON.toJSONString(newUser));

輸出結(jié)果:

{“address”:{“area”:“binjiang”,“city”:“shanghai”,“province”:“zhejiang”},“name”:“Hollis”,“password”:“hollischuang”} {“address”:{“area”:“binjiang”,“city”:“shanghai”,“province”:“zhejiang”},“name”:“Hollis”,“password”:“hollischuang”}

可以發(fā)現(xiàn),原來(lái)的對(duì)象也受到了修改的影響。

這就是所謂的淺拷貝!

74732e18-f46d-11eb-9bcf-12bb97331649.png

如何進(jìn)行深拷貝

發(fā)現(xiàn)問(wèn)題之后,我們就要想辦法解決,那么如何實(shí)現(xiàn)深拷貝呢?

1、實(shí)現(xiàn)Cloneable接口,重寫(xiě)clone()

在Object類(lèi)中定義了一個(gè)clone方法,這個(gè)方法其實(shí)在不重寫(xiě)的情況下,其實(shí)也是淺拷貝的。

如果想要實(shí)現(xiàn)深拷貝,就需要重寫(xiě)clone方法,而想要重寫(xiě)clone方法,就必須實(shí)現(xiàn)Cloneable,否則會(huì)報(bào)CloneNotSupportedException異常。

將上述代碼修改下,重寫(xiě)clone方法:

public class Address implements Cloneable{ private String province; private String city; private String area; //省略構(gòu)造函數(shù)和setter/getter@Override public Object clone() throws CloneNotSupportedException { return super.clone();

} } class User implements Cloneable{ private String name; private String password; private Address address; //省略構(gòu)造函數(shù)和setter/getter @Override protected Object clone() throws CloneNotSupportedException { User user = (User)super.clone();

user.setAddress((Address)address.clone()); return user; } }

之后,在執(zhí)行一下上面的測(cè)試代碼,就可以發(fā)現(xiàn),這時(shí)候newUser中的address對(duì)象就是一個(gè)新的對(duì)象了。

這種方式就能實(shí)現(xiàn)深拷貝,但是問(wèn)題是如果我們?cè)赨ser中有很多個(gè)對(duì)象,那么clone方法就寫(xiě)的很長(zhǎng),而且如果后面有修改,在User中新增屬性,這個(gè)地方也要改。

那么,有沒(méi)有什么辦法可以不需要修改,一勞永逸呢?

2、序列化實(shí)現(xiàn)深拷貝

我們可以借助序列化來(lái)實(shí)現(xiàn)深拷貝。先把對(duì)象序列化成流,再?gòu)牧髦蟹葱蛄谢蓪?duì)象,這樣就一定是新的對(duì)象了。

序列化的方式有很多,比如我們可以使用各種JSON工具,把對(duì)象序列化成JSON字符串,然后再?gòu)淖址蟹葱蛄谢蓪?duì)象。

如使用fastjson實(shí)現(xiàn):

User newUser = JSON.parseObject(JSON.toJSONString(user), User.class);

也可實(shí)現(xiàn)深拷貝。

除此之外,還可以使用Apache Commons Lang中提供的SerializationUtils工具實(shí)現(xiàn)。

我們需要修改下上面的User和Address類(lèi),使他們實(shí)現(xiàn)Serializable接口,否則是無(wú)法進(jìn)行序列化的。

class User implements Serializable class Address implements Serializable

然后在需要拷貝的時(shí)候:

User newUser = (User) SerializationUtils.clone(user);

同樣,也可以實(shí)現(xiàn)深拷貝啦~!

總結(jié)

當(dāng)我們使用各類(lèi)BeanUtils的時(shí)候,一定要注意是淺拷貝還是深拷貝,淺拷貝的結(jié)果就是兩個(gè)對(duì)象中的引用對(duì)象都是同一個(gè)地址,只要發(fā)生改變,都會(huì)有影響。

想要實(shí)現(xiàn)深拷貝,有很多種辦法,其中比較常用的就是實(shí)現(xiàn)Cloneable接口重寫(xiě)clone方法,還有使用序列化+反序列化創(chuàng)建新對(duì)象。

好了,以上就是今天的全部?jī)?nèi)容了。

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4969

    瀏覽量

    74014
  • 工具
    +關(guān)注

    關(guān)注

    4

    文章

    317

    瀏覽量

    28874

原文標(biāo)題:這樣的爛代碼,我實(shí)習(xí)的時(shí)候都寫(xiě)不出來(lái)!

文章出處:【微信號(hào):sztonyu,微信公眾號(hào):深圳東裕光大】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    hpm6750 兩個(gè)板載網(wǎng)卡+usbcdc_ecm網(wǎng)卡,多次調(diào)用ftp,切換網(wǎng)卡后,報(bào)錯(cuò)

    hpm6750 兩個(gè)板載網(wǎng)卡+usbcdc_ecm網(wǎng)卡,多次調(diào)用ftp,多次切換網(wǎng)線后,出現(xiàn)報(bào)錯(cuò)pbuf_free:p->ref>0;有時(shí)候出現(xiàn)[E
    發(fā)表于 01-19 16:05

    搞笑諾貝爾:科學(xué)界的邪修盛宴

    真正的智慧有時(shí)候就藏在不為人關(guān)注的日常里
    的頭像 發(fā)表于 11-21 22:17 ?3433次閱讀
    搞笑諾貝爾:科學(xué)界的邪修盛宴

    伺服電機(jī)和步進(jìn)電機(jī)的核心區(qū)別

    大家在運(yùn)動(dòng)控制的時(shí)候是用伺服電機(jī)的還是用步進(jìn)電機(jī)做定位控制了?為什么有時(shí)候用伺服電機(jī),有時(shí)候又步進(jìn)電機(jī)?這是什么原因呢?本期我們就一起來(lái)探討一下步進(jìn)電機(jī)和伺服電機(jī)的區(qū)別!
    的頭像 發(fā)表于 10-15 14:32 ?1790次閱讀
    伺服電機(jī)和步進(jìn)電機(jī)的核心區(qū)別

    正點(diǎn)原子F407開(kāi)發(fā)板BSP RTstudio配置LVGL demo界面不能觸摸怎么解決?

    是開(kāi)啟了touch的支持,另外還增加了觸摸的復(fù)位,按下電路板的復(fù)位按鈕后,有時(shí)候可以讀取到觸摸,有時(shí)候就不行
    發(fā)表于 10-14 06:31

    代碼格式化工具Clang-Format提升你的CW32工程質(zhì)量

    它能自動(dòng)統(tǒng)一團(tuán)隊(duì)代碼風(fēng)格,讓不同開(kāi)發(fā)者寫(xiě)出代碼如出一轍。就像 CW32 官方庫(kù)函數(shù)遵循統(tǒng)一規(guī)范一樣,Clang-Format 能讓團(tuán)隊(duì)所有成員的代碼瞬間保持一致,徹底消除 "tabs
    的頭像 發(fā)表于 10-09 17:43 ?1160次閱讀
    <b class='flag-5'>代碼</b>格式化工具Clang-Format提升你的CW32工程質(zhì)量

    H743的LPUART1接收數(shù)據(jù)有時(shí)候出錯(cuò)怎么解決?

    MODBUS協(xié)議,從機(jī)回復(fù)的都是正確的。LPUART1接收到就有時(shí)不正確。 波特率9600,時(shí)鐘用的是內(nèi)部CSI。 同一塊兒板子有時(shí)出現(xiàn),有時(shí)正常。有的板子出現(xiàn),有的板子不出現(xiàn)。
    發(fā)表于 09-22 06:58

    K230芯片溫度過(guò)高會(huì)燒掉嗎?最高能到多少度呢?

    如題,K230芯片溫度過(guò)高會(huì)燒掉嗎?最高能到多少度?我有時(shí)候運(yùn)行的時(shí)候發(fā)現(xiàn)芯片溫度到70度了,會(huì)不會(huì)燒壞
    發(fā)表于 08-08 06:09

    為什么給傳感器發(fā)送命令,同樣的代碼有時(shí)候秒回應(yīng),之后就不回應(yīng)了(⊙o⊙)?

    /* 包含必要的頭文件 */ #include \"project.h\" // PSoC Creator生成的項(xiàng)目頭文件 #include <stdio.h>// 標(biāo)準(zhǔn)輸入輸出,用于sprintf等函數(shù) #include <stdint.h>// 標(biāo)準(zhǔn)整數(shù)類(lèi)型定義 #include <string.h>// 字符串操作函數(shù) /* 指令幀頭定義 */ #define CMD_HEADER_10x42 // 指令幀第一個(gè)特征字節(jié) #define CMD_HEADER_20x4D // 指令幀第二個(gè)特征字節(jié) #define CMD_STANDBY_CTRL0xF4 // 待機(jī)控制指令碼 #define STANDBY_CMD_LEN7 // 待機(jī)指令總長(zhǎng)度(字節(jié)數(shù)) /* 系統(tǒng)參數(shù)配置 */ #define STANDBY_PACKET_SIZE 24 // 預(yù)期的待機(jī)響應(yīng)數(shù)據(jù)包大小 #define CMD_RETRY_INTERVAL 220 // 指令重試間隔時(shí)間(毫秒) #define STANDBY_TIMEOUT 3000// 等待待機(jī)確認(rèn)的超時(shí)時(shí)間(毫秒) #define MAX_RETRY_COUNT 15// 最大重試次數(shù) /* 系統(tǒng)時(shí)間變量(毫秒計(jì)時(shí))*/ volatile uint32_t systemtime = 0; // 使用volatile防止編譯器優(yōu)化 /* 待機(jī)控制狀態(tài)結(jié)構(gòu)體 */ typedef struct { volatile uint8_t standbyCmdSent;// 1=已發(fā)送待機(jī)指令 volatile uint8_t standbyConfirmed;// 1=收到待機(jī)確認(rèn) volatile uint8_t retryCount;// 當(dāng)前重試次數(shù)計(jì)數(shù) uint32_t lastStandbyCmdTime;// 最后一次發(fā)送指令的時(shí)間戳 } STANDBY_CTRL; /* 全局待機(jī)控制狀態(tài)實(shí)例 */ STANDBY_CTRL standbyCtrl; /* 待機(jī)指令數(shù)據(jù)包(固定格式)*/ const uint8_t standbyCmd[STANDBY_CMD_LEN] = { CMD_HEADER_1, // 幀頭字節(jié)1 CMD_HEADER_2, // 幀頭字節(jié)2 CMD_STANDBY_CTRL,// 指令碼(待機(jī)控制) 0x00,// 數(shù)據(jù)高字節(jié)(00=待機(jī)) 0x00,// 數(shù)據(jù)低字節(jié) 0x01,// 校驗(yàn)字節(jié)1(固定值) 0x83 }; // 校驗(yàn)字節(jié)2(校驗(yàn)和) /* 發(fā)送待機(jī)指令函數(shù) / void SendStandbyCommand(void) { / 通過(guò)UART發(fā)送指令數(shù)據(jù) */ PM_UART_PutArray(standbyCmd, STANDBY_CMD_LEN); /* 更新發(fā)送狀態(tài) */ standbyCtrl.standbyCmdSent = 1; // 設(shè)置已發(fā)送標(biāo)志 standbyCtrl.lastStandbyCmdTime = systemtime; // 記錄發(fā)送時(shí)間 standbyCtrl.retryCount++; // 增加重試計(jì)數(shù)器 /* 打印調(diào)試信息 */ UART_PutString(\"CMD[\");// 輸出指令前綴 char info[10];// 臨時(shí)緩沖區(qū) sprintf(info, \"%d/%d]: \", // 格式化重試信息 standbyCtrl.retryCount, MAX_RETRY_COUNT); UART_PutString(info);// 輸出重試次數(shù) /* 打印完整指令內(nèi)容(十六進(jìn)制) */ for (uint8_t i = 0; i < STANDBY_CMD_LEN; i++) { char hex[4]; // 臨時(shí)存儲(chǔ)十六進(jìn)制字符串 sprintf(hex, \"%02X \", standbyCmd[i]);// 格式化字節(jié)為十六進(jìn)制 UART_PutString(hex); // 輸出字節(jié) } UART_PutString(\"\\\\n\"); // 換行 } /* 進(jìn)入待機(jī)模式流程控制 / void EnterStandbyMode(void) { / 重置所有狀態(tài)標(biāo)志 */ standbyCtrl.standbyCmdSent = 0;// 清除發(fā)送標(biāo)志 standbyCtrl.standbyConfirmed = 0; // 清除確認(rèn)標(biāo)志 standbyCtrl.retryCount = 0; // 重置重試計(jì)數(shù)器 /* 發(fā)送第一條待機(jī)指令 */ SendStandbyCommand(); } /* 系統(tǒng)滴答定時(shí)器中斷回調(diào)函數(shù) */ void SysTickISRCallback(void) { systemtime++;// 每毫秒遞增系統(tǒng)時(shí)間計(jì)數(shù)器 } /* UART接收中斷服務(wù)程序 / CY_ISR(UART_Sensor_Rx_Isr) { / 讀取接收到的數(shù)據(jù)字節(jié) */ uint8_t rxData = PM_UART_ReadRxData(); /* 簡(jiǎn)化處理:僅檢測(cè)響應(yīng)幀頭0x42 */ if(rxData == CMD_HEADER_1) { standbyCtrl.standbyConfirmed = 1; // 設(shè)置確認(rèn)標(biāo)志 UART_PutString(\"ACK received\\\\n\");// 打印確認(rèn)信息 } } /* 主程序入口 / int main(void) { / 硬件初始化 */ CyGlobalIntEnable;// 開(kāi)啟全局中斷 UART_Start(); // 初始化調(diào)試UART PM_UART_Start(); // 初始化傳感器UART /* 中斷配置 */ PM_UART_SetRxInterruptMode(PM_UART_RX_STS_FIFO_NOTEMPTY); // 設(shè)置接收中斷模式 PM_ISR_StartEx(UART_Sensor_Rx_Isr);// 注冊(cè)UART中斷服務(wù)程序 /* 系統(tǒng)時(shí)間初始化 */ CySysTickStart();// 啟動(dòng)系統(tǒng)滴答定時(shí)器 CySysTickSetCallback(0, SysTickISRCallback); // 注冊(cè)定時(shí)器回調(diào) /* 打印啟動(dòng)信息 */ UART_PutString(\"System Ready - Max Retry=\"); // 輸出前綴 char maxRetry[3];// 臨時(shí)緩沖區(qū) sprintf(maxRetry, \"%d\", MAX_RETRY_COUNT); // 格式化最大重試次數(shù) UART_PutString(maxRetry); // 輸出次數(shù) UART_PutString(\"\\\\n\");// 換行 /* 開(kāi)始待機(jī)流程 */ EnterStandbyMode(); // 首次進(jìn)入待機(jī)模式 /* 主循環(huán) */ for(;;) { /* 檢查指令已發(fā)送但未確認(rèn)的情況 */ if(standbyCtrl.standbyCmdSent && !standbyCtrl.standbyConfirmed) { /* 檢測(cè)是否超時(shí) */ if((systemtime - standbyCtrl.lastStandbyCmdTime) > STANDBY_TIMEOUT) { /* 判斷是否達(dá)到最大重試次數(shù) */ if(standbyCtrl.retryCount < MAX_RETRY_COUNT) { /* 未達(dá)最大次數(shù),繼續(xù)重試 */ UART_PutString(\"Timeout - \"); // 打印超時(shí)信息 SendStandbyCommand();// 重發(fā)指令 } else { /* 已達(dá)最大重試次數(shù) */ UART_PutString(\"Max retry reached. \"); // 打印錯(cuò)誤信息 UART_PutString(\"Last try delay:\");// 打印延遲信息 char delay[10];// 臨時(shí)緩沖區(qū) sprintf(delay,\"%lums\\\\n\",// 格式化延遲時(shí)間 systemtime - standbyCtrl.lastStandbyCmdTime); UART_PutString(delay); // 輸出延遲時(shí)間 /* 重置狀態(tài),5秒后重新嘗試 */ standbyCtrl.standbyCmdSent = 0;// 清除發(fā)送標(biāo)志 CyDelay(5000); // 延時(shí)5秒 EnterStandbyMode();// 重新開(kāi)始流程 } } } /* 檢查是否收到確認(rèn) */ if(standbyCtrl.standbyConfirmed) { /* 打印成功信息 */ UART_PutString(\"Standby confirmed. Total tries:\"); char tries[4];// 臨時(shí)緩沖區(qū) sprintf(tries, \"%d\\\\n\", standbyCtrl.retryCount); // 格式化嘗試次數(shù) UART_PutString(tries); // 輸出次數(shù) /* 待機(jī)確認(rèn)后的永久循環(huán) */ while(1) { CyDelay(1000); // 可在此處添加低功耗處理 } } /* 主循環(huán)延遲(降低CPU占用率) */ CyDelay(100); } }*附件:PTQS1005A-N 多合一傳感器中文規(guī)格書(shū) V1.0.pdf
    發(fā)表于 07-29 10:54

    某車(chē)聯(lián)網(wǎng)終端有時(shí)無(wú)法短信喚醒的故障分析

    某車(chē)企反饋車(chē)載物聯(lián)網(wǎng)終端4G下有時(shí)無(wú)法接收短信,導(dǎo)致車(chē)輛無(wú)法喚醒。查詢(xún)短信中心記錄,下發(fā)失敗原因有時(shí)是“用戶不在服務(wù)區(qū)”,有時(shí)是“用戶關(guān)機(jī)”。實(shí)際終端一直保持開(kāi)機(jī)狀態(tài)。
    的頭像 發(fā)表于 07-14 10:39 ?754次閱讀
    某車(chē)聯(lián)網(wǎng)終端<b class='flag-5'>有時(shí)</b>無(wú)法短信喚醒的故障分析

    請(qǐng)問(wèn)工程移植都有哪些需要注意的地方?

    ST的固件庫(kù)還是挺豐富的,有時(shí)候我們直接移植工程還是挺方便的,不過(guò)總是會(huì)有各種各樣的報(bào)錯(cuò)存在,在移植的時(shí)候有哪些需要注意的嗎?或者一些常見(jiàn)的報(bào)錯(cuò)如何解決?
    發(fā)表于 07-11 06:50

    ++和--運(yùn)算時(shí)數(shù)據(jù)在正數(shù)時(shí)計(jì)算是正確的,負(fù)數(shù)時(shí)有時(shí)候會(huì)溜掉計(jì)數(shù),為什么?

    我用STM32G4做的無(wú)刷驅(qū)動(dòng)板,用TIM3的霍爾模式來(lái)讀取電機(jī)的霍爾值,在程序里我寫(xiě)了一段計(jì)數(shù)程序,當(dāng)用手旋轉(zhuǎn)電機(jī)正轉(zhuǎn)時(shí)每次霍爾值改變計(jì)數(shù)值做++運(yùn)算,反轉(zhuǎn)時(shí)--運(yùn)算,轉(zhuǎn)動(dòng)慢的時(shí)候沒(méi)有任何問(wèn)題
    發(fā)表于 06-23 07:25

    DC紋波測(cè)試問(wèn)題

    為什么在測(cè)試DC紋波的時(shí)候,為什么有時(shí)候測(cè)出來(lái)是幾十mv,有時(shí)候測(cè)出來(lái)是20多V,是測(cè)試方法有問(wèn)題嗎,還是別的注意事項(xiàng),用的200M的帶寬
    發(fā)表于 06-08 22:00

    【經(jīng)驗(yàn)分享】玩轉(zhuǎn)FPGA串口通信:從“幻覺(jué)調(diào)試”到代碼解析

    FPGA開(kāi)發(fā),思路先行!玩FPGA板子,讀代碼是基本功!尤其對(duì)從C語(yǔ)言轉(zhuǎn)戰(zhàn)FPGA的“寶貝們”來(lái)說(shuō),適應(yīng)流水線(pipeline)編程可能需要點(diǎn)時(shí)間。上篇點(diǎn)燈代碼解讀了基礎(chǔ),而如果能親手寫(xiě)出串口通訊
    的頭像 發(fā)表于 06-05 08:05 ?1115次閱讀
    【經(jīng)驗(yàn)分享】玩轉(zhuǎn)FPGA串口通信:從“幻覺(jué)調(diào)試”到<b class='flag-5'>代碼</b>解析

    CY7C68013A跑著跑著掉線是什么原因?qū)е碌模?/a>

    RT所示,我現(xiàn)在用這顆USB芯片,跑的USB High Speed模式,在win10上會(huì)出現(xiàn)跑著跑著USB設(shè)備消失了,設(shè)備管理器中都也找不到該設(shè)備了,必須要重新插拔一下才可以,有時(shí)候1天就會(huì)出現(xiàn)一次,有時(shí)候3-4天出現(xiàn)一次。這可能是什么原因造成的?
    發(fā)表于 06-03 07:56

    使用Hal庫(kù)的SPI讀取磁邊傳感器導(dǎo)致STM32G4無(wú)法運(yùn)行怎么解決?

    ;amp; (txallowed == 1U)) 有時(shí)候可以運(yùn)行的時(shí)間長(zhǎng)一點(diǎn),有時(shí)候一下子就卡死了,網(wǎng)上找的資料也沒(méi)有說(shuō)如何解決,求大神幫忙
    發(fā)表于 03-14 08:24