C++常見函數使用


備注:總結C++中一些常見函數的使用,提高工作效率

數組的拼接:

    //報文頭的前6B固定
    DRV_UCHAR pkt_info_head[PALIVE_TO_NP_LEN] = {0x70, 0xff, 0x01, 0x00, (BYTE)lag_keepalive_info.chip_port, 0x00};
    set_lag_keepalive_pkt_info(lag_keepalive_info, pkt_info_head);

 

void lag_drive_adp::set_lag_keepalive_pkt_info(pkt_alive_oper_info& lag_keepalive_info, DRV_UCHAR* pkt_info_head)
{
    //給124B的報文添加6B的固定報文頭
    memcpy_s(&pkt_info_head[6], PALIVE_LAG_KA_LEN*SizeofArray(pkt_info_head), &lag_keepalive_info.pkt_info[0], PALIVE_LAG_KA_LEN*SizeofArray(lag_keepalive_info.pkt_info));
}

 PALIVE_TO_NP_LEN=130。PALIVE_LAG_KA_LEN=124上述函數在在6B的報文頭前面添加了124B的報文信息,組成130B的報文。

errno_t memcpy_s(
   void *dest,
   size_t numberOfElements,
   const void *src,
   size_t count 
);

memcpy_s的四個參數命名其實是有迷惑性的,個人的理解是,dest-目標地址,numberOfElenments-目標地址的字符個數(可使用sizeof獲取),src-源地址,count-需要拷貝的源字符個數(可使用sizeof獲取)。

numberOfElements
count  統計的是字節的個數。

注意一點:numberOfElenments必須大於等於count,否則拷貝將出現中斷。
sizeof的使用:

c/c++數組與sizeof的基礎知識

 

memset_s 

void * memset(void * dest,int ch,size_t count);
errno_t memset_s(void * dest,rsize_t destsz,int ch,rsize_t count)

 

dest

-

指向要填充的對象的指針

ch

-

填充字節

count

-

要填充的字節數

destsz

-

目標數組的大小

作用:按一個字節一個字節來給數組或者是結構體賦值的

https://blog.csdn.net/yang_zongjun/article/details/39025581

使用:

https://cloud.tencent.com/developer/section/1009614

 

C++數組長度 以及sizeof(), size(), length(), strlen()

 

 

一個INT元素是4字節合一起就是0x01010101(十六進制),就等於16843009,就完成了對一個INT元素的賦值了。所以用memset對非字符型數組賦初值是不可取的!

c語言memset詳解

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM