在对缓冲区(一般为数组)进行拷贝前,要保证复制的长度不要超过缓冲区的空间大小。比如在 memcpy 前,要检查目的地址是否有足够的空间。
使用宏或 sizeof 可保证缓冲长度的一致性:
char dst_buf[64]; memcpy(dst_buf, src_buf,64)
当缓冲大小改变为 32 的时候,需要改动两处代码。一旦忘记修改 memcpy 处的拷贝长度,就会造成内存越界。
对上面的代码进行改善
#define BUF_SIZE 64 char dst_buf[BUF_SIZE]; memcpy(dst_buf, src_buf, BUF_SIZE);
或
char dst_buf[64]; memcpy(dst_buf, src_buf, sizeof(dst_buf));
这样就可以做到缓存大小和复制长度的同步修改。
使用安全的库函数也可以保证复制的长度不超过缓冲区的空间,下面来介绍 4 种库函数。
原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/289670.html