備注:總結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的使用:
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對非字符型數組賦初值是不可取的!