常用字符串函数汇总

1 /*
2   *   linux/lib/string.c
3   *
4   *   Copyright (C) 1991, 1992   Linus Torvalds
5   */
6
7 /*
8   * stupid library routines.. The optimized versions should generally be found
9   * as inline code in <asm-xx/string.h>
10   *
11   * These are buggy as well..
12   */
13  
14 #include <linux/types.h>
15
16 char * ___strtok = NULL;
17
18 char * strcpy(char * dest,const char *src)
19 {
20          char *tmp = dest;
21
22          while ((*dest++ = *src++) != '/0')
23                  /* nothing */;
24          return tmp;
25 }

26
27 char * strncpy(char * dest,const char *src,size_t count)
28 {
29          char *tmp = dest;
30
31          while (count-- && (*dest++ = *src++) != '/0')
32                  /* nothing */;
33
34          return tmp;
35 }
36
37 char * strcat(char * dest, const char * src)
38 {
39          char *tmp = dest;
40
41          while (*dest)
42                  dest++;
43          while ((*dest++ = *src++) != '/0')
44                  ;
45
46          return tmp;
47 }

48
49 char * strncat(char *dest, const char *src, size_t count)
50 {
51          char *tmp = dest;
52
53          if (count) {
54                  while (*dest)
55                          dest++;
56                  while ((*dest++ = *src++)) {
57                          if (--count == 0)
58                                  break;
59                  }
60          }
61
62          return tmp;
63 }
64
65 int strcmp(const char * cs,const char * ct)
66 {
67          register signed char __res;
68
69          while (1) {
70                  if ((__res = *cs - *ct++) != 0 || !*cs++)
71                          break;
72          }
73
74          return __res;
75 }
76
77 int strncmp(const char * cs,const char * ct,size_t count)
78 {
79          register signed char __res = 0;
80
81          while (count) {
82                  if ((__res = *cs - *ct++) != 0 || !*cs++)
83                          break;
84                  count--;
85          }
86
87          return __res;
88 }
89
90 char * strchr(const char * s,char c)
91 {
92          for(; *s != c; ++s)
93                  if (*s == '/0')
94                          return NULL;
95          return (char *) s;
96 }
97
98 size_t strlen(const char * s)
99 {
100          const char *sc;
101
102          for (sc = s; *sc != '/0'; ++sc)
103                  /* nothing */;
104          return sc - s;
105 }
106
107 size_t strnlen(const char * s, size_t count)
108 {
109          const char *sc;
110
111          for (sc = s; *sc != '/0' && count--; ++sc)
112                  /* nothing */;
113          return sc - s;
114 }
115
116 size_t strspn(const char *s, const char *accept)
117 {
118          const char *p;
119          const char *a;
120          size_t count = 0;
121
122          for (p = s; *p != '/0'; ++p) {
123                  for (a = accept; *a != '/0'; ++a) {
124                          if (*p == *a)
125                                  break;
126                  }
127                  if (*a == '/0')
128                          return count;
129                  ++count;
130          }
131
132          return count;
133 }
134
135 char * strpbrk(const char * cs,const char * ct)
136 {
137          const char *sc1,*sc2;
138
139          for( sc1 = cs; *sc1 != '/0'; ++sc1) {
140                  for( sc2 = ct; *sc2 != '/0'; ++sc2) {
141                          if (*sc1 == *sc2)
142                                  return (char *) sc1;
143                  }
144          }
145          return NULL;
146 }
147
148 char * strtok(char * s,const char * ct)
149 {
150          char *sbegin, *send;
151
152          sbegin   = s ? s : ___strtok;
153          if (!sbegin) {
154                  return NULL;
155          }
156          sbegin += strspn(sbegin,ct);
157          if (*sbegin == '/0') {
158                  ___strtok = NULL;
159                  return( NULL );
160          }
161          send = strpbrk( sbegin, ct);
162          if (send && *send != '/0')
163                  *send++ = '/0';
164          ___strtok = send;
165          return (sbegin);
166 }
167
168 void * memset(void * s,char c,size_t count)
169 {
170          char *xs = (char *) s;
171
172          while (count--)
173                  *xs++ = c;
174
175          return s;
176 }
177
178 char * bcopy(const char * src, char * dest, int count)
179 {
180          char *tmp = dest;
181
182          while (count--)
183                  *tmp++ = *src++;
184
185          return dest;
186 }
187
188 void * memcpy(void * dest,const void *src,size_t count)
189 {
190          char *tmp = (char *) dest, *s = (char *) src;
191
192          while (count--)
193                  *tmp++ = *s++;
194
195          return dest;
196 }
197
198 void * memmove(void * dest,const void *src,size_t count)
199 {
200          char *tmp, *s;
201
202          if (dest <= src) {
203                  tmp = (char *) dest;
204                  s = (char *) src;
205                  while (count--)
206                          *tmp++ = *s++;
207                  }
208          else {
209                  tmp = (char *) dest + count;
210                  s = (char *) src + count;
211                  while (count--)
212                          *--tmp = *--s;
213                  }
214
215          return dest;
216 }
217
218 int memcmp(const void * cs,const void * ct,size_t count)
219 {
220          const unsigned char *su1, *su2;
221          signed char res = 0;
222
223          for( su1 = cs, su2 = ct; 0 < count; ++su1, ++su2, count--)
224                  if ((res = *su1 - *su2) != 0)
225                          break;
226          return res;
227 }
228
229 /*
230   * find the first occurrence of byte 'c', or 1 past the area if none
231   */
232 void * memscan(void * addr, unsigned char c, size_t size)
233 {
234          unsigned char * p = (unsigned char *) addr;
235
236          while (size) {
237                  if (*p == c)
238                          return (void *) p;
239                  p++;
240                  size--;
241          }
242          return (void *) p;
243 }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
VB.NET中的字符串函数可以处理字符串的拼接、截取、替换、查找等操作。以下是一些常用字符串函数: 1. Concat:将多个字符串拼接成一个字符串。 2. & :将两个字符串拼接成一个字符串。与Concat函数功能相同。 3. Substring:从指定的位置开始截取字符串的一部分。 4. Replace:将字符串中的指定子字符串替换为另一个字符串。 5. Trim:删除字符串开头和结尾的空格。 6. TrimStart:删除字符串开头的空格。 7. TrimEnd:删除字符串结尾的空格。 8. ToLower:将字符串转换为小写。 9. ToUpper:将字符串转换为大写。 10. Split:将字符串按照指定的分隔符分割成一个字符串数组。 11. Join:将一个字符串数组按照指定的分隔符连接成一个字符串。 12. Length:返回字符串的长度。 13. Contains:判断一个字符串是否包含指定的子字符串。 14. StartsWith:判断一个字符串是否以指定的子字符串开头。 15. EndsWith:判断一个字符串是否以指定的子字符串结尾。 16. IndexOf:查找字符串中指定子字符串的位置。 17. LastIndexOf:查找字符串中指定子字符串最后出现的位置。 18. PadLeft:在字符串左侧填充指定字符,使字符串达到指定长度。 19. PadRight:在字符串右侧填充指定字符,使字符串达到指定长度。 20. Format:按照指定格式将多个参数格式化为一个字符串。 注意:以上仅列举了一些常用字符串函数,实际上还有很多其他函数可以用于处理字符串。需要根据具体情况来选择合适的函数
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值