Fortran के उन्नत विषय: Pointers, Recursion, और Modules का परिचय

Fortran के उन्नत विषय: Pointers, Recursion, और Modules का परिचय

Fortran प्रोग्रामिंग के उन्नत (Advanced) विषय आपको अधिक जटिल और शक्तिशाली प्रोग्राम बनाने की क्षमता देते हैं। इस अध्याय में, हम Pointers, Recursion, और Modules जैसी उन्नत तकनीकों पर चर्चा करेंगे। ये फीचर्स आपके प्रोग्राम को अधिक लचीला, मॉड्यूलर, और कुशल बनाते हैं। इस अध्याय के अंत तक, आप Fortran के इन उन्नत पहलुओं को समझने और उपयोग करने में सक्षम होंगे।

Pointers

Fortran में Pointers एक उन्नत फीचर हैं, जिनका उपयोग वेरिएबल्स के लिए मेमोरी लोकेशन को संदर्भित करने के लिए किया जाता है। Pointers आपको डायनामिक मेमोरी एलोकेशन और अधिक जटिल डेटा संरचनाओं के साथ काम करने की सुविधा देते हैं। यह फीचर विशेष रूप से तब उपयोगी होता है जब प्रोग्राम के दौरान वेरिएबल्स की मेमोरी को नियंत्रित और मॉडिफाई करने की आवश्यकता होती है।

Pointers का परिचय:

Pointer एक प्रकार का वेरिएबल है, जो किसी अन्य वेरिएबल के मेमोरी एड्रेस को स्टोर करता है। इसका मतलब है कि Pointer सीधे उस वेरिएबल पर काम नहीं करता, बल्कि उसकी मेमोरी लोकेशन के माध्यम से उसके मानों को एक्सेस और मॉडिफाई करता है।

Pointers का उपयोग करके आप डायनामिक (प्रोग्राम के रन-टाइम के दौरान) मेमोरी एलोकेशन कर सकते हैं और डेटा संरचनाओं के साथ अधिक लचीलापन प्राप्त कर सकते हैं।

Pointer और Target का उपयोग:

Fortran में एक Pointer को किसी Target के साथ जोड़ने की आवश्यकता होती है। Target वह वेरिएबल है जिसका मेमोरी एड्रेस Pointer द्वारा रेफर किया जाता है।

Syntax:
Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
real, pointer :: ptr ! Pointer declaration
real, target :: var ! Target variable declaration
real, pointer :: ptr ! Pointer declaration real, target :: var ! Target variable declaration
real, pointer :: ptr  ! Pointer declaration
real, target :: var   ! Target variable declaration
Pointer Assignment:

Pointer और Target को जोड़ने के लिए => ऑपरेटर का उपयोग किया जाता है।

Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
ptr => var ! Pointer 'ptr' को 'var' का मेमोरी एड्रेस असाइन किया गया
ptr => var ! Pointer 'ptr' को 'var' का मेमोरी एड्रेस असाइन किया गया
ptr => var  ! Pointer 'ptr' को 'var' का मेमोरी एड्रेस असाइन किया गया

 

Pointer का उदाहरण:

Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
program pointer_example
real, target :: x = 10.0
real, pointer :: p
! Pointer को Target 'x' के साथ असाइन करना
p => x
! Pointer के माध्यम से मान एक्सेस और मॉडिफाई करना
print *, "Pointer के माध्यम से x का मान:", p
p = 20.0
print *, "Pointer द्वारा संशोधित x का नया मान:", x
end program pointer_example
program pointer_example real, target :: x = 10.0 real, pointer :: p ! Pointer को Target 'x' के साथ असाइन करना p => x ! Pointer के माध्यम से मान एक्सेस और मॉडिफाई करना print *, "Pointer के माध्यम से x का मान:", p p = 20.0 print *, "Pointer द्वारा संशोधित x का नया मान:", x end program pointer_example
program pointer_example
    real, target :: x = 10.0
    real, pointer :: p

    ! Pointer को Target 'x' के साथ असाइन करना
    p => x

    ! Pointer के माध्यम से मान एक्सेस और मॉडिफाई करना
    print *, "Pointer के माध्यम से x का मान:", p
    p = 20.0
    print *, "Pointer द्वारा संशोधित x का नया मान:", x
