strncpy是标准库 <string.h>中的一个字符串操作函数,用于安全地复制指定长度的字符串。它的设计初衷是为了防止缓冲区溢出
一、函数原型
char *strncpy(char *str1, const char *str2, size_t n);
str1: 目标字符串的指针(复制后的存储位置)。
str2: 源字符串的指针(要复制的字符串)。
n: 最多复制的字符数(包括终止符 `\0`)。
二、功能说明
1. 复制最多 n个字符从 str2 到 str1。
- 如果 str2 的长度小于 n :
- 将 str2 的所有字符(包括 `\0`)复制到 str1,剩余空间用 `\0` 填充。
- 如果 str2 的长度大于或等于 n :
- 只复制前 n 个字符到 str1 ,不会自动添加 `\0`(可能导致目标字符串未终止!)。
2. 返回值:返回 str1 的指针。
三、关键注意事项
1. 不会自动添加终止符
如果 str2 的前 `n` 个字符中没有 `\0`,那么 str1 的结果字符串不会以 `\0` 结尾。这可能导致后续操作(如 strlen 或 printf)出现未定义行为。
解决方案:手动添加终止符:
str1[n - 1] = '\0'; // 确保字符串终止
2. 性能问题
如果 str2 很短,strncpy会填充多余的 `\0`,这可能影响效率。
3. 更安全的替代函数
现代C推荐使用 strlcpy(非标准但广泛支持)或 snprintf:
snprintf(dest, n, "%s", str2); // 自动处理终止符
4.与 strcpy 的区别 :
strcpy 会复制整个 str2(包括 `\0`),而 strncpy 严格按指定长度操作,行为更可控但需谨慎处理终止符。
四、 示例代码
#include <stdio.h>
#include <string.h>
int main()
{
char str2[] = "Hello, World!";
char str1[10];
// 复制最多9个字符(留1位给'\0')
strncpy(str1, str2, sizeof(str1) - 1);
str1[sizeof(str1) - 1] = '\0'; // 手动终止
printf("Copied string: %s\n", str1); // 输出 "Hello, Wo"
return 0;
}
五、何时使用?
- 当需要明确限制复制的字符数时(如固定大小的缓冲区)。
- 但务必手动处理字符串终止符,或改用更安全的函数(如 snprintf)。