C语言常用库函数实现
2021-07-12 07:07
标签:细节 字节 == 地址 覆盖 ems set font src 1.strcpy 细节是: (1)判断地址是否为空; (2)参数只有两个地址,没有拷贝的长度。拷贝到‘\0‘时就会终止,要保证最终dst末尾是‘\0‘; (3)要保证目标字串的长度足够,能够容纳原串的长度; (4)因为拷贝是dst会移动,而最终要返回的是拷贝后字符串的起始地址,因此要先保存dst的地址,便于最终返回。 2.strcmp 3.strlen 4.memcpy 细节: 1)src和dst所指内存区域不能重叠,函数返回指向dst的指针。如果src和dst以任何形式出现了重叠,它的结果是未定义的。 2)与strcpy相比,memcpy遇到’\0’不结束,而且一定会复制完n个字节。只要保证src开始有n字节的有效数据,dest开始有n字节内存空间就行。 3)如果目标数组本身已有数据,执行memcpy之后,将覆盖原有数据(最多覆盖n个)。 如果要追加数据,则每次执行memcpy()后,要将目标地址增加到要追加数据的地址。 4)source和destin都不一定是数组,任意的可读写的空间均可。 5.memmov Q:memcpy与memmove的区别? A:当src和dst区域没有重叠时,两个函数是完全一样的。木有重叠的条件是: dst = ((char *)src + count 。否则,memcpy是不能正常工作的,memmove是可以正常工作的。 6.memset 7.atoi && itoa 8.atof C语言常用库函数实现 标签:细节 字节 == 地址 覆盖 ems set font src 原文地址:https://www.cnblogs.com/dzy521/p/9547681.htmlchar * strcpy(char *dst,const char *src)
{
if((dst==NULL)||(src==NULL))
return NULL;
char *ret = dst; //[1]
while ((*dst++=*src++)!=‘\0‘); //[2]
return ret;//[3]
}
int strcmp(const char *str1, const char *str2)
{
int ret=0;
while( !(ret = *(unsigned char*)str1 - *(unsigned char*)str2 ) && *str1 ) //红色为了当str1==str2的时候,已经判断到了字符串末尾,跳出循环
{
str1++;
str2++;
}
if(ret 0)
return -1;
else if(ret > 0)
return 1;
return 0;
size_t __cdecl strlen ( //源自标准库
const char * str
)
{
const char *eos = str;
while( *eos++ ) ;
return( eos - str - 1 ); //为什么要-1? 因为当eos为‘\0‘后仍又++
}
void * __cdecl memcpy ( void * dst,const void * src,size_t count)
{
void * ret = dst;
while (count--)
{ // 注意, memcpy函数没有处理dst和src区域是否重叠的问题
*(char *)dst = *(char *)src;
dst = (char *)dst + 1;
src = (char *)src + 1;
}
return(ret);
}
void * __cdecl memmove ( void * dst,const void * src,size_t count)
{
void * ret = dst;
if (dst char *)dst >= ((char *)src + count))
{
// 若dst和src区域没有重叠,则从起始处开始逐一拷贝
while (count--)
{
*(char *)dst = *(char *)src;
dst = (char *)dst + 1;
src = (char *)src + 1;
}
}
else
{ // 若dst和src 区域交叉,则从尾部开始向起始位置拷贝,这样可以避免数据冲突
dst = (char *)dst + count - 1;
src = (char *)src + count - 1;
while (count--)
{
*(char *)dst = *(char *)src;
dst = (char *)dst - 1;
src = (char *)src - 1;
}
}
return(ret);
}
void* memset(void* dst,int val, size_t count)
{
void* ret = dst;
while(count--)
{
*(char*)dst = (char)val;
dst = (char*)dst + 1; //移动一个字节
}
return ret;
}