end program pointer_example

स्पष्टीकरण:

  • x एक target वेरिएबल है, और p एक Pointer है।
  • p => x से Pointer को x का मेमोरी एड्रेस दिया गया।
  • इसके बाद, p के माध्यम से x के मान को एक्सेस किया गया और फिर संशोधित किया गया।

डायनामिक मेमोरी एलोकेशन:

Pointers का एक मुख्य लाभ यह है कि आप इसके माध्यम से डायनामिक मेमोरी एलोकेशन कर सकते हैं। इसका मतलब है कि आप प्रोग्राम के रन-टाइम पर वेरिएबल्स के लिए मेमोरी आवंटित (allocate) और मुक्त (deallocate) कर सकते हैं।

डायनामिक एलोकेशन का उदाहरण:
Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
program dynamic_allocation_example
real, pointer :: ptr
integer :: n
! यूज़र से Array का साइज लेना
print *, "Array का साइज दर्ज करें:"
read *, n
! डायनामिक मेमोरी एलोकेशन
allocate(ptr(n))
! Pointer के माध्यम से Array में मान असाइन करना
ptr = [(i, i = 1, n)]
! Array के मान प्रिंट करना
print *, "Pointer Array के मान हैं:", ptr
! मेमोरी को मुक्त करना (Deallocate)
deallocate(ptr)
end program dynamic_allocation_example
program dynamic_allocation_example real, pointer :: ptr integer :: n ! यूज़र से Array का साइज लेना print *, "Array का साइज दर्ज करें:" read *, n ! डायनामिक मेमोरी एलोकेशन allocate(ptr(n)) ! Pointer के माध्यम से Array में मान असाइन करना ptr = [(i, i = 1, n)] ! Array के मान प्रिंट करना print *, "Pointer Array के मान हैं:", ptr ! मेमोरी को मुक्त करना (Deallocate) deallocate(ptr) end program dynamic_allocation_example
program dynamic_allocation_example
    real, pointer :: ptr
    integer :: n

    ! यूज़र से Array का साइज लेना
    print *, "Array का साइज दर्ज करें:"
    read *, n

    ! डायनामिक मेमोरी एलोकेशन
    allocate(ptr(n))

    ! Pointer के माध्यम से Array में मान असाइन करना
    ptr = [(i, i = 1, n)]

    ! Array के मान प्रिंट करना
    print *, "Pointer Array के मान हैं:", ptr

    ! मेमोरी को मुक्त करना (Deallocate)
    deallocate(ptr)
end program dynamic_allocation_example

स्पष्टीकरण:

  • इस प्रोग्राम में, यूज़र से एक Array का साइज लिया गया और डायनामिकली मेमोरी allocate की गई।
  • Pointer का उपयोग करके Array के मान असाइन किए गए और उन्हें प्रिंट किया गया।
  • अंत में, deallocate स्टेटमेंट का उपयोग करके मेमोरी को मुक्त कर दिया गया।

Pointer का उपयोग:

Pointers का उपयोग मुख्य रूप से निम्नलिखित कार्यों के लिए किया जाता है:

  1. डायनामिक मेमोरी एलोकेशन: प्रोग्राम रन-टाइम के दौरान मेमोरी आवंटित और मुक्त करने के लिए।
  2. डेटा स्ट्रक्चर: Pointers का उपयोग जटिल डेटा संरचनाओं (जैसे linked lists) में किया जाता है।
  3. फ्लेक्सिबल प्रोग्रामिंग: Pointers आपको मेमोरी और वेरिएबल्स के साथ अधिक लचीलापन प्रदान करते हैं, जिससे आपका प्रोग्राम अधिक कुशल और मॉड्यूलर बनता है।

Pointers Fortran में मेमोरी और वेरिएबल्स के साथ डायनामिक रूप से काम करने के लिए एक शक्तिशाली फीचर हैं। वे डायनामिक मेमोरी एलोकेशन और जटिल डेटा संरचनाओं के साथ काम करना आसान बनाते हैं। हालांकि Pointers का उपयोग करते समय सावधानी की आवश्यकता होती है, क्योंकि अनुचित मेमोरी प्रबंधन से प्रोग्राम त्रुटियों (errors) का सामना कर सकता है। सही तरीके से उपयोग किए जाने पर, Pointers आपके प्रोग्राम को अधिक कुशल और लचीला बनाते हैं।

