#include <stdio.h>
#include <stdlib.h>
struct test
{
int a[5];
};
void print_test(struct test* a, const char* msg)
{
int i;
printf("%s:\t", msg);
for (i = 0; i < 5; ++i)
printf("%d ", a->a[i]);
printf("\n");
}
void reset(struct test* input, int start)
{
int i;
struct test tmp;
for (i = 0; i < 5; ++i)
tmp.a[i] = start + i;
*input = tmp;
}
int main()
{
struct test r1, r2, r3;
int i;
for (i = 0; i < 5; ++i) {
r1.a[i] = i;
r2.a[i] = i + 20;
r3.a[i] = i + 40;
}
print_test(&r1, "r1");
print_test(&r2, "r2");
print_test(&r3, "r3");
r1 = r2;
r2 = r3;
reset(&r3, 80);
print_test(&r1, "r1");
print_test(&r2, "r2");
print_test(&r3, "r3");
return(0);
}
我以前一直以为结构体复制需要用memcpy这种东西,今天才知道可以直接用=号,求教一下各位。
C语言中,结构体是一篇连续的内存空间,使用=赋值操作,底层用到的就是memcpy;
如果结构体中有指针变量;操作后。两个指针指向的同一块区域,而不会分配新的区域;
struct S
{
int a;
char * b;
};
int main(){
S s1;
s1.b = new char[5];
memcpy(s1.b,"hell",5);
S s2;
s2 = s1;
printf("s1.b:%s ,%d \n s2.b:%s,%d\n" ,s1.b,int(s1.b),s2.b,int(s2.b));
return 0;
}
output://复制后的地址空间相同
s1.b:hell ,4921176
s2.b:hell,4921176
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。