测试程序
#include<iostream>
#include<cstring>
using namespace std;
int a[204],b[204],lena,n;
char s1[100]="12345";
char s2[100]="abcdefg";
char s3[100]="ABCDE";
int main()
{
strncat (s1,s2,3);//s1="12345abc";
strncpy(s1,s3,3);//s3的前三个字符拷贝到s1,s1="ABC45abc";
strncpy(s2,s3,6);//s2="ABCDE";
strncmp(s1,s3,3);//比较s1和s3的前三个字符,比较结果相等则输出0,小于则输出负数,大于则输出正数;
char *p=strchr(s1,'B');//在s1中查找'B' 第一次出现的位置;
if(p)//判断p是否为空指针。
cout<<"5)"<<p-s1<<","<<*p<<endl;
p=strstr(s1,"45a");//在s1中查找子串"45a"。s1="ABC45abc"
//strtok 用法:给定的字符串分隔成若干个子串
cout<<"strtok usage demo:"<<endl;
char str[]="-this,a sample string,OK.";
// 使用strtok从str中抽出被" ,.-"这几个字符分隔的子串
p = strtok (str," ,.-");
while (p!=NULL)//只要p不为NULL则说明找到一个子串。
{
cout<<p<<endl;
p= strtok(NULL," ,.-");//后续调用,第一个参数必须是NULL
}
return 0;
}
解释与函数代码
char *strchr(const char* str,int c);
作用是寻找字符c在字符串str中第一次出现的位置。如果找到,就返回指向该位置的char*指针;如果str中不包含字符c,则返回NULL。
strncpy(char s1[a],char s2[b],n)
作用是如果s3长度大于等于n,则将s3的前n个字符拷贝到s1里面去,相应的会替换掉s1里面的n个字符,若小于n则全部拷贝到s1里面去,且“ ”也会被拷贝,即s3的字符长度。
strncat(const char s1[a],char *s2[b],n);
作用是把s2数组的前n个字符粘贴到s1数组的后面。
char* strstr(const char*str,const char*subStr);
作用是寻找子串subStr在str中第一次出现的位置,如果找到,就返回指向该位置的指针,没找到就返回NULL。
int stricmp(const char *s1,const char *s2);
作用是大小写无关的字符串比较,如果是s1小于s2则返回负数,若等于则返回0,大于则返回正数。不同编译器结果可能不同。
int strncmp(const char *s1,const *s2,int n);
作用是比较是s1前n个字符组成的子串和s2前n个字符组成的子串的大小,若长度不足n,则取整个串作为子串。返回值和strcmp类似。
char *strncpy(char *dest,const char *src,int n);
作用是拷贝src的前n个字符到dest。如果src长度大于等于n,该函数不会自动往dest中写入“ ”,若src长度不足n,则拷贝src全部内容以及结尾的“ ”到dest。
char *strtok(char *str,const char * delim);
连续调用该函数若干次,可以做到:从str中逐个抽取出被字符串delim中的字符分隔开的若干个子串。
int atoi(char *s);
将字符串s里的内容转换成一个整形数返回。比如,字符串s的内容是“1234”,那么函数返回值就是1234,如果s格式不是一个整形,比如“a12”,那么返回0。
double atof(char *s);
将字符串s中的内容转换成实数返回,比如,“12.34”就会转换成12.34.如果s的格式不是一个实数,则返回0。
char *itoa(int calue,char *string,int radix);
将整形值value以radix进制表示法写入string。