跪求.C++的大大们过来一下.关于memcpy缓冲区的请问.

跪求.......C++的大大们过来一下............关于memcpy缓冲区的请教............急急急急急急急急急急急急急急急.....
由于本人当前在家分休假笔记本里没有C++编译器,故对无法测试下面一小段的C++代码结果。对于其中的疑惑想请高手解答一下。问题部分,我将以红色标注……

//计算TCP校验和,计算校验和时需要包括TCP pseudo header 

                memcpy(SendBuf,&psd_header,sizeof(psd_header)); //内存复制TCP伪首部缓冲区到 SendBuf变量
                memcpy(SendBuf+sizeof(psd_header),&tcp_header,sizeof(tcp_header));  //通过SendBuf+sizeof(psd_header)移动指针,再将tcp_header的缓冲区复制合并
                tcp_header.th_sum=checksum((USHORT *)SendBuf,sizeof(psd_header)+sizeof(tcp_header)); //用checksum函数计算校验和,并将返回值赋给tcp_header.th_sum

//计算IP校验和 

                memcpy(SendBuf,&ip_header,sizeof(ip_header)); //内存复制ip报头中的首部缓冲区到 SendBuf变量
                memcpy(SendBuf+sizeof(ip_header),&tcp_header,sizeof(tcp_header)); //通过SendBuf+sizeof(ip_header)移动指针,再将tcp_header的缓冲区复制合并
                memset(SendBuf+sizeof(ip_header)+sizeof(tcp_header),0,4); //通过SendBuf+sizeof(ip_header)+sizeof(tcp_header)移动指针,并向后填充4个零
                datasize=sizeof(ip_header)+sizeof(tcp_header); //计算IP报头和TCP报头加在一起的长度
                ip_header.checksum=checksum((USHORT *)SendBuf,datasize); //用checksum函数计算校验和,并将返回值赋给ip_header.checksum


//填充发送缓冲区 

                memcpy(SendBuf,&ip_header,sizeof(ip_header)); //...这行代码我很是不解。在上面的校验和计算中SendBuf缓冲区里已经有了IP报头数据和TCP报头数据。那么现在SendBuf缓冲区里到底是全部被ip_header重新覆盖了还是部分被覆盖了。

//发送TCP报文   Win_Socket sendto

                ErrorCode=sendto( //指定目的地发送数据,sendto()适用于已连接的数据报或流式套接口发送数据。返回值为整型,如果成功,则返回发送的字节数,失败则返回0
                                                SockRaw,  //参数1.Socket创建句柄
                                SendBuf, //报文缓冲区指针 如果SendBuf缓冲区里只有ip_header,那么tcp_header在整个过程中岂不是仅仅为了校验和而存在?!!!
                                datasize, //缓冲区长度
                                0, //调用方式标志位, 一般为0, 改变Flags,将会改变Sendto发送的形式
                                (struct sockaddr*) &DestAddr, //(可选)指针,指向目的套接字的地址
                                sizeof(DestAddr)); //(可选)指针指向目的套接字的地址的长度
C++ Socket sendto memcpy

------解决方案--------------------
计算机组成原理→DOS命令→汇编语言→C语言(不包括C++)、代码书写规范→数据结构、编译原理、操作系统→计算机网络、数据库原理、正则表达式→其它语言(包括C++)、架构……

对学习编程者的忠告:
眼过千遍不如手过一遍!
书看千行不如手敲一行!
手敲千行不如单步一行!
单步源代码千行不如单步对应汇编一行!

VC调试时按Alt+8、Alt+7、Alt+6和Alt+5,打开汇编窗口、堆栈窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应堆栈、内存和寄存器变化,这样过一遍不就啥都明白了吗。
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
(Turbo C或Borland C用Turbo Debugger调试,Linux或Unix下用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)

想要从本质上理解C指针,必须学习汇编以及C和汇编的对应关系。
从汇编的角度理解和学习C语言的指针,原本看似复杂的东西就会变得非常简单!
指针即地址。“地址又是啥?”“只能从汇编语言和计算机组成原理的角度去解释了。”
但我又不得不承认:
 有那么些人喜欢或者适合用“先具体再抽象”的方法学习和理解复杂事物;
 而另一些人喜欢或者适合用“先抽象再具体”的方法学习和理解复杂事物。
而我本人属前者。

这辈子不看内存地址和内存值;只画链表、指针示意图,画堆栈示意图,画各种示意图,甚至自己没画过而只看过书上的图……能从本质上理解指针、理解函数参数传递吗?本人深表怀疑!
这辈子不种麦不收麦不将麦粒拿去磨面;只吃馒头、吃面条、吃面包、……甚至从没看过别人怎么蒸馒头,压面条,烤面包,……能从本质上理解面粉、理解面食吗?本人深表怀疑!!

提醒:
“学习用汇编语言写程序”

“VC调试(TC或BC用TD调试)时按Alt+8、Alt+7、Alt+6和Alt+5,打开汇编窗口、堆栈窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应堆栈、内存和寄存器变化,这样过一遍不就啥都明白了吗。