Recursion

Fortran में Recursion एक महत्वपूर्ण प्रोग्रामिंग तकनीक है, जहाँ एक फ़ंक्शन खुद को कॉल करता है। Recursive Functions का उपयोग तब किया जाता है जब किसी समस्या को छोटे भागों में विभाजित किया जा सकता है, और हर भाग का समाधान उसी प्रक्रिया का उपयोग करके किया जा सकता है। यह तकनीक जटिल समस्याओं को हल करने के लिए बहुत उपयोगी होती है, जैसे गणितीय समस्याएँ (फ़ैक्टोरियल, फ़िबोनैचि सीरीज़, आदि)।

Recursive Functions का परिचय:

Recursive Function एक ऐसा फ़ंक्शन होता है जो अपनी परिभाषा के अंदर खुद को कॉल करता है। यह तब तक खुद को कॉल करता रहता है जब तक कि एक निश्चित शर्त (base case) पूरी नहीं हो जाती। Base case वह स्थिति होती है जहाँ Recursion को रोक दिया जाता है।

Recursive Function का सिंटैक्स:
Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
recursive function function_name(arguments) result(result_name)
! Function का कोड
end function function_name
recursive function function_name(arguments) result(result_name) ! Function का कोड end function function_name
recursive function function_name(arguments) result(result_name)
    ! Function का कोड
end function function_name
  • recursive: यह कीवर्ड फ़ंक्शन को बताता है कि यह Recursion का समर्थन करता है।
  • result(result_name): यह फ़ंक्शन द्वारा लौटाए जाने वाले परिणाम को निर्दिष्ट करता है।

1. Recursive Function का एक सरल उदाहरण (Factorial):

फ़ैक्टोरियल की गणना एक क्लासिक उदाहरण है जो Recursion का उपयोग करता है। फ़ैक्टोरियल एक संख्या का गुणनफल होता है, और इसे निम्नलिखित रूप में परिभाषित किया जा सकता है: n!=n×(n−1)!n! = n \times (n – 1)! और, 0!=10! = 1 (Base Case)।

उदाहरण:
Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
program factorial_example
integer :: num, result
print *, "कृपया एक संख्या दर्ज करें:"
read *, num
result = factorial(num)
print *, "फ़ैक्टोरियल", num, "का मान है:", result
end program factorial_example
recursive function factorial(n) result(fact)
integer :: n, fact
if (n == 0) then
fact = 1 ! Base case: 0! = 1
else
fact = n * factorial(n - 1) ! Recursive call
end if
end function factorial
program factorial_example integer :: num, result print *, "कृपया एक संख्या दर्ज करें:" read *, num result = factorial(num) print *, "फ़ैक्टोरियल", num, "का मान है:", result end program factorial_example recursive function factorial(n) result(fact) integer :: n, fact if (n == 0) then fact = 1 ! Base case: 0! = 1 else fact = n * factorial(n - 1) ! Recursive call end if end function factorial
program factorial_example
    integer :: num, result

    print *, "कृपया एक संख्या दर्ज करें:"
    read *, num

    result = factorial(num)
    print *, "फ़ैक्टोरियल", num, "का मान है:", result
end program factorial_example

recursive function factorial(n) result(fact)
    integer :: n, fact

    if (n == 0) then
        fact = 1   ! Base case: 0! = 1
    else
        fact = n * factorial(n - 1)  ! Recursive call
    end if
end function factorial

स्पष्टीकरण:

  • factorial फ़ंक्शन खुद को तब तक कॉल करता रहता है जब तक कि n की मान 0 नहीं हो जाती (Base case)।
  • जैसे ही n == 0, फ़ंक्शन 1 लौटाता है, और फ़ैक्टोरियल की गणना Recursion की मदद से पूरी होती है।

2. फ़िबोनैचि सीरीज़ के लिए Recursive Function:

फ़िबोनैचि सीरीज़ एक ऐसी सीरीज़ है जिसमें प्रत्येक संख्या पिछले दो संख्याओं का योग होती है। इसे भी Recursive Function द्वारा हल किया जा सकता है।

