strlen
數(shù)組長(zhǎng)度的計(jì)算是通過strlen來的,它的作用就是判斷給定的數(shù)組元素個(gè)數(shù),直到碰到\0結(jié)束
函數(shù)原型
1
|
size_t strlen ( const char * str ); |
廢話少說,直接上代碼
1
2
3
4
5
6
7
8
9
10
11
|
int my_strlen( char *str) { char * ch=str; int count=0; while (*ch!= '\0' ) { count++; ch++; } return count; } |
但考慮到安全性,因?yàn)榍箝L(zhǎng)度并不會(huì)改變?cè)醋址?,所以加上const修飾char,保證該字符串的內(nèi)容不能被修改,但是可以改變指向
1
2
3
4
5
6
7
8
9
10
11
|
int my_strlen( const char *str) { char * ch=str; int count=0; while (*ch!= '\0' ) { count++; ch++; } return count; } |
strcpy
strcpy是將一個(gè)字符串含\0整體拷貝到另一個(gè)字符串中
原型為
1
|
char * strcpy ( char * destination, const char * source ); |
1
2
3
4
5
6
7
8
9
10
11
|
void my_strcpy( char * dest, const char *src) { char * ch=src; while (*ch!= '\0' ) { *dest=*ch; dest++; ch++; } *dest= '\0' ; } |
同理不改變?cè)址约由蟘onst修飾。在最后記得手動(dòng)給目的字符串加上\0,這樣才能保證輸出正確
strcat
原型
1
|
char * strcat ( char * destination, const char * source ); |
1
2
3
4
5
6
7
8
9
10
11
12
|
void my_strcat( char * dest, const char *src) { char * ch=dest; while (*ch!= '\0' )ch++; while (*src!= '\0' ) { *ch=*src; ch++; src++; } *ch= '\0' ; } |
先遍歷跑完目的字符串,接著再將原字符串所指的值一一賦給目的字符串.而因?yàn)槭前言釉谀康淖址?,所以目的字符串要足夠?/p>
strcmp
原型
1
|
int strcmp ( const char * str1, const char * str2 ); |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
int my_strcmp( const char * str1, const char *str2) { assert (str1); assert (str2); char * s1=str1; char * s2=str2; while (*s1==*s2) { if (*s1== '\0' ) { return 0; } s1++; s2++; } if (*s1>*s2) { return 1; } else { return -1; } } |
?
上面代碼最后可以簡(jiǎn)化為return *s1-*s2,不過主函數(shù)里要相應(yīng)更改了
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注服務(wù)器之家的更多內(nèi)容!
原文鏈接:https://blog.csdn.net/wfy17030212/article/details/121289845