分享一則向上取整的技巧
時(shí)間:2021-12-07 14:29:34
手機(jī)看文章
掃描二維碼
隨時(shí)隨地手機(jī)看文章
[導(dǎo)讀]做底層或者說(shuō)驅(qū)動(dòng)開(kāi)發(fā)時(shí),經(jīng)常會(huì)遇到一些硬件限制,比如STM32有些寄存器要求16bit訪問(wèn)、32bit訪問(wèn),否則可能引發(fā)Hardfault中斷;再比如擦除flash扇區(qū)時(shí),會(huì)要求整塊擦除。這些都是硬件決定的,必須這樣做。假設(shè)我們需要32?bit訪問(wèn)一個(gè)地址dst時(shí),如果要寫(xiě)入10...
做底層或者說(shuō)驅(qū)動(dòng)開(kāi)發(fā)時(shí),經(jīng)常會(huì)遇到一些硬件限制,比如 STM32 有些寄存器要求 16 bit 訪問(wèn)、32 bit 訪問(wèn),否則可能引發(fā) Hardfault 中斷;再比如擦除 flash 扇區(qū)時(shí),會(huì)要求整塊擦除。這些都是硬件決定的,必須這樣做。
#define SIZE (4)
if((len % SIZE) != 0) // 判斷是否整除{ len = len / SIZE 1;}else{ len = len / SIZE;}
for(int i = 0; i < len; i ){ dst [i] = src [i]; // 32 bit 訪問(wèn)} 我們可以看到,上面的寫(xiě)法是最容易想到的一種,也是新手最常寫(xiě)的,但是有經(jīng)驗(yàn)的老手會(huì)怎么寫(xiě)呢?
#define SIZE (4)
len = (len SIZE - 1) / SIZE;
for(int i = 0; i < len; i ){ dst [i] = src [i]; // 32 bit 訪問(wèn)}
#define SIZE (4)
if((len % SIZE) != 0) // 判斷是否整除{ len = len / SIZE 1;}else{ len = len / SIZE;}
for(int i = 0; i < len; i ){ dst [i] = src [i]; // 32 bit 訪問(wèn)} 我們可以看到,上面的寫(xiě)法是最容易想到的一種,也是新手最常寫(xiě)的,但是有經(jīng)驗(yàn)的老手會(huì)怎么寫(xiě)呢?
#define SIZE (4)
len = (len SIZE - 1) / SIZE;
for(int i = 0; i < len; i ){ dst [i] = src [i]; // 32 bit 訪問(wèn)}