उदाहरण:
Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
program fibonacci_example
integer :: num, i
print *, "कृपया सीरीज़ की सीमा दर्ज करें:"
read *, num
print *, "फ़िबोनैचि सीरीज़:"
do i = 0, num - 1
print *, fibonacci(i)
end do
end program fibonacci_example
recursive function fibonacci(n) result(fib)
integer :: n, fib
if (n == 0) then
fib = 0 ! Base case 1
elseif (n == 1) then
fib = 1 ! Base case 2
else
fib = fibonacci(n - 1) + fibonacci(n - 2) ! Recursive call
end if
end function fibonacci
program fibonacci_example integer :: num, i print *, "कृपया सीरीज़ की सीमा दर्ज करें:" read *, num print *, "फ़िबोनैचि सीरीज़:" do i = 0, num - 1 print *, fibonacci(i) end do end program fibonacci_example recursive function fibonacci(n) result(fib) integer :: n, fib if (n == 0) then fib = 0 ! Base case 1 elseif (n == 1) then fib = 1 ! Base case 2 else fib = fibonacci(n - 1) + fibonacci(n - 2) ! Recursive call end if end function fibonacci
program fibonacci_example
    integer :: num, i

    print *, "कृपया सीरीज़ की सीमा दर्ज करें:"
    read *, num

    print *, "फ़िबोनैचि सीरीज़:"
    do i = 0, num - 1
        print *, fibonacci(i)
    end do
end program fibonacci_example

recursive function fibonacci(n) result(fib)
    integer :: n, fib

    if (n == 0) then
        fib = 0   ! Base case 1
    elseif (n == 1) then
        fib = 1   ! Base case 2
    else
        fib = fibonacci(n - 1) + fibonacci(n - 2)  ! Recursive call
    end if
end function fibonacci

स्पष्टीकरण:

  • fibonacci फ़ंक्शन दो Base cases (0 और 1) का उपयोग करता है।
  • उसके बाद, हर संख्या को पिछले दो संख्याओं के योग से गणना की जाती है, और फ़िबोनैचि सीरीज़ को प्रिंट किया जाता है।

Recursion का उपयोग:

Recursion का उपयोग तब किया जाता है जब किसी समस्या को बार-बार छोटे भागों में विभाजित करना संभव हो। कुछ प्रमुख उपयोग निम्नलिखित हैं:

  1. गणितीय समस्याएँ: फ़ैक्टोरियल, फ़िबोनैचि, आदि जैसी समस्याओं को हल करने में।
  2. डेटा स्ट्रक्चर: Recursion का उपयोग पेड़ों (trees) और ग्राफ़्स (graphs) जैसे डेटा संरचनाओं के साथ किया जाता है।
  3. समस्याओं को विभाजित और हल करना (Divide and Conquer): Recursion का उपयोग विभाजित और जीतें (Divide and Conquer) एल्गोरिद्म में किया जाता है, जैसे कि Merge Sort और Quick Sort।

Recursive Functions के लाभ:

  1. सरलता: Recursion जटिल समस्याओं को हल करने के लिए एक स्वाभाविक और सरल तरीका है।
  2. Modularity: Recursion का उपयोग करके आप समस्याओं को छोटे, पुनरावृत्त (iterative) हिस्सों में विभाजित कर सकते हैं।
  3. Flexible: यह तकनीक डेटा संरचनाओं और एल्गोरिद्म के लिए अधिक लचीलापन प्रदान करती है।

Recursive Functions की चुनौतियाँ:

  1. प्रदर्शन (Performance): कभी-कभी Recursion का अत्यधिक उपयोग प्रदर्शन को प्रभावित कर सकता है, क्योंकि प्रत्येक Recursive कॉल मेमोरी स्टैक में स्थान लेता है।
  2. Stack Overflow: गलत तरीके से उपयोग किए जाने पर, Recursion अनंत लूप (infinite recursion) में फंस सकता है, जिससे Stack Overflow त्रुटियाँ हो सकती हैं।

