網(wǎng)站的建站流程個(gè)人建站
文章目錄
- 一、字符函數(shù)
- 1、字符分類函數(shù)
- 2、字符轉(zhuǎn)換函數(shù)
- 二、字符串函數(shù)
- 1、strlen
- 概述
- 模擬實(shí)現(xiàn)
- 2、strcpy
- 概述
- 模擬實(shí)現(xiàn)
- 3、strcat
- 概述
- 模擬實(shí)現(xiàn)
- 3、strcmp
- 概述
- 模擬實(shí)現(xiàn)
- 4、有限制的字符串函數(shù)
- strncpy
- strncat
- strncmp
- 4、strstr
- 概述
- 模擬實(shí)現(xiàn)
一、字符函數(shù)
1、字符分類函數(shù)
包含頭文件:
#include<ctype.h>
函數(shù) | 如果它的參數(shù)復(fù)合下列條件就返回真(一個(gè)非零數(shù)字) |
---|---|
iscntrl | 任何控制字符 |
任何控制字符 | 空白字符:空格’ ‘,換頁’\f’,換行’\n’,回車’\r’,制表符’\t’或者垂直制表符’\v’ |
isdigit | 十進(jìn)制數(shù)字0~9 |
isxdigit | 十六進(jìn)制數(shù)字,包括所有十進(jìn)制數(shù)字,小寫字母a~f,大寫字母A-F |
islower | 小寫字母a~z |
isupper | 大寫字母A~Z |
isalpha | 字母a~z或A-Z |
isalnum | 字母或者數(shù)字,a-z,A-Z ,0~9 |
ispunct | 標(biāo)點(diǎn)符號(hào),任何不屬于數(shù)字或者字母的圖形字符(可打印) |
isgraph | 任何圖形字符 |
isprint | 任何可打印字符,包括圖形字符和空白字符 |
這些字符函數(shù)都很類似,舉一個(gè)例子
將小寫字母轉(zhuǎn)換成大寫字母
#include<stdio.h>
#include<ctype.h>int main()
{char str[] = "Test String";char c;int i = 0;while (str[i]){c = str[i];if (islower(c))c = c - 32;putchar(c);i++;}return 0;
}
運(yùn)行結(jié)果
TEST STRING.
2、字符轉(zhuǎn)換函數(shù)
int tolower ( int c ); //將參數(shù)傳進(jìn)去的?寫字?轉(zhuǎn)?寫
int toupper ( int c ); //將參數(shù)傳進(jìn)去的?寫字?轉(zhuǎn)?寫
我們知道,將小寫字母轉(zhuǎn)換成大寫是-32,大寫字母轉(zhuǎn)換成小寫字母是+32
那么,現(xiàn)在有了字符轉(zhuǎn)換函數(shù),就可以直接實(shí)現(xiàn)
#include <stdio.h>
#include <ctype.h>
int main()
{int i = 0;char str[] = "Test String.\n";char c;while (str[i]){c = str[i];if (islower(c))c = toupper(c);putchar(c);i++;}return 0;
}
運(yùn)行結(jié)果
TEST STRING.
二、字符串函數(shù)
1、strlen
概述
size_t strlen ( const char * str );
? 字符串以 ‘\0’ 作為結(jié)束標(biāo)志,strlen函數(shù)返回的是在字符串中 ‘\0’ 前?出現(xiàn)的字符個(gè)數(shù)(不包含 ‘\0’ )。
? 參數(shù)指向的字符串必須要以 ‘\0’ 結(jié)束。
? 注意函數(shù)的返回值為size_t,是?符號(hào)的( 易錯(cuò) )
? 學(xué)會(huì)strlen函數(shù)的模擬實(shí)現(xiàn)
模擬實(shí)現(xiàn)
法1:
#include<stdio.h>
#include<string.h>
#include<assert.h>size_t my_strlen(const char* str)
{int count = 0;assert(str);while (*str){count++;str++;}return count;
}int main()
{char arr[] = "abc";size_t len = my_strlen(arr);printf("%zd\n", len);return 0;
}
法2:
#include<stdio.h>
#include<string.h>
#include<assert.h>size_t my_strlen(const char* str)
{assert(str);if (*str == '\0')return 0;elsereturn 1 + my_strlen(str + 1);
}int main()
{char arr[] = "abc";size_t len = my_strlen(arr);printf("%zd\n", len);return 0;
}
法3:
#include<stdio.h>
#include<string.h>
#include<assert.h>size_t my_strlen(char* s)
{char* p = s;while (*p)p++;return p - s;
}int main()
{char arr[] = "abc";size_t len = my_strlen(arr);printf("%zd\n", len);return 0;
}
2、strcpy
概述
char * strcpy ( char * destination, const char * source );
? 源字符串必須以 ‘\0’ 結(jié)束。
? 會(huì)將源字符串中的 ‘\0’ 拷?到?標(biāo)空間。
? ?標(biāo)空間必須?夠?,以確保能存放源字符串。
? ?標(biāo)空間必須可變。
? 學(xué)會(huì)模擬實(shí)現(xiàn)。
模擬實(shí)現(xiàn)
char my_strcpy(char* dest, const char* src)
{char* ret = dest;assert(dest);assert(src);while (*dest++ = *src++){;}return ret;
}
3、strcat
概述
? 源字符串必須以 ‘\0’ 結(jié)束。
? ?標(biāo)字符串中也得有 \0 ,否則沒辦法知道追加從哪?開始。
? ?標(biāo)空間必須有?夠的?,能容納下源字符串的內(nèi)容。
? ?標(biāo)空間必須可修改。
模擬實(shí)現(xiàn)
char my_strcat(char* dest, const char* src)
{char* ret = *src;assert(dest);assert(src);while (*dest){dest++;}while (*dest++ = *src){;}return ret;
}
3、strcmp
概述
標(biāo)準(zhǔn)規(guī)定:
? 第?個(gè)字符串?于第?個(gè)字符串,則返回?于0的數(shù)字
? 第?個(gè)字符串等于第?個(gè)字符串,則返回0
? 第?個(gè)字符串?于第?個(gè)字符串,則返回?于0的數(shù)字
模擬實(shí)現(xiàn)
int my_strcmp(const char* arr1, const char* arr2)
{assert(arr1);assert(arr2);while (*arr1 == *arr2){if (*arr1 == '\0')return 0;arr1++;arr2++;}return *arr1 - *arr2;
}
4、有限制的字符串函數(shù)
前面1-3學(xué)習(xí)字符串函數(shù),但是那些字符串函數(shù)沒有個(gè)數(shù)限制,不安全
下面小編帶大家了解一下有個(gè)數(shù)限制的字符串函數(shù)
strncpy
char * strncpy ( char * destination, const char * source, size_t num );
? 拷?num個(gè)字符從源字符串到?標(biāo)空間。
? 如果源字符串的?度?于num,則拷?完源字符串之后,在?標(biāo)的后邊追加0,直到num個(gè)。
strncat
char * strncat ( char * destination, const char * source, size_t num );
#include <stdio.h>
#include <string.h>
int main()
{char str1[20];char str2[20];strcpy(str1, "To be ");strcpy(str2, "or not to be");strncat(str1, str2, 6);printf("%s\n", str1);return 0;
}
strncmp
int strncmp ( const char * str1, const char * str2, size_t num );
?較str1和str2的前num個(gè)字符,如果相等就繼續(xù)往后?較,最多?較num個(gè)字?,如果提前發(fā)現(xiàn)不?
樣,就提前結(jié)束,?的字符所在的字符串?于另外?個(gè)。如果num個(gè)字符都相等,就是相等返回0.
4、strstr
概述
char * strstr ( const char *, const char * );
在字符串中找一個(gè)子字符串
返回str2在str1中第一次出現(xiàn)的位置
如果str2在str1中沒有出現(xiàn),就返回NULL
模擬實(shí)現(xiàn)
#include<stdio.h>
#include<string.h>
#include<assert.h>const char* my_strstr(const char* str1, const char * str2)
{assert(str1);assert(str2);const char* cp = str1;const char* s1 = NULL;const char* s2 = NULL;//如果子串是空字符串,直接返回str1if (*str2 == '\0')return str1;while (*cp){s1 = cp;s2 = str2;while (*s1 == *s2 && *s1 && *s2){s1++;s2++;}if (*s2 == '\0')return cp;cp++;}return NULL;
}int main()
{char arr1[] = "abbbcdef";char arr2[] = "bbc";char* ret = my_strstr(arr1, arr2);if (ret != NULL)printf("%s\n", ret);elseprintf("找不到\n");return 0;
}
圖解: