再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";