mem系列函数与str系列函数
Mem系列函数通常处理内存内容,⽽Str通常处理字符串,这俩个家族系列函数经常会使⽤为了能够更好地体现出两家族函数的异同,将采⽤对⽐的形式⼀⼀列出:
⼀拷贝函数
函数名称: memcpy
函数原型:void *memcpy(void *dest, const void *src,size_t n);
函数功能:内存拷贝;将src指向内存地址的连续N个指针位置的内容拷贝⾄dest指针指向的位置
函数返回:⽆
参数说明:dest — ⽬的内存空间指针
src — 源内存空间指针
n — 拷贝指针位置个数
使⽤⽅法:
#include"iostream"
using namespace std;
void main()
{
char* src = "Hello World";
char* dst = (char*)malloc(20 * sizeof(char));//<====>char* dst = new char[7];
memset(dst, 0, 20 * sizeof(char));
memcpy(dst, src, 7 * sizeof(char));
cout << "dst:" << dst << endl;
system("pause");
}
输出:
dst:Hello W
请按任意键继续. . .
函数名称:strcpy
函数原型:char *strcpy(char* dest, const char *src);
函数功能:字符串拷贝;把从src地址开始且含有\0结束符的字符串复制到以dest开始的地址空间
函数返回:dest字符串指针
相关说明: src和dest所指内存区域不可以重叠且dest必须有⾜够的空间来容纳src的字符串。
使⽤⽅法:
#define _CRT_SECURE_NO_WARNINGS//关闭安全检查
#include"iostream"
using namespace std;
void main()
{
char * src = "Hello Frankie World !";
char * dest = new char[50];
char * dest1 = new char[50];
memset(dest, 0, 50);
memset(dest1, 0, 50);
memcpy(dest, src, 7);
strcpy(dest1, src);
cout << "dset值为:" << dest << endl;
cout << "dset1值为:" << dest1 << endl;
system("pause");
}
输出:
dset值为:Hello F
dset1值为:Hello Frankie World !
请按任意键继续. . .
memcpy与strcpy区别:
1、复制的内容不同。strcpy只能复制字符串,⽽memcpy可以复制任意内容,例如字符数组、整型、结构体、类等。
2、复制的⽅法不同。strcpy不需要指定长度,它遇到被复制字符的串结束符"\0"才结束,所以容易溢出。memcpy则是根据其第3个参数决定复制的长度。
3、⽤途不同。通常在复制字符串时⽤strcpy,⽽需要复制其他类型数据时则⼀般⽤memcpy
补充:
函数名称: strncpy
函数原型:char * strncpy( char *dest, char *src, size_t num );
函数功能:
复制src中的内容(字符,数字、汉字....)到dest,复制多少由num的值决定,返回指向dest的指针。如果遇到null字符('\0'),且还没有到num个字符时,就⽤(num - n)(n是遇到null字符前已经有的⾮null字符个数)个null字符附加到destination。注意:并不是添加到destination的最后,⽽是紧跟着由source中复制⽽来的字符后⾯
函数返回: dest指针
使⽤⽅法:
#define _CRT_SECURE_NO_WARNINGS//关闭安全检查
#include"iostream"
using namespace std;
void main()
{
char * src = "Hello Frankie World !";
char * dest = new char[50];
char * dest1 = new char[50];
char * dest2 = new char[50];
memset(dest, 0, 50);
memset(dest1, 0, 50);
memset(dest2, 0, 50);
memcpy(dest, src, 7);
strcpy(dest1, src);
strncpy(dest2, src, 7);
std::cout << "dset值为:" << dest << endl;
std::cout << "dset1值为:" << dest1 << endl;
std::cout << "dset2值为:" << dest2 << endl;
system("pause");
}
输出:
dset值为:Hello F
dset1值为:Hello Frankie World !
dset2值为:Hello F
请按任意键继续. . .
相关说明:
如果n > dest串长度,dest栈空间溢出产⽣崩溃异常。
否则:
1)
src串长度<=dest串长度,(这⾥的串长度包含串尾NULL字符)
如果n<src串长度,src的前n个字符复制到dest中。但是由于没有null字符,所以直接访问dest串会发⽣栈溢出的异常情况。 <="" p="">
如果n = src串长度,与strcpy⼀致。
如果n >src串长度,src串存放于dest字串的[0,src串长度],dest串的(src串长度, dest串长度]处存放NULL。
2)
src串长度>dest串长度
如果n =dest串长度,则dest串没有NULL字符,会导致输出会有乱码。如果不考虑src串复制完整性,可以将dest 最后⼀字符置为NULL。3)
综上,⼀般情况下,使⽤strncpy时,建议将n置为dest串长度(除⾮你将多个src串都复制到dest数组,并且从dest尾部反向操作),复制完毕后,为保险起见,将dest串最后⼀字符置NULL,避免发⽣在第2)种情况下的输出乱码问题。当然喽,⽆论是strcpy还是strncpy,保证 src串长度<dest串长度才是最重要的。
⼆⽐较函数
函数名称:memcmp
函数原型:int memcmp (const void *S1, const void *S2, size_t size)
函数功能:⽤于⽐较内存数据S1与S2的前size个字符,如若相同,返回0
函数返回:如果S1,S2相同返回0,不相同返回-1
参数说明: S1—待⽐较内存数据1
S2—待⽐较内存数据2
size—⽐较内存数据个数
⽤法:
void main()
{
int nResult = -2;//如果S1,S2相同返回0,不相同返回-1,所以初始值设置为-2
int nCount = 12;
char *S1 = "Frankie is best!";
char *S2 = "Frankie is no good!";
nResult = memcmp(S1, S2, nCount);
if (nResult == 0)
{
std::cout << "S1与S2在第" << nCount << "位置前相同" << endl;
}
else
{
std::cout << "S1与S2在第" << nCount << "位置前不相同" << endl;
}
system("pause");
}
输出:
S1与S2在第12位置前不相同
请按任意键继续. . .
函数名称:_memicmp
函数原型:int _memicmp (const void *S1, const void *S2, size_t size)
函数功能:⽤于⽐较内存数据S1与S2的前size个字符,如若相同,返回0
特别注明:相对于memcmp⽽⾔,memicmp不区分字母⼤⼩写
函数返回:如果S1,S2相同返回0,不相同返回-1
⽤法:
//#define _CRT_SECURE_NO_WARNINGS//关闭安全检查
#include"iostream"
using namespace std;
void main()
{
int nResult = -2;
int nCount = 3;
char * S1 = "ABC";
char * S2 = "abc";
nResult = _memicmp(S1, S2, nCount);
if (nResult == 0)
{
std::cout << "S1 与 S2 相同,不区分⼤⼩写" << endl;
}
system("pause");
}
输出:
S1与S2在第12位置前不相同
请按任意键继续. . .
函数名称:strcmp
函数原型:int strcmp(const char *S1,const char * S2);
函数功能:⽐较S1与S2字符串
函数返回:
当s1<s2时,返回为负数注意不是-1
当s1==s2时,返回值= 0
当s1>s2时,返回正数注意不是1
即:两个字符串⾃左向右逐个字符相⽐(按ASCII值⼤⼩相⽐较),直到出现不同的字符或遇'\0'为⽌。如:"A"<"B" "a">"A" "computer">"compare"
特别注意:
strcmp(const char *s1,const char * s2)这⾥⾯只能⽐较字符串,不能⽐较数字等其他形式的参数。
参数说明:
S1:待⽐较字符串S1
S2:待⽐较字符串S2
⽤法:
//#define _CRT_SECURE_NO_WARNINGS//关闭安全检查
#include"iostream"
using namespace std;
void main()
{
char *S1 = "A";
char *S2 = "B";
if (strcmp(S1, S1) == 0)
{
std::cout << "S1 等于 S1" << endl;
}
if (strcmp(S2, S1) > 0)
{
std::cout << "S2 ⼤于 S1"<< endl;
}
if (strcmp(S1, S2) < 0)
{
std::cout << "S1 ⼩于 S2" << endl;
}
system("pause");
}
函数名称:strncmp
函数原型:int strncmp (const char *s1, const char *s2, size_t size)
函数功能:⽐较S1与S2字符串前size个字符的不同
函数返回:
此函数功能即⽐较字符串str1和str2的前maxlen个字符。如果前maxlen字节完全相等,返回值就=0;在前maxlen字节⽐较过程中,如果出现str1[n]与str2[n]不等,则返回(str1[n]-str2[n])。
⽤法:
//#define _CRT_SECURE_NO_WARNINGS//关闭安全检查
#include"iostream"
using namespace std;
void main()
{
char *S1 = "ABCD";
char *S2 = "ABFC";
if (strncmp(S1, S1,3) == 0)
{
std::cout << "S1 等于 S1" << endl;
}
if (strncmp(S2, S1,3) > 0)
strcmp比较数组{
std::cout << "S2 ⼤于 S1"<< endl;
}
if (strncmp(S1, S2,3) < 0)
{
std::cout << "S1 ⼩于 S2" << endl;
}
system("pause");
}
功能⽐较:
⼆者都可以⽤于字符串的⽐较,但是⼆者是有⽐较⼤的差异的:
因为strcmp是按照字节(byte-wise)⽐较的,并且⽐较的过程中会检查是否出现了"/0"结束符,⼀旦任意⼀个字符串指针前进过程中遇到结束符,将终⽌⽐较。
⽽memcmp函数是⽤于⽐较两个内存块的内容是否相等,在⽤于字符串⽐较时通常⽤于测试字符串是否相等,不常进⾏byte-wise的字符串⽐较。如果要⽐较的对象中包含⼀些由于边界对齐需求⽽填⼊结构对象中的空格、联合 (union)结束的额外空格、字符串所分配的空间未使⽤完的部分引起的“ holes”的话,最好使⽤memcmp来完成。这些“holes”的内容是不确定的,在执⾏byte-wise⽐较时结果也是不明确的。
效率差异:
strcmp⽐较的字符串,⽽memcmp⽐较的是内存块,strcmp需要时刻检查是否遇到了字符串结束的 /0 字符,⽽memcmp则完全不⽤担⼼这个问题,所以memcmp的效率要⾼于strcmp
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论