linux strlcpy strncpy strcpy 和 sprintf 详解

再linux 下字符串处理函数尤为重要,下面我们就详细简介一下:

a) strcpy(dst,src) 这个函数是不检查边界的,他只把src copy 到dst 中如果 dst 长度不够 就会发生内存践踏,如 strcpy(buf[8],"123456789") 在这种状况下 buf 中存的就是 12345678 而buf 就没有字符串结束符了 \0 这回再字符串打印出现问题。

b) strncpy(dst,src,size)这个函数在有些情况下是会填补\0 的,但是他还是不会检查呢边界的。  一个前提是 size 的值一定是小于等于 dst的大小的。

    1. 当src 的大小比size 小时 这时会有\0 的, 应为当src 的长度不够size 时 他会用\0来补齐size 的长度的,所以这中情况下时安全的。 例如: strncpy(buf[8],"123456",8) 这是buf 存的时 "123456\0\0"

    2. 当dst 的长度与size 相等时 如果src 的长度比size 长或者相等时 这是 dst 中的字符串最后时没有\0 的。例如: strncpy(buf[8],"123456789",8) 这时buf中村的是 "12345678"

    3. 当dst 的长度比size 长时 如果src 的长度比size长时 如果dst有初始化 则字符串有结尾符 \0   。例如: strncpy(buf[8],,"12345678",7) 这是村的是 “1234567\0”

 

strlcpy(dst,src,size) 这个函数是安全的他会copy size-1 个长度的src 到dst 中,前提也是dst的长度的大于等于size,例如: strlcpy(buf[8],"123456789",8) 这时buf 中存的是"1234567\0"

sprintf(buf,size,format,src)  这个函数和strncpy 是不同的他是安全的 他会 向buf中 格式输入 size-1 的字符 并且在最后 补一个\0  l例如: sprintf(buf[8],8,"%s","1234567890") 这是buf 中存的是 "1234567\0"

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章