
strlen和sizeof作用于string通过字符串化c_str()得出的字符串结果都是一样的。所以用strlen时通过+1使得strncpy将最后一个结尾符拷贝过去了,但是用sizeof的时候没有+1,结果就没有最后的结尾符拷贝到p里面,输出没有碰到结尾符,才会乱码。
strncpy在msdn上的解释是:
当函数的第三个参数小于等于第二个参数的长度时,空字串不会被加到参数一的结尾。当函数的第三个参数大于第二个参数的长度时,参数一copy完字符串后到整个空间结束全部被置为空字符。
string自己提供了获取长度和容量的成员函数
str1.length() // 获取长度str1.capacity() // 获取容量
至于c_str()得到的东西到底是怎样的。看源码注释是说带有结尾字符的常量字符串,但是为什么在strlen和sizeof *** 作下和C语言的char数组不同这一点的确不太好解释。
你再查查其他资料,如果知道原因了,顺便也告诉下我...
“strncpy”的用法如下:
strncpy 是 C语言的库函数之一,来自 C语言标准库,定义于 string.h,char *strncpy(char *dest, const char *src, int n),把src所指向的字符串中以src地址开始的前n个字节复制到dest所指的数组中,并返回dest。
一、功能:
(c/c++)复制字符串src中的内容(字符,数字、汉字....)到字符串dest中,复制多少由size_t n的值决定。如果src的前n个字符不含NULL字符,则结果不会以NULL字符结束。如果n<src的长度,只是将src的前n个字符复制到dest的前n个字符,不自动添加'\0',也就是结果dest不包括'\0',需要再手动添加一个'\0'。如果src的长度小于n个字节,则以NULL填充dest直到复制完n个字节。src和dest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符长度+'\0'。
二、strcpy、strncpy与memcpy的区别与使用方法:
1、memcpy函数
void *memcpy(void *s1, const void *s2, size_t n)
说明:
函数memcpy从s2指向的对象中复制n个字符到s1指向的对象中。如果复制发生在两个重叠的对象中,则这种行为未定义。
返回值:函数memcpy返回s1的值。
2、strcpy函数
char *strcpy(char *s2, const char *s1)
说明:
函数strcpy把s1指向的串(包括空字符)复制到s2指向的数组中。如果复制发生在两个重叠的对象中,则这种行为未定义。
返回值:函数strcpy返回s2的值。
3、strncpy函数
char *strncpy(char *s2, const char *s1, size_t n)
说明:
函数strncpy从s1指向的数组中最多复制n个字符(不复制空字符后面的字符)到s2指向的数组中。如果复制发生在两个重叠的对象中,则这种行为未定义。如果s1指向的数组是一个比n短的字符串,则在s2定义的数组后面补空字符,直到写入了n个字符。
strncpy 不会在目标字符串末尾加 '\0' 字符。而函数的临时变量一般存储在栈中(先进后出),所以就输出了 s2 中复制的 "Today",然后输出s2数组6个字符之后的部分,即栈中的垃圾数据(未初始化的数组在内存中一般是 0xCC,就是烫烫烫),然后输出字符串 s,直到 s 中的 '\0' 字符输出结束。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)