C语言字符串函数大全

千杯不醉-sen 2010-03-31 09:38:36
函数名: strcpy
功 能: 拷贝一个字符串到另一个
用 法: char *strcpy(char *destin, char *source);
程序例:

#include <stdio.h>
#include <string.h>
int main(void)
{
char string[10];
char *str1 = "abcdefghi";
stpcpy(string, str1);
printf("%s\n", string);
return 0;
}



函数名: strcat
功 能: 字符串拼接函数
用 法: char *strcat(char *destin, char *source);
程序例:

#include <string.h>
#include <stdio.h>
int main(void)
{
char destination[25];
char *blank = " ", *c = "C++", *Borland = "Borland";
strcpy(destination, Borland);
strcat(destination, blank);
strcat(destination, c);
printf("%s\n", destination);
return 0;
}



函数名: strchr
功 能: 在一个串中查找给定字符的第一个匹配之处\
用 法: char *strchr(char *str, char c);
程序例:

#include <string.h>
#include <stdio.h>
int main(void)
{
char string[15];
char *ptr, c = 'r';
strcpy(string, "This is a string");
ptr = strchr(string, c);
if (ptr)
printf("The character %c is at position: %d\n", c, ptr-string);
else
printf("The character was not found\n");
return 0;
}



函数名: strcmp
功 能: 串比较
用 法: int strcmp(char *str1, char *str2);
看Asic码,str1>str2,返回值 > 0;两串相等,返回0
程序例:

#include <string.h>
#include <stdio.h>
int main(void)
{
char *buf1 = "aaa", *buf2 = "bbb", *buf3 = "ccc";
int ptr;
ptr = strcmp(buf2, buf1);
if (ptr > 0)
printf("buffer 2 is greater than buffer 1\n");
else
printf("buffer 2 is less than buffer 1\n");
ptr = strcmp(buf2, buf3);
if (ptr > 0)
printf("buffer 2 is greater than buffer 3\n");
else
printf("buffer 2 is less than buffer 3\n");
return 0;
}



函数名: strncmpi
功 能: 将一个串中的一部分与另一个串比较, 不管大小写
用 法: int strncmpi(char *str1, char *str2, unsigned maxlen);
程序例:

#include <string.h>
#include <stdio.h>
int main(void)
{
char *buf1 = "BBB", *buf2 = "bbb";
int ptr;
ptr = strcmpi(buf2, buf1);
if (ptr > 0)
printf("buffer 2 is greater than buffer 1\n");
if (ptr < 0)
printf("buffer 2 is less than buffer 1\n");
if (ptr == 0)
printf("buffer 2 equals buffer 1\n");
return 0;
}



函数名: strcpy
功 能: 串拷贝
用 法: char *strcpy(char *str1, char *str2);
程序例:
#include <stdio.h>
#include <string.h>
int main(void)
{
char string[10];
char *str1 = "abcdefghi";
strcpy(string, str1);
printf("%s\n", string);
return 0;
}



函数名: strcspn
功 能: 在串中查找第一个给定字符集内容的段
用 法: int strcspn(char *str1, char *str2);
程序例:

#include <stdio.h>
#include <string.h>
#include <alloc.h>
int main(void)
{
char *string1 = "1234567890";
char *string2 = "747DC8";
int length;
length = strcspn(string1, string2);
printf("Character where strings intersect is at position %d\n", length);
return 0;
}



函数名: strdup
功 能: 将串拷贝到新建的位置处
用 法: char *strdup(char *str);
程序例:

#include <stdio.h>
#include <string.h>
#include <alloc.h>
int main(void)
{
char *dup_str, *string = "abcde";
dup_str = strdup(string);
printf("%s\n", dup_str);
free(dup_str);
return 0;
}



函数名: stricmp
功 能: 以大小写不敏感方式比较两个串
用 法: int stricmp(char *str1, char *str2);
程序例:

#include <string.h>
#include <stdio.h>
int main(void)
{
char *buf1 = "BBB", *buf2 = "bbb";
int ptr;
ptr = stricmp(buf2, buf1);
if (ptr > 0)
printf("buffer 2 is greater than buffer 1\n");
if (ptr < 0)
printf("buffer 2 is less than buffer 1\n");
if (ptr == 0)
printf("buffer 2 equals buffer 1\n");
return 0;
}


