【校招 --阶段一 高级编程语言】语言基础之字符函数

9 篇文章 0 订阅

一、字符操作函数
函数介绍:

求字符串长度
strlen

size_t strlen ( const char * str );

字符串已经’\0’ 作为结束标志,strlen函数返回的是在字符串中’\0’ 前面出现的字符个数(不包含’\0’ )。参数指向的字符串必须要以’\0’ 结束。 注意函数的返回值为size_t,是无符号的( 易错) 学会strlen函数的模拟实现

#include <stdio.h>
int main()
{
const char*str1 = "abcdef";
const char*str2 = "bbb";
if(strlen(str2)-strlen(str1)>0)
{
printf("str2>str1\n");
}
else
{
printf("srt1>str2\n");
}
return 0;
}

该段代码会输出什么呢?
在这里插入图片描述
strcpy

char* strcpy(char * destination, const char * source );

源字符串必须以’\0’ 结束。
会将源字符串中的’\0’ 拷贝到目标空间。
目标空间必须足够大,以确保能存放源字符串。
目标空间必须可变。
学会模拟实现。

#include <stdio.h>
#include<iostream>
#include<string>
#include<stdlib.h>
using namespace std;
#pragma warning(disable:4996)
int main()
{
	char a[16] = {'1','1', '1', '1', '1', '1', '1', '1', '1', '1', '1', '1', '1', '1','1', '1' };
	const  char* b = "1789";
	strcpy(a, b);
	cout << a << endl;

	return 0;
}

数组中由16个1现在通过strcpy函数拷贝将b中数据拷贝到a中

在这里插入图片描述
输出结果只是拷贝后的数据
在这里插入图片描述
可以看出来靠碑函数也能将\0复制去以至于将\0后边数据读不出来。

strcat

char * strcat ( char * destination, const char * source );

源字符串必须以’\0’ 结束。
目标空间必须有足够的大,能容纳下源字符串的内容。
目标空间必须可修改。
字符串自己给自己追加,如何?

int main()
{
	char a[16] ="0 ";
	const  char* b = "1789";
	strcat(a, b);
	cout << a << endl;

	return 0;
}

在这里插入图片描述
strcmp

int strcmp ( const char * str1, const char * str2 );

标准规定:
第一个字符串大于第二个字符串,则返回大于0的数字
第一个字符串等于第二个字符串,则返回0
第一个字符串小于第二个字符串,则返回小于0的数字
那么如何判断两个字符串?

	const char* a = "123456789";
	const char* b = "123406789";
	cout << strcmp(a, b) << endl;
	const char* c = "123456789";
	const char* d = "123456789";
	cout << strcmp(c,d) << endl;
	const char* e = "123406789";
	const char* f = "123456789";
	cout << strcmp(a, b) << endl;
	return 0;

在这里插入图片描述
strncpy

char * strncpy ( char * destination, const char * source, size_t num );

拷贝num个字符从源字符串到目标空间。
如果源字符串的长度小于num,则拷贝完源字符串之后,在目标的后边追加0,直到num个。

strncat

char * strncat ( char * destination, const char * source, size_t num );
char a[20] = "123456\0lll";
	const char* b = "789";
	strncat(a, b,strlen(b));
	cout << a << endl;

在这里插入图片描述
字符串拼接从destination字符串第一个\0开始拼接拼接完成后在末尾自动添加上\0
在这里插入图片描述
标红的地方是改变的地方

strncmp

int strncmp ( const char * str1, const char * str2, size_t num );

比较到出现另个字符不一样或者一个字符串结束或者num个字符全部比较完
在这里插入图片描述

/* strncmp example */
#include <stdio.h>
#include <string.h>
int main ()
{
char str[][5] = { "R2D2" , "C3PO" , "R2A6" };
int n;
puts ("Looking for R2 astromech droids...");
for (n=0 ; n<3 ; n++)
if (strncmp (str[n],"R2xx",2) == 0)
{
printf ("found %s\n",str[n]);
}
return 0;
}

strstr

char * strstr ( const char *, const char * );

返回指向str1中第一个出现的str2的指针,如果str2不是str1的一部分,则返回空指针

cout<<strstr("123456789", "5");

在这里插入图片描述
strstr查找到第一次5出现的位置,返回他的指针

/* strstr example */
#include <stdio.h>
#include <string.h>
int main ()
{
char str[] ="This is a simple string";
char * pch;
pch = strstr (str,"simple");
strncpy (pch,"sample",6);
puts (str);
return 0;
}

strstr查找simple首先出现的位置,接着strncpy替换simple为sample

例子 统计字符串2出现的次数:


	char str[] = "1234567891223458885";
	char* pch=str;
	int i=0;
	while (1) {
		
		pch = strstr(pch, "2");
		if (pch != NULL) {

			i++;
			pch += 1;
			//找到第一次2出现的位置然后往后移动一位
		}
		else {

			break;
		}
		
	}
	cout << i;
	return 0;

strtok

char * strtok ( char * str, const char * sep );

sep参数是个字符串,定义了用作分隔符的字符集合
第一个参数指定一个字符串,它包含了0个或者多个由sep字符串中一个或者多个分隔符分割的标记。
strtok函数找到str中的下一个标记,并将其用\0 结尾,返回一个指向这个标记的指针。(注:strtok函数会改
变被操作的字符串,所以在使用strtok函数切分的字符串一般都是临时拷贝的内容并且可修改。)
strtok函数的第一个参数不为NULL ,函数将找到str中第一个标记,strtok函数将保存它在字符串中的位置。
strtok函数的第一个参数为NULL ,函数将在同一个字符串中被保存的位置开始,查找下一个标记。
如果字符串中不存在更多的标记,则返回NULL 指针。

strtok 是用来字符串分割的首次调用需将字符串的起始地址传入,后续调用,只需将第一个参数设为NULL即可。

/* strtok example */
#include <stdio.h>
#include <string.h>
int main ()
{
char str[] ="- This, a sample string.";
char * pch;
printf ("Splitting string \"%s\" into tokens:\n",str);
pch = strtok (str," ,.-");
while (pch != NULL)
{
printf ("%s\n",pch);
pch = strtok (NULL, " ,.-");
}
return 0;
}

在这里插入图片描述
二、其他函数
在这里插入图片描述

  • 15
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 12
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

自首的小偷

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值