linux strlcpy strncpy strcpy 和 sprintf 以及snprintf strtok详解

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

之前的理解有误,sprintf(buf,"%s", string) // 是不安全的, 想想如果它安全 为何还要snprintf() 函数的存在

snprintf(buf,sizeof(buf),format,src) 这个函数是安全的, 即使你的size 越界了buf 他还是会再最后 补一个\0 所以他也是安全的, 不用你考虑边界。例如: snprintf(buf[8],8,"%s","1234567890") 这是buf 中存的是 "1234567\0"

strtok(str,tok)这个函数需要注意  他是 在str中搜索tok 然后 把它替换成'\0' 所以 需要注意 strstr 不能是常量  这个函数回破坏str 所以 如果你不想原来的内容被破坏 就必须copy 一个临时的str 来做strtok 操作。 如果str 是空字串并且其中没有 tok 这个符 返回结果是NULL 一定要注意,比如 char str[32]={0};  char *p = strtok(str,“|”); 这时 返回的是NULL。  如果这个str 不是空字符 那就无所谓 比如  char str[32]="|"; 或者 char str[32]="xxxx";

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值