函数名: strerror
功 能: 返回指向错误信息字符串的指针
用 法: char *strerror(int errnum);
程序例:

#include <stdio.h>
#include <errno.h>
int main(void)
{
char *buffer;
buffer = strerror(errno);
printf("Error: %s\n", buffer);
return 0;
}



函数名: strcmpi
功 能: 将一个串与另一个比较, 不管大小写
用 法: int strcmpi(char *str1, char *str2);
程序例:

#include <string.h>
#include <stdio.h>
int main(void)
{
char *buf1 = "BBB", *buf2 = "bbb";
int ptr;
ptr = strcmpi(buf2, buf1);
if (ptr > 0)
printf("buffer 2 is greater than buffer 1\n");
if (ptr < 0)
printf("buffer 2 is less than buffer 1\n");
if (ptr == 0)
printf("buffer 2 equals buffer 1\n");
return 0;
}



函数名: strncmp
功 能: 串比较
用 法: int strncmp(char *str1, char *str2, int maxlen);
程序例:

#include <string.h>
#include <stdio.h>
int main(void)
{
char *buf1 = "aaabbb", *buf2 = "bbbccc", *buf3 = "ccc";
int ptr;
ptr = strncmp(buf2,buf1,3);
if (ptr > 0)
printf("buffer 2 is greater than buffer 1\n");
else
printf("buffer 2 is less than buffer 1\n");
ptr = strncmp(buf2,buf3,3);
if (ptr > 0)
printf("buffer 2 is greater than buffer 3\n");
else
printf("buffer 2 is less than buffer 3\n");
return(0);
}
...全文
1117 37 打赏 收藏 转发到动态 举报
写回复
用AI写文章
37 条回复
切换为时间正序
请发表友善的回复…
发表回复
飞翔的鸽子 2011-12-27
  • 打赏
  • 举报
回复
不错,如果能把它后台实现源程序写出来更好。
飞翔的鸽子 2011-12-27
  • 打赏
  • 举报
回复
我靠,傻眼了,先前写的就是用法,没有源代码,后来gigglesun兄分享了几个原代码,我还以为我看错了,源代码最好,有了源代码还怕不会用,呵呵!
飞翔的鸽子 2011-12-27
  • 打赏
  • 举报
回复
写错了,已经是源代码了。很好。
ehsgs1 2010-07-07
  • 打赏
  • 举报
回复
mark
sunlp007 2010-06-20
  • 打赏
  • 举报
回复
lz真是好人啊
千杯不醉-sen 2010-04-07
  • 打赏
  • 举报
回复
[Quote=引用 30 楼 gigglesun 的回复:]
C/C++ code
//1. strlen(),计算字符串长度
int strlen(const char string)
{
int i=0;
while(string[i]) i++;
return i;
}

//2. strcpy(), 字符串拷贝.
char *strcpy(char *destination, const c……
[/Quote]

很好,其实常用的就那么几个。。。。
喜-喜 2010-04-06
  • 打赏
  • 举报
回复
shou cang
ithiker 2010-04-06
  • 打赏
  • 举报
回复
//1. strlen(),计算字符串长度 
int strlen(const char string)
{
int i=0;
while(string[i]) i++;
return i;
}

//2. strcpy(), 字符串拷贝.
char *strcpy(char *destination, const char *source)
{
while(*destination++ = *source++);
return (destination-1);
}

//3. strcat(), 字符串的连接.
char *strcat(char *target,const char *source)
{
char *original=target;
while(*target) target++; // Find the end of the string
while(*target++=*source++);
return(original);
}

//4. streql(), 判断两个字符串是否相等.
int streql(char *str1,char *str2)
{
while((*str1==*str2)&&(*str1))
{
str1++;
str2++;
}
return((*str1==NULL)&&(*str2==NULL));
}

//5. strchr(), 在字符串中查找某个字符.
char *strchr(const char *string,int letter)
{
while((*string!=letter)&(*string))
string++;
return (string);
}

//6. chrcnt(), 计算某个字符在字符串中出现的次数.
int chrcnt(const char *string,int letter)
{
int count=0;
while(*string++)
if(*string==letter)
count++;
return count;
}

//7. strcmp(), 判断两个字符串是否相等.
int strcmp(const char *str1,const char *str2)
{
while((*str1==*str2)&&(*str1))
{
str1++;
str2++;
}
if((*str1==*str2)&&(!*str1)) //Same strings
return 0;
else if((*str1)&&(!*str2)) //Same but str1 longer
return 1;
else if((*str2)&&(!*str1)) //Same but str2 longer
return -1;
else return((*str1>*str2)?1:-1);
}


来源:http://www.360doc.com/showWeb/0/0/21867195.aspx
原文由几个出错地方,改过了,大家参考下


ithiker 2010-04-06
  • 打赏
  • 举报
回复
仔细看了下
应该叫C语言字符串函数用法大全
有没有谁可以找到这些函数的定义呢?
__Jun__ 2010-04-06
  • 打赏
  • 举报
回复
mark
千杯不醉-sen 2010-04-06
  • 打赏
  • 举报
回复
[Quote=引用 20 楼 lihaiyang1 的回复:]
我想问一下LZ
#include <stdio.h>
#include <string.h>
#include <alloc.h>
int main(void)
{
char *string1 = "1234567890";
char *string2 = "747DC8";
int length;
length = strcspn(string1, string……
[/Quote]

哦!我也有点晕了...也想了好久,没有定下最终结论。你看看这个,看有什么想法...

/*
原型:extern int strcspn(char *string1,char *string2);
用法:#include <string.h>
功能:在字符串string1中搜寻string2中所出现的字符。
说明:返回第一个出现的字符在string1中的下标值,亦即在string1中出现而string2中没有出现的子串的长度。
举例:
*/
#include <string.h>
#include <stdio.h>
#include <stdlib.h>

main()
{
char *string1 = "1234567890";
char *string2 = "747DC8";
int length;
system("cls");
length=strcspn(string1,string2);
printf("The first char both in string1 and string2 is: %c\n",string1[length]);
printf("Character where strings intersect is at position %d\n", length);
getchar();
return 0;
}
千杯不醉-sen 2010-04-06
  • 打赏
  • 举报
回复
[Quote=引用 17 楼 z15881328993 的回复:]
函数名: strcmpi
功 能: 将一个串与另一个比较, 不管大小写
用 法: int strcmpi(char *str1, char *str2);
程序例:
C/C++ code
#include <string.h>
#include <stdio.h>
int main(void)
{
char *buf1 = "BBB", *buf2 = "bbb";
i……
[/Quote]
呵呵....不加也行!

#include <malloc.h>
xiaotutu6000 2010-04-05
  • 打赏
  • 举报
回复
jiefen
企-鹅 2010-04-05
  • 打赏
  • 举报
回复
.[Quote=引用 22 楼 hqin6 的回复:]
做成一个chm的多好,直接查,也方便以后扩充
[/Quote]
ForestDB 2010-04-05
  • 打赏
  • 举报
回复
jf.
爱在深秋 2010-04-04
  • 打赏
  • 举报
回复
我想问一下LZ
#include <stdio.h>
#include <string.h>
#include <alloc.h>
int main(void)
{
char *string1 = "1234567890";
char *string2 = "747DC8";
int length;
length = strcspn(string1, string2);
printf("Character where strings intersect is at position %d\n", length);
return 0;
}
你举的这个函数名的用途是什么????
我点看不懂
yianyongle 2010-04-04
  • 打赏
  • 举报
回复
感谢分享!!!收藏!
太乙 2010-04-04
  • 打赏
  • 举报
回复
做成一个chm的多好,直接查,也方便以后扩充
bullbat 2010-04-04
  • 打赏
  • 举报
回复
lz辛苦,赞RP。。
msj321 2010-04-04
  • 打赏
  • 举报
回复
mark
加载更多回复(17)

69,368

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