![](https://iknow-base.cdn.bcebos.com/lxb/notice.png)
以下有库函数strcpy(char *s1,const char *s2)功能不相等的函数是()?
2个回答
展开全部
有const修饰的变量项表明改项不能被更改。
如:
int
b=20;
const
int
*a=&b;
这时const修饰的是(*a)表示a所指向的对象不能更改
int
*const
a=&b;
这时const修饰的是a表示a所指向的地址不能更改
A、D就是最后将s1指向的位置改变了,B、C呢那就更错了,其实我想它们大致是想实现字符串拷贝的功能:
VC中的strcpy的源码:
char
*
__cdecl
strcpy(char
*
dst,
const
char
*
src)
{
char
*
cp
=
dst;
while(
*cp++
=
*src++
)
;
/*
Copy
src
over
dst
*/
return(
dst
);
}
如:
int
b=20;
const
int
*a=&b;
这时const修饰的是(*a)表示a所指向的对象不能更改
int
*const
a=&b;
这时const修饰的是a表示a所指向的地址不能更改
A、D就是最后将s1指向的位置改变了,B、C呢那就更错了,其实我想它们大致是想实现字符串拷贝的功能:
VC中的strcpy的源码:
char
*
__cdecl
strcpy(char
*
dst,
const
char
*
src)
{
char
*
cp
=
dst;
while(
*cp++
=
*src++
)
;
/*
Copy
src
over
dst
*/
return(
dst
);
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
正确的答案是B。
如果楼主没有打错答案的选项的话,这道题的答案其实很明显。在A、C和D选项的代码里赋值是用*s1++=*s2++和*s1=*s2,即把s2指向的地址保存的值赋给s1指向的地址。而B选项的代码里是用s1++=s2++,即把s2的值赋给s1,所改变的是s1的值,而非s1所指向字符串的值。而且s1++=s2++这个本身就不是一个合法的表达式。
重楼の爱幂关于选项的解释都错了,不过关于const的解释是正确的。在函数的参数中使用const可以用来保护数据不被函数修改。strcpy的功能是把字符串s2复制到字符串s1,字符串s2的值是不需要修改的。使用const可以明确这一点,如果试图在函数中修改字符串s2,例如*s2='a'(正如重楼の爱幂的解释,const
char
*s2表示的是s2所指向的是一个常量,即*s2不能被修改;但s2本身是可以被修改的,所以s2++这样的语句是正确的),那么在编译时就会出错。
如果楼主没有打错答案的选项的话,这道题的答案其实很明显。在A、C和D选项的代码里赋值是用*s1++=*s2++和*s1=*s2,即把s2指向的地址保存的值赋给s1指向的地址。而B选项的代码里是用s1++=s2++,即把s2的值赋给s1,所改变的是s1的值,而非s1所指向字符串的值。而且s1++=s2++这个本身就不是一个合法的表达式。
重楼の爱幂关于选项的解释都错了,不过关于const的解释是正确的。在函数的参数中使用const可以用来保护数据不被函数修改。strcpy的功能是把字符串s2复制到字符串s1,字符串s2的值是不需要修改的。使用const可以明确这一点,如果试图在函数中修改字符串s2,例如*s2='a'(正如重楼の爱幂的解释,const
char
*s2表示的是s2所指向的是一个常量,即*s2不能被修改;但s2本身是可以被修改的,所以s2++这样的语句是正确的),那么在编译时就会出错。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询