char * strcat (char * dst, char * src)
{
char * cp = dst;
while( *cp )
++cp; /* Find end of dst */
while( *cp++ = *src++ )
; /* Copy src to end of dst */
return( dst );
}
char * strcpy (char * dst, char * src)
{
char * cp = dst;
while( *cp++ = *src++ )
; /* Copy src over dst */
return( dst );
}
这是在MS的vc7里面的strcat和strcpy的两段代码。
可谓直截了当,一点都没有拖泥带水!对于参数没有做任何检验!
那么这样做到底为什么呢?效率吧!
这样两个函数的利用率应该是非常高的。假如每次调用都唧唧歪歪一番,岂不是很浪费!
同时,就要求我们在使用这两个函数时非常小心!否则,会有问题。
那么,我们自己定义的函数对于安全性和效率该如何权衡呢?在vc或者其它的c++库里面这样定义strcpy是有其道理的,因为strcpy的使用者是伟大的c++程序员,故无需多言,效率优先(尽管很多伟大的cpper没有正确使用他们)。
最后,俺认为:当权衡一个函数的安全性和效率时应该根据其本身的使命来定夺。而不能说什么安全第一、效率第一之类。
今天就是这样,有事下次再讲。幼稚了,别笑俺!要不讨论讨论……
本文地址:http://com.8s8s.com/it/it21733.htm