字符串函数汇总

面试中常常会要求写一些基本的库函数,尤其以字符串库函数考的最多,所以本文汇总了一些常见的字符串库函数的实现。此外,把与内存相关的操作函数也汇总到了一起。

//求字符串长度
int strlen(const char *s) {
	int n = 0;
	while (*s++ != '\0')
		n++;
	return n;
}

//字符串拷贝,返回指针是为了实现链式操作,如strlen(strcpy(dst, src)),dst需要保证有足够空间
char *strcpy(char *dst, const char *src) {
	assert(dst != NULL && src != NULL); //拷贝空串无意义
	char *ret = dst;
	while ((*dst++ = *src++) != '\0')
		;
	return ret;
}

//字符串比较,p>q则返回整数,p=q返回0,否则返回负数
int strcmp(const char *p, const char *q) {
	while (*p && *p == *q)
		p++, q++;
	return (int) ((unsigned char) *p - (unsigned char) *q);
}

// 找到字符c在字符串s中首次出现的位置
char *strchr(const char *s, char c) {
	for (; *s; s++)
		if (*s == c)
			return (char *) s;
	return NULL;
}

//拼接字符串,注意这里dst需要保证有足够的空间
char *strcat(char *dst, const char *src) {
	char *d = dst;
	while (*d)
		d++;
	while ((*d = *src) != '\0')
		;
	return dst;
}

//设置内存位置v开始的n个元素值为c
void *memset(void *v, int c, size_t n) {
	char *p = v;
	int m = n;

	while (--m >= 0) {
		*p++ = c;
	}
	return v;
}

//内存拷贝,注意这里不考虑内存覆盖的情况
void *memcpy(void *dst, const void *src, size_t n) {
	char *d = dst;
	const char *s = src;
	while (n--)
		*d++ = *s++;
	return dst;
}

//内存拷贝函数更健壮的版本,可以处理内存覆盖的情况
void *memmove(void *dst, const void *src, int n) {
	char *d = dst;
	const char *s = src;
	if (s < d && s + n > d) {
		s += n;
		d += n;
		 while (--n >= 0)
			 *--d = *--s;
	} else {
		while (--n >= 0)
			*d++ = *s++;
	}
	return dst;
}


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值