C字串函式strcmp\strcpy\strcat\memcpy
阿新 • • 發佈:2019-01-29
1.strcmp
int strcmp(const char* str1, const char*str2){
assert(str1 != NULL&&str2 != NULL);
while (*str1&&*str1 == *str2){
str1++;
str2++;
}
if (*(unsigned char*)str1 < *(unsigned char*)str2){
return -1;
}
else if (*(unsigned char*) str1 > *(unsigned char*)str2){
return 1;
}
else{
return 0;
}
}
注意:
1.引數是 const
2.異常輸入處理 assert(str1 != NULL&&str2 != NULL);
3.字元之間大小比較時一定要先將char*型指標先轉換為unsigned char*
因為有符號字元值的範圍是-128~127,無符號字元值的範圍是0~255,而字串的ASCII沒有負值。
例如 *str1的值為1,*str2的值為255。
本來*str1<*str2,但是有符號數中255是-1.
2.strcat
char *strcat(char* strDest, const char*strSrc){
assert(strDest != NULL&&strSrc != NULL);
char* address = strDest;
while (*strDest != '\0') strDest++;
while (*strSrc != '\0'){
*strDest = *strSrc;
strDest++;
strSrc++;
}
*strDest = '\0' ;//
return address;
}
1.注意引數和返回值
2.要覆蓋原字串’\0’,結尾新增’\0’
3.strcpy
char *strcpy(char* strDest, const char*strSrc){
assert(strDest != NULL&&strSrc != NULL);
char* address = strDest;
while (*strSrc != '\0'){
*strDest = *strSrc;
strDest++;
strSrc++;
}
*strDest = '\0';
return address;
}
如果有必要也應該考慮地址重疊問題
4.memcpy
先看下標準memcpy()的解釋:
void * memcpy ( void * destination, const void * source, size_t num );
自己動手實現memcpy()時就需要考慮地址重疊的情況。
#include<iostream>
#include<cstdio>
using namespace std;
void* mymemcpy(void* dst, const void* src, size_t n){
if (dst == NULL || src == NULL) return NULL;
char* pdst;
char* psrc;
if (src >= dst || (char*)dst >= (char*)src + n - 1){
pdst = (char*)dst;
psrc = (char*)src;
while (n--){
*pdst++ = *psrc++;
}
}
else{
pdst = (char*)dst+ n - 1;
psrc = (char*)src+ n - 1;
while (n--){
*pdst-- = *psrc--;
}
}
return dst;
}
int main(){
char buf[100] = "abcdefghijk";
memcpy(buf+2, buf, 5);
//mymemcpy(buf + 2, buf, 5);
printf("%s\n", buf + 2);
return 0;
}
結果
abcdehijk