【面试题】C语言:模拟实现strncpy,尝试比较strncpy与strcpy区别。
2016-05-30 17:15
411 查看
比较strncpy与strcpy联系:
两者均为字符串拷贝函数,用于拷贝字符串。
[b]比较strncpy与strcpy区别:[/b]
strcpy比较时找字符串结束标志‘\0’,一旦找到 ‘\0’,比较结束。而后者我们可以根据实际情况完成指定长度n的字符串拷贝,因此函数strcpy里面多了一个字母n,即strncpy.由此,从此处看strncpy比strcpy功能强大一点。
关于strcpy可以查看我的博客链接:/article/4218930.html
strncpy代码如下:
本文出自 “Han Jing's Blog” 博客,请务必保留此出处http://10740184.blog.51cto.com/10730184/1715679
两者均为字符串拷贝函数,用于拷贝字符串。
[b]比较strncpy与strcpy区别:[/b]
strcpy比较时找字符串结束标志‘\0’,一旦找到 ‘\0’,比较结束。而后者我们可以根据实际情况完成指定长度n的字符串拷贝,因此函数strcpy里面多了一个字母n,即strncpy.由此,从此处看strncpy比strcpy功能强大一点。
关于strcpy可以查看我的博客链接:/article/4218930.html
strncpy代码如下:
#include<stdio.h> #include<stdlib.h> #include<assert.h> #include<string.h> char* my_strncpy(char* dest, const char* src, size_t count) { assert(src); char* strdest= dest; while (count--) { *dest++ = *src++; } *dest = '\0'; return strdest; } int main() { char arr1[10] = { 0 }; char arr2[] = "hello world!"; char* ret = my_strncpy(arr1, arr2, 2); printf("%s", ret); system("pause"); return 0; }
本文出自 “Han Jing's Blog” 博客,请务必保留此出处http://10740184.blog.51cto.com/10730184/1715679
相关文章推荐
- 【面试题】C语言:模拟实现内存放置函数memset()
- 【面试题】C语言:模拟实现memcmp,试比较memcmp与strcmp,strncmp的区别
- 【指针篇】C语言:指针与数组的区别,数组指针与指针数组的剖析。
- C语言:实现一个函数itoa(int n,char s[]),将整数n这个数字转换为对应的字符串,保存到s中
- C语言:字符数组的内容为;tneduts a ma i;,内容改为i am a student.只能开辟有限个空间
- 【面试常考】C语言:输入:&quot;student a am i&quot;,输出&quot;i am a student,不能使用库函数
- C语言:在字符串中找出第一个只出现一次的字符。如输入“abaccdeff”,则输出&#39;b&#39;
- 【笔试题】C语言:在字符串中找出第一个只出现一次的字符。如输入“abaccdeff”,则输出&#39;b&#39;。
- C语言:每瓶汽水1元,两个空瓶可以置换一瓶汽水,现在有20元,最多能喝多少瓶汽水。
- C语言:实现一个函数,可以左旋字符串中的k个字符。
- C语言:判断一个字符串是否为另外一个字符串旋转之后的字符串。(左旋右旋、求子串)
- C语言:【面试题】在二维数组中,每行每列都按照递增的顺序排序,判断数组中是否包含一个数。
- C语言:自己动手查看float以及double类型的变量2.5在内存中的存储方式。
- C语言:用递归函数DigitSum(n)实现输入1729,输出sum=1+7+2+9=19的值
- C语言:编写reverse_string(char * string)(递归实现)函数,将参数字符串中的字符反向排列
- C语言:编写一个函数实现n^k,使用递归实现
- C语言:模拟实现strstr函数,若是子串,输出子串后面的字符串,否则输出null
- C语言:实现一个函数,打印乘法口诀表,如:输入9,输出9*9口诀表
- 【面试题】C语言:使用函数实现两个数的交换
- C语言:实现一个函数判断year是不是闰年