Recursive Functions Fortran में जटिल समस्याओं को छोटे और आसान भागों में विभाजित करके हल करने के लिए एक शक्तिशाली उपकरण हैं। सही तरीके से उपयोग करने पर, Recursion आपको गणितीय समस्याओं, डेटा संरचनाओं, और एल्गोरिद्म को अधिक आसानी से हल करने में मदद करता है। हालांकि, इसे सावधानी से इस्तेमाल करना चाहिए, क्योंकि यह प्रदर्शन और मेमोरी के मामले में चुनौतीपूर्ण हो सकता है।

Modules और Libraries

Fortran में Modules और Libraries का उपयोग प्रोग्राम को बेहतर ढंग से संगठित करने और पुन: उपयोग करने योग्य कोड बनाने के लिए किया जाता है। Modules के माध्यम से आप Functions, Subroutines, और वेरिएबल्स को एक जगह संग्रहित कर सकते हैं, जिन्हें प्रोग्राम में कहीं भी उपयोग किया जा सकता है। Libraries आपको पहले से निर्मित कोड (फ़ंक्शंस, Subroutines) का उपयोग करने की अनुमति देती हैं, जिससे आपका कोड अधिक कुशल और सरल बन जाता है।

Modules का उपयोग और प्रैक्टिस:

Modules Fortran में एक शक्तिशाली फीचर हैं, जिनका उपयोग कोड को encapsulate करने और पुन: उपयोग करने के लिए किया जाता है। आप किसी भी Subroutines, Functions, या डेटा को Modules में संग्रहीत कर सकते हैं और फिर किसी अन्य प्रोग्राम या मॉड्यूल से उन्हें इम्पोर्ट कर सकते हैं।

Modules का Syntax:
Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
module module_name
! वेरिएबल्स और Subroutines की डिक्लेरेशन
contains
! Functions और Subroutines
end module module_name
module module_name ! वेरिएबल्स और Subroutines की डिक्लेरेशन contains ! Functions और Subroutines end module module_name
module module_name
    ! वेरिएबल्स और Subroutines की डिक्लेरेशन
contains
    ! Functions और Subroutines
end module module_name
  • module: यह कीवर्ड मॉड्यूल को परिभाषित करता है।
  • contains: यह बताता है कि मॉड्यूल के अंदर कौन-कौन से Functions या Subroutines शामिल हैं।

Modules का उदाहरण:

Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
program module_example
use math_module ! मॉड्यूल इम्पोर्ट करना
real :: x = 5.0, result
result = square(x) ! मॉड्यूल में परिभाषित फंक्शन का उपयोग
print *, "5 का वर्ग:", result
end program module_example
module math_module
contains
function square(a) result(res)
real :: a, res
res = a * a
end function square
end module math_module
program module_example use math_module ! मॉड्यूल इम्पोर्ट करना real :: x = 5.0, result result = square(x) ! मॉड्यूल में परिभाषित फंक्शन का उपयोग print *, "5 का वर्ग:", result end program module_example module math_module contains function square(a) result(res) real :: a, res res = a * a end function square end module math_module
program module_example
    use math_module  ! मॉड्यूल इम्पोर्ट करना
    real :: x = 5.0, result

    result = square(x)  ! मॉड्यूल में परिभाषित फंक्शन का उपयोग
    print *, "5 का वर्ग:", result
end program module_example

module math_module
contains
    function square(a) result(res)
        real :: a, res
        res = a * a
    end function square
end module math_module

स्पष्टीकरण:

  • math_module नाम का एक मॉड्यूल परिभाषित किया गया है, जिसमें square नाम का फ़ंक्शन है।
  • use math_module स्टेटमेंट का उपयोग करके हमने इस मॉड्यूल को अपने प्रोग्राम में इम्पोर्ट किया और फिर square फ़ंक्शन को कॉल किया।

Modules के उपयोग के लाभ:

  1. कोड का पुन: उपयोग (Reusability): Modules का उपयोग करके आप एक बार कोड लिखकर उसे कई स्थानों पर आसानी से उपयोग कर सकते हैं।
  2. बेहतर संगठन (Better Organization): Modules प्रोग्राम को अधिक संगठित और स्पष्ट बनाते हैं, क्योंकि आप विभिन्न कार्यों को एक ही मॉड्यूल में समूहित कर सकते हैं।
  3. Modularity: Modules प्रोग्राम को मॉड्यूलर बनाते हैं, जिससे कोड को मैनेज और डिबग करना आसान होता है।

Libraries का उपयोग:

