विधानसभा - संख्या

संख्यात्मक डेटा को आमतौर पर बाइनरी सिस्टम में दर्शाया जाता है। अंकगणितीय निर्देश बाइनरी डेटा पर काम करते हैं। जब नंबर स्क्रीन पर प्रदर्शित होते हैं या कीबोर्ड से दर्ज किए जाते हैं, तो वे ASCII फॉर्म में होते हैं।

अब तक, हमने इस इनपुट डेटा को अंकगणितीय गणनाओं के लिए ASCII फॉर्म में बाइनरी में बदल दिया है और परिणाम को बाइनरी में वापस बदल दिया है। निम्न कोड यह दिखाता है -

section	.text
   global _start        ;must be declared for using gcc
	
_start:	                ;tell linker entry point
   mov	eax,'3'
   sub     eax, '0'
	
   mov 	ebx, '4'
   sub     ebx, '0'
   add 	eax, ebx
   add	eax, '0'
	
   mov 	[sum], eax
   mov	ecx,msg	
   mov	edx, len
   mov	ebx,1	         ;file descriptor (stdout)
   mov	eax,4	         ;system call number (sys_write)
   int	0x80	         ;call kernel
	
   mov	ecx,sum
   mov	edx, 1
   mov	ebx,1	         ;file descriptor (stdout)
   mov	eax,4	         ;system call number (sys_write)
   int	0x80	         ;call kernel
	
   mov	eax,1	         ;system call number (sys_exit)
   int	0x80	         ;call kernel
	
section .data
msg db "The sum is:", 0xA,0xD 
len equ $ - msg   
segment .bss
sum resb 1

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

The sum is:
7

इस तरह के रूपांतरण, हालांकि, एक ओवरहेड है, और असेंबली भाषा प्रोग्रामिंग बाइनरी रूप में, अधिक कुशल तरीके से संख्याओं को संसाधित करने की अनुमति देता है। दशमलव संख्या को दो रूपों में दर्शाया जा सकता है -

  • ASCII फॉर्म
  • BCD या बाइनरी कोडेड दशमलव रूप

ASCII प्रतिनिधित्व

ASCII प्रतिनिधित्व में, दशमलव संख्या ASCII वर्णों के स्ट्रिंग के रूप में संग्रहीत की जाती है। उदाहरण के लिए, दशमलव मूल्य 1234 इस प्रकार है -

31	32	33	34H

जहां, 31H 1 के लिए ASCII मान है, 2 के लिए 32H ASCII मान है, और इसी तरह। ASCII प्रतिनिधित्व में प्रसंस्करण संख्या के लिए चार निर्देश हैं -

  • AAA - एडीसीआई एडिशन के बाद समायोजित करें

  • AAS - घटाव के बाद ASCII समायोजित करें

  • AAM - ASCII गुणा के बाद समायोजित करें

  • AAD - विभाजन से पहले ASCII समायोजित करें

ये निर्देश किसी भी ऑपरेंड को नहीं लेते हैं और एएल रजिस्टर में आवश्यक ऑपरेंड मान लेते हैं।

निम्नलिखित उदाहरण अवधारणा को प्रदर्शित करने के लिए AAS निर्देश का उपयोग करता है -

section	.text
   global _start        ;must be declared for using gcc
	
_start:	                ;tell linker entry point
   sub     ah, ah
   mov     al, '9'
   sub     al, '3'
   aas
   or      al, 30h
   mov     [res], ax
	
   mov	edx,len	        ;message length
   mov	ecx,msg	        ;message to write
   mov	ebx,1	        ;file descriptor (stdout)
   mov	eax,4	        ;system call number (sys_write)
   int	0x80	        ;call kernel
	
   mov	edx,1	        ;message length
   mov	ecx,res	        ;message to write
   mov	ebx,1	        ;file descriptor (stdout)
   mov	eax,4	        ;system call number (sys_write)
   int	0x80	        ;call kernel
	
   mov	eax,1	        ;system call number (sys_exit)
   int	0x80	        ;call kernel
	
section	.data
msg db 'The Result is:',0xa	
len equ $ - msg			
section .bss
res resb 1

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

The Result is:
6

बीसीडी प्रतिनिधित्व

बीसीडी प्रतिनिधित्व दो प्रकार के होते हैं -

  • अनपैक्ड बीसीडी प्रतिनिधित्व
  • पैक्ड बीसीडी प्रतिनिधित्व

अनपैक्ड बीसीडी प्रतिनिधित्व में, प्रत्येक बाइट एक दशमलव अंक के बाइनरी बराबर संग्रहीत करता है। उदाहरण के लिए, संख्या 1234 इस रूप में संग्रहीत है -

01	02	03	04H

इन नंबरों के प्रसंस्करण के लिए दो निर्देश हैं -

  • AAM - ASCII गुणा के बाद समायोजित करें

  • AAD - विभाजन से पहले ASCII समायोजित करें

चार ASCII समायोजित निर्देश, एएए, एएएस, एएएम, और एएडी का उपयोग अनपैक किए गए बीसीडी प्रतिनिधित्व के साथ भी किया जा सकता है। पैक्ड बीसीडी प्रतिनिधित्व में, प्रत्येक अंक को चार बिट्स का उपयोग करके संग्रहीत किया जाता है। दो दशमलव अंकों को एक बाइट में पैक किया जाता है। उदाहरण के लिए, संख्या 1234 इस रूप में संग्रहीत है -

12	34H

इन नंबरों के प्रसंस्करण के लिए दो निर्देश हैं -

  • DAA - जोड़ के बाद दशमलव समायोजित

  • DAS - दशमलव घटाव के बाद समायोजित करें

पैक्ड बीसीडी प्रतिनिधित्व में गुणन और विभाजन के लिए कोई समर्थन नहीं है।

उदाहरण

निम्न प्रोग्राम दो 5-अंकीय दशमलव संख्याओं को जोड़ता है और योग प्रदर्शित करता है। यह उपरोक्त अवधारणाओं का उपयोग करता है -

section	.text
   global _start        ;must be declared for using gcc

_start:	                ;tell linker entry point

   mov     esi, 4       ;pointing to the rightmost digit
   mov     ecx, 5       ;num of digits
   clc
add_loop:  
   mov 	al, [num1 + esi]
   adc 	al, [num2 + esi]
   aaa
   pushf
   or 	al, 30h
   popf
	
   mov	[sum + esi], al
   dec	esi
   loop	add_loop
	
   mov	edx,len	        ;message length
   mov	ecx,msg	        ;message to write
   mov	ebx,1	        ;file descriptor (stdout)
   mov	eax,4	        ;system call number (sys_write)
   int	0x80	        ;call kernel
	
   mov	edx,5	        ;message length
   mov	ecx,sum	        ;message to write
   mov	ebx,1	        ;file descriptor (stdout)
   mov	eax,4	        ;system call number (sys_write)
   int	0x80	        ;call kernel
	
   mov	eax,1	        ;system call number (sys_exit)
   int	0x80	        ;call kernel

section	.data
msg db 'The Sum is:',0xa	
len equ $ - msg			
num1 db '12345'
num2 db '23456'
sum db '     '

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

The Sum is:
35801