4. strlen
返回字符串长度。
5.strcat
把 src 所指向的字符串追加到 dst 所指向的字符串的结尾。
6.strcmp
把 str1 所指向的字符串和 str2 所指向的字符串进行比较。
如果返回值小于 0,则表示 str1 小于 str2。
如果返回值大于 0,则表示 str1 大于 str2。
如果返回值等于 0,则表示 str1 等于 str2。
7.strncpy
把 src 所指向的字符串复制到 dst,最多复制 n 个字符。当 src 的长度小于 n 时,dst 的剩余部分将用空字节填充。
#include<iostream>
#include<cstring>
#include<algorithm>
#include<assert.h>
using namespace std;
size_t myStrlen(const char* src) {
assert(src != NULL);
size_t ans = 0;
while (*src != '\0') {
ans++;
src++;
}
return ans;
}
char* myStrcat(char* dst, const char* src) {
assert(dst != NULL && src != NULL);
char* tempDst = dst;
while (*tempDst != '\0')
tempDst++;
while (*src != '\0') {
*tempDst = *src;
tempDst++;
src++;
}
return dst;
}
int myStrcmp(const char* str1, const char* str2) {
assert(str1 != NULL && str2 != NULL);
// 两个字符串自左向右逐个字符相比(按 ASCII 值大小相比较),直到出现不同的字符或遇 \0 为止。
while (str1 && str2 && *str1 == *str2) {
str1++;
str2++;
}
return *str1 - *str2;
}
char* myStrncpy(char* dst, const char* src, size_t n) {
assert(dst != NULL && src != NULL);
char* tempDst = dst;
if (dst < src || src + n < dst) {
while (n-- && *src != '\0') {
*tempDst = *src;
tempDst++;
src++;
}
*tempDst = '\0';
}
else {
n = min(n, strlen(src));
tempDst += n;
tempDst = '\0';
tempDst--;
src += n - 1;
while (n--) {
*tempDst = *src;
tempDst--;
src--;
}
}
return dst;
}
int main() {
cout << "strlen example: " << endl;
char str[] = "I am a string";
cout << myStrlen(str) << endl;
cout << "strcat example: " << endl;
char str1[40] = "I am a string";
char str2[20] = " and a string.";
cout << myStrcat(str1, str2) << endl;
cout << "strcmp example: " << endl;
char s1[] = "string";
char s2[] = "String";
cout << myStrcmp(s1, s2) << endl;
cout << "strncpy example: " << endl;
char s3[] = "hello world";
char s4[20] = "";
cout << myStrncpy(s4, s3, strlen(s3)) << endl;
system("pause");
return 0;
}