पहले इस उदाहरण को देखें:
एक साधारण सी प्रोग्राम के लिए सी कोड नीचे दिया गया है
struct Foo {
char a;
int b;
double c;
} foo1,foo2;
void foo_assign(void)
{
foo1 = foo2;
}
int main(/*char *argv[],int argc*/)
{
foo_assign();
return 0;
}
Foo_assign () के लिए समतुल्य ASM कोड है
00401050 <_foo_assign>:
401050: 55 push %ebp
401051: 89 e5 mov %esp,%ebp
401053: a1 20 20 40 00 mov 0x402020,%eax
401058: a3 30 20 40 00 mov %eax,0x402030
40105d: a1 24 20 40 00 mov 0x402024,%eax
401062: a3 34 20 40 00 mov %eax,0x402034
401067: a1 28 20 40 00 mov 0x402028,%eax
40106c: a3 38 20 40 00 mov %eax,0x402038
401071: a1 2c 20 40 00 mov 0x40202c,%eax
401076: a3 3c 20 40 00 mov %eax,0x40203c
40107b: 5d pop %ebp
40107c: c3 ret
जैसा कि आप देख सकते हैं कि असेंबली में "असाइन" निर्देश द्वारा केवल एक असाइनमेंट को प्रतिस्थापित किया जाता है, असाइनमेंट ऑपरेटर का मतलब केवल एक मेमोरी लोकेशन से दूसरे मेमोरी लोकेशन पर डेटा ले जाना है। असाइनमेंट केवल एक संरचना के तत्काल सदस्यों के लिए करेगा और जब आप किसी संरचना में कॉम्प्लेक्स डेटाटाइप करते हैं तो कॉपी करने में विफल होंगे। यहां कॉम्पलेक्स का मतलब है कि आपके पास सूचियों की ओर संकेत करने के लिए सरणी नहीं है।
एक संरचना के भीतर वर्णों की एक सरणी स्वयं ही अधिकांश संकलक पर काम नहीं करेगी, ऐसा इसलिए है क्योंकि असाइनमेंट बस डेटाटाइप को जटिल प्रकार के होने पर भी देखे बिना कॉपी करने की कोशिश करेगा।