Fortran में Libraries का उपयोग आपको पहले से निर्मित कोड या विशेष गणितीय, वैज्ञानिक, और तकनीकी कार्यों के लिए तैयार किए गए Functions और Subroutines का उपयोग करने की अनुमति देता है। Libraries को उपयोग करने के लिए आपको उन्हें अपने प्रोग्राम में इम्पोर्ट करना होता है।

Libraries को Import करने का Syntax:
Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
use library_name
use library_name
use library_name

आपको बस use स्टेटमेंट का उपयोग करके लाइब्रेरी को अपने प्रोग्राम में इम्पोर्ट करना होता है, और उसके बाद आप उसमें परिभाषित सभी Functions और Subroutines का उपयोग कर सकते हैं।

Libraries का उदाहरण:

मान लें कि आपके पास math_library नाम की एक लाइब्रेरी है, जो गणितीय फ़ंक्शंस प्रदान करती है, जैसे कि किसी संख्या का वर्गमूल (square root) निकालना।

Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
program library_example
use math_library ! लाइब्रेरी को इम्पोर्ट करना
real :: x = 9.0, result
! लाइब्रेरी से square_root फ़ंक्शन को कॉल करना
result = square_root(x)
print *, "9 का वर्गमूल:", result
end program library_example
program library_example use math_library ! लाइब्रेरी को इम्पोर्ट करना real :: x = 9.0, result ! लाइब्रेरी से square_root फ़ंक्शन को कॉल करना result = square_root(x) print *, "9 का वर्गमूल:", result end program library_example
program library_example
    use math_library  ! लाइब्रेरी को इम्पोर्ट करना
    real :: x = 9.0, result

    ! लाइब्रेरी से square_root फ़ंक्शन को कॉल करना
    result = square_root(x)
    print *, "9 का वर्गमूल:", result
end program library_example
Libraries का उपयोग कैसे करें:
  1. सिस्टम या थर्ड-पार्टी Libraries: Fortran में कई गणितीय और वैज्ञानिक Libraries उपलब्ध हैं, जैसे कि LAPACK, BLAS, और FFTW। इन्हें अपने प्रोग्राम में इम्पोर्ट करने से आप जटिल गणितीय कार्यों को आसानी से कर सकते हैं।
  2. कस्टम Libraries: आप अपनी खुद की Libraries बना सकते हैं, जिसमें आप Frequently used Functions और Subroutines को रख सकते हैं।
Libraries के उदाहरण:
  1. LAPACK (Linear Algebra PACKage): यह लाइब्रेरी Linear Algebra की समस्याओं को हल करने के लिए उपयोग की जाती है।
  2. BLAS (Basic Linear Algebra Subprograms): BLAS का उपयोग बेसिक linear algebra ऑपरेशन्स के लिए किया जाता है।
  3. FFTW (Fastest Fourier Transform in the West): यह लाइब्रेरी Fourier Transform करने के लिए उपयोग की जाती है।

Libraries के लाभ:

  1. समय की बचत (Time-Saving): Libraries का उपयोग करके आपको जटिल गणनाओं के लिए कोड लिखने की आवश्यकता नहीं होती। आप पहले से बने Functions का उपयोग कर सकते हैं।
  2. प्रदर्शन (Performance): कई Libraries को विशेष रूप से कुशल और तेज़ गणना के लिए डिज़ाइन किया गया है, जिससे आपका प्रोग्राम अधिक प्रभावी होता है।
  3. पुन: उपयोग (Reusability): Libraries आपको बार-बार कोड लिखने से बचाती हैं। आप एक ही लाइब्रेरी को विभिन्न प्रोग्राम्स में उपयोग कर सकते हैं।

Modules और Libraries Fortran में कोड को पुन: उपयोग और संगठित करने के लिए अत्यधिक महत्वपूर्ण फीचर्स हैं। Modules का उपयोग आपको अपने Functions और Subroutines को एक जगह पर संरक्षित करने की सुविधा देता है, जबकि Libraries आपको पहले से निर्मित और कुशल कोड का उपयोग करने की अनुमति देती हैं। इनका सही उपयोग करने से आप अपने प्रोग्राम को अधिक शक्तिशाली, मॉड्यूलर, और प्रभावी बना सकते हैं।



Index