strupr:將字符串s轉(zhuǎn)換為大寫形式
公司主營業(yè)務(wù):成都做網(wǎng)站、成都網(wǎng)站制作、成都外貿(mào)網(wǎng)站建設(shè)、移動(dòng)網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)推出玉屏免費(fèi)做網(wǎng)站回饋大家。
strlwr:將字符串s轉(zhuǎn)換為小寫形式
以上兩個(gè)沒說的!
●strlen功能:返回字符串s的長度,不包括串結(jié)束字符'\0',也不是數(shù)組長度;
如下幾種方式:
1)strlen("china") 結(jié)果為5
2)char s[20]="china";
strlen(s) 結(jié)果為5
3)char *s="china";
strlen(s) 結(jié)果為5
●strcpy(字符串1,字符串2): 把字符串2中的所有內(nèi)容,復(fù)制到字符串1中,不管字符串1中原先存放的是什么,全部被覆蓋(要注意的是s1的長度要足夠容納s2)
●strcat(字符串1,字符串2): 將兩個(gè)字符串連接,形成一個(gè)新的字符串(要注意的是s1的長度要足夠容納s1和s2,只能字符串和字符串連接,不能直接和整型,float,double等連接,不過可以加上雙引號(hào)" ",使之變成字符型)
如下:
#includestdio.h
#includestring.h
void main()
{
char a[100];
char b[100];
strcpy(a,"我愛-");
strcpy(b,"-美女");
strcat(a,b);
puts(a); /*輸出:我愛--美女*/
}
●strcmp比較字符串的大小,但不是比較s1和s2的長度,而是比較對(duì)應(yīng)字符串中的ASCII碼的大小
如下:
char s1[10]="china";
char s2[10]="chz";
strcmp(s1,s2); //返回一個(gè)負(fù)數(shù),即s1s2。雖然s1的長度大于s2,但比較的是ASCII碼
string.h頭文件中包含的字符串函數(shù)
void?*memcpy(void?*dest,?const?void?*src,?size_t?n);//將n字節(jié)長的內(nèi)容從一個(gè)內(nèi)存地址復(fù)制到另一個(gè)地址;如果兩個(gè)地址存在重疊,則最終行為未定義
void?*memmove(void?*dest,?const?void?*src,?size_t?n);//將n字節(jié)長的內(nèi)容從一個(gè)內(nèi)存地址復(fù)制到另一個(gè)地址;與memcpy不同的是它可以正確作用于兩個(gè)存在重疊的地址
void?*memchr(const?void?*s,?char?c,?size_t?n);//在從s開始的n個(gè)字節(jié)內(nèi)查找c第一次出現(xiàn)的地址并返回,若未找到則返回NULL
int?memcmp(const?void?*s1,?const?void?*s2,?size_t?n);//對(duì)從兩個(gè)內(nèi)存地址開始的n個(gè)字符進(jìn)行比較
void?*memset(void?*,?int,?size_t);//用某種字節(jié)內(nèi)容覆寫一段內(nèi)存空間
char?*strcat(char?*dest,?const?char?*src);//在字符串dest之后連接上src
char?*strncat(char?*dest,?const?char?*src,?size_t?n);//從src截取n個(gè)字符連接在字符串dest之后,返回dest字符串
char?*strchr(const?char*?str,?int?ch);//從字符串str頭開始查找字符ch首次出現(xiàn)的位置
char?*strrchr(const?char*?str,int?ch);//從字符串str尾開始查找字符ch首次出現(xiàn)的位置
int?strcmp(const?char?*,?const?char?*);//基于字典順序比較兩個(gè)字符串
int?strncmp(const?char?*,?const?char?*,?size_t);//基于字典順序比較兩個(gè)字符串,最多比較n個(gè)字節(jié)
int?strcoll(const?char?*,?const?char?*);//基于當(dāng)前區(qū)域設(shè)置的字符順序比較兩個(gè)字符串
char?*strcpy(char*?str1,?const?char*?str2);//將str2拷貝給str1
char?*strncpy(char*?str1,?const?char*?str2,?size_t?n);//截取str2的n個(gè)字符拷貝給str1
char?*strerror(int);//返回錯(cuò)誤碼對(duì)應(yīng)的解釋字符串,參見errno.h(非線程安全函數(shù))
size_t?strlen(const?char?*);//返回一個(gè)字符串的長度
size_t?strspn(const?char?*s,?const?char?*strCharSet);//從字符串s的起始處開始,尋找第一個(gè)不出現(xiàn)在strCharSet中的字符,返回其位置索引值。換句話說,返回從字符串s的起始位置的完全由strCharSet中的字符構(gòu)成的子串的最大長度。strspn為string?span的縮寫。不支持多字節(jié)字符集。
size_t?strcspn(const?char?*s,?const?char?*strCharSet);//從字符串s的起始處開始,尋找第一個(gè)出現(xiàn)在strCharSet中的字符,返回其位置索引值。換句話說,返回從字符串s的起始位置的完全由不屬于strCharSet中的字符構(gòu)成的子串的最大長度。strcspn為string?complement?span的縮寫。不支持多字節(jié)字符集。
char?*strpbrk(const?char?*s,?const?char?*strCharSet);//在字符串s中查找strCharSet中任意字符第一次出現(xiàn)的位置的指針值。strpbrk為string?pointer?break縮寫。不支持多字節(jié)字符集。
char?*strstr(const?char?*haystack,?const?char?*needle);//在字符串haystack中查找字符串needle第一次出現(xiàn)的位置,heystack的長度必須長于needle
char?*strtok(char?*strToken,?const?char?*strDelimit?);//將一個(gè)字符串strToken依據(jù)分界符(delimiter)分隔成一系列字符串。此函數(shù)非線程安全,且不可重入;但MSVC實(shí)現(xiàn)時(shí)使用了thread-local?static?variable因而是線程安全的單仍然是不可重入,即在單線程中不能對(duì)兩個(gè)源字符串交替調(diào)用該函數(shù)來分析token,應(yīng)當(dāng)對(duì)一個(gè)字符串分析完成后再處理別的字符串。
size_t?strxfrm(char?*dest,?const?char?*src,?size_t?n);//根據(jù)當(dāng)前l(fā)ocale轉(zhuǎn)換一個(gè)字符串為strcmp使用的內(nèi)部格式
my_string.h
#ifndef _MY_STRING_H_
#define _MY_STRING_H_
//比較
int my_strcmp(const char *,const char *);
//復(fù)制
char *my_strcpy(char *,const char *);
//檢查字符是否為數(shù)字或字母
int my_isAlpha(char );
int my_isNumber(char );
//大寫轉(zhuǎn)換為小寫。
char *my_convert(char *);
#endif
my_string.c
#include "my_string.h"
//比較
int my_strcmp(const char *cs,const char *ct)
{
register signed char __res;
while (1) {
if ((__res = *cs - *ct++) != 0 || !*cs++)
break;
}
return __res;
}
//復(fù)制
char *my_strcpy(char *dest,const char *src)
{
char *tmp=dest;
while((*dest++=*src++) != '\0');
return tmp;
}
//檢查字符是否為數(shù)字或字母
int my_isAlpha(char c)
{
if((c='a' c='z') || (c='A' c='Z'))
return 1;//返回1為字母
else
return 0;//返回0為其他字符
}
int my_isNumber(char c)
{
if((c='0' c='9'))
return 1;
else
return 0;
}
//大寫轉(zhuǎn)換為小寫。
char *my_convert(char *src)
{
char *tmp=src;
while(*src!='\0')
{
if(*src ='A' *src='Z')
*src=*src+32;
}
return tmp;
}
別忘了自己測(cè)試一下
1.字符串連接函數(shù):strcat();
原型:char *strcat(char *str1,const char *str2);
2.字符串查詢函數(shù):strchr();
原型:char *strchr(const char *str1,const char *str2);
3.字符串比較函數(shù):strcmp();
原型:int strcmp(const char *str1,const char *str2);
4.字符串拷貝函數(shù):strcpy();
原型:char *strcpy(char *str1,const char *str2);
5.求字符串長度的函數(shù):strlen();
原型:unsigned int strlen(const char *str);
6.字符串查詢函數(shù):strstr()
原型:char *strstr(const *str1,const char *str2);
好像就這幾種比較常用
如果對(duì)你有所幫助,請(qǐng)記得采納最佳答案,謝謝!
strcmp是比較古老的函數(shù)了,它就是在檢查'\0'為結(jié)尾的字符串,你的字符數(shù)組位置為5時(shí),沒有位置來存儲(chǔ)'\0',所以函數(shù)strcmp檢查時(shí)候不會(huì)停止,會(huì)繼續(xù)向后面檢查(后面的地址沒有賦值,都是隨機(jī)的數(shù),直到遇見'0'),所以不會(huì)相等。
strcpy(p+strlen(q),r);表示從數(shù)組首地址偏移strlen(q),也就是從元素d所在的位置開始復(fù)制
這時(shí)復(fù)制完后數(shù)組p的長度為3+5=8(元素d被覆蓋)
strcat(p,q);表示從數(shù)組p的尾部進(jìn)行連接,這時(shí)數(shù)組p的長度為8+3=11
而數(shù)組p在定義為char p[20],即請(qǐng)求連續(xù)開辟20個(gè)char類型存儲(chǔ)單元,而每個(gè)char占一字節(jié),所以sizeof(p)等于20
還有問題嗎