जावा कमांड-लाइन आर्ग्युमेंट्स की व्याख्या: बुनियादी से लेकर व्यावहारिक डिज़ाइन पैटर्न तक

目次

1. परिचय

इस अध्याय का उद्देश्य

Java कमांड‑लाइन आर्ग्युमेंट्स एक मूलभूत सुविधा है जो प्रोग्रामों को रन‑टाइम पर बाहरी मान प्राप्त करने और उसके अनुसार व्यवहार बदलने की अनुमति देती है। यह लेख String[] args का अर्थ से लेकर वास्तविक‑दुनिया के अनुप्रयोगों में उपयोग किए जाने वाले व्यावहारिक डिज़ाइन पैटर्न तक सब कुछ समझाता है। इस अध्याय में हम पहले यह स्पष्ट करेंगे कि कमांड‑लाइन आर्ग्युमेंट्स क्या कर सकते हैं और किन परिस्थितियों में वे उपयोगी होते हैं।

कमांड‑लाइन आर्ग्युमेंट्स क्या हैं?

एक Java एप्लिकेशन आमतौर पर main मेथड से शुरू होता है जिसका सिग्नेचर इस प्रकार होता है:

public class App {
    public static void main(String[] args) {
        // args is an array of strings passed at runtime
    }
}

args स्ट्रिंग्स का एक एरे है जो प्रोग्राम लॉन्च होने पर प्रदान किए गए मानों को संग्रहीत करता है। उदाहरण के लिए:

javac App.java
java App Tokyo 2025 debug

इस मामले में, args में ["Tokyo", "2025", "debug"] शामिल है।
यदि कोई आर्ग्युमेंट नहीं दिया गया, तो args.length 0 होगा।

सामान्य उपयोग केस

  • पर्यावरण या लक्ष्य बदलना : प्रोडक्शन बनाम टेस्टिंग मोड, रीजन कोड, भाषाएँ, लॉग लेवल।
  • बाहरी रूप से प्रोसेसिंग टार्गेट निर्दिष्ट करना : इनपुट फ़ाइल नाम, डायरेक्टरी, URL, ID सूची।
  • बैच प्रोसेसिंग और ऑटोमेशन : शेड्यूल्ड जॉब्स को डेट या रेंज पास करना, CI/CD पाइपलाइन से पैरामीटर इंजेक्ट करना।

इन सभी मामलों में, व्यवहार बिना पुनः कम्पाइल किए बदला जा सकता है, जिससे कमांड‑लाइन आर्ग्युमेंट्स शेल स्क्रिप्ट्स और क्रॉन जैसे जॉब शेड्यूलर्स के साथ उपयोग के लिए आदर्श बनते हैं।

प्रमुख डिज़ाइन विचार

  • आवश्यक और वैकल्पिक आर्ग्युमेंट्स को अलग रखें : यदि आवश्यक आर्ग्युमेंट्स गायब हों, तो स्पष्ट हेल्प आउटपुट या एग्ज़िट कोड के साथ विफल हों।
  • जल्दी वैलिडेट करें : संख्यात्मक या डेट मानों को यथाशीघ्र कन्वर्ट करें और अमान्य इनपुट पर स्पष्ट मार्गदर्शन प्रदान करें।
  • डिफ़ॉल्ट वैल्यू डिज़ाइन करें : वैकल्पिक आर्ग्युमेंट्स के पास सुरक्षित डिफ़ॉल्ट होना चाहिए ताकि प्रोग्राम फिर भी चल सके।
  • पढ़ने‑योग्यता और रख‑रखाव : सीधे एरे एक्सेस को बिखरने से बचें; आर्ग्युमेंट्स को संरचित ऑब्जेक्ट्स (DTOs या कॉन्फ़िगरेशन क्लासेज) में पार्स करें।

आर्ग्युमेंट्स, एनवायरनमेंट वेरिएबल्स और कॉन्फ़िग फ़ाइल्स में से चयन

  • कमांड‑लाइन आर्ग्युमेंट्स : अस्थायी ओवरराइड या जॉब‑स्पेसिफिक सेटिंग्स के लिए सबसे उपयुक्त (सबसे उच्च प्राथमिकता, स्थानीयकृत कॉन्फ़िगरेशन)।
  • एनवायरनमेंट वेरिएबल्स : सीक्रेट्स या एंडपॉइंट्स के लिए उपयुक्त जो डिप्लॉयमेंट पर्यावरण के अनुसार बदलते हैं।
  • कॉन्फ़िगरेशन फ़ाइल्स (properties/JSON/YAML) : कई सेटिंग्स को व्यवस्थित रूप से प्रबंधित करने, पुन: उपयोग और वर्ज़न कंट्रोल के साथ काम करने के लिए आदर्श।

व्यावहारिक रूप से, तीन‑परत डिज़ाइन — कॉन्फ़िग फ़ाइल्स + एनवायरनमेंट वेरिएबल्स + कमांड‑लाइन आर्ग्युमेंट्स — अच्छी तरह काम करता है, जिसमें कमांड‑लाइन आर्ग्युमेंट्स को सबसे उच्च प्राथमिकता मिलती है।

न्यूनतम उदाहरण: सभी आर्ग्युमेंट्स की सूची

public class ArgsEcho {
    public static void main(String[] args) {
        if (args.length == 0) {
            System.out.println("No arguments were provided.");
            System.out.println("Example: java ArgsEcho input.txt debug");
            return;
        }
        System.out.println("Received arguments:");
        for (int i = 0; i < args.length; i++) {
            System.out.printf("args[%d] = %s%n", i, args[i]);
        }
    }
}

इस लेख में आगे क्या कवर किया जाएगा (रोडमैप)

  • String[] args पर बेसिक ऑपरेशन्स (लेंथ चेक, एलिमेंट एक्सेस)
  • टाइप कन्वर्ज़न (int/double/boolean और एक्सेप्शन हैंडलिंग)
  • -v, --help, --mode=prod जैसे ऑप्शन फ़ॉर्मेट्स
  • IDE कॉन्फ़िगरेशन और टेस्टिंग के दौरान आर्ग्युमेंट्स पास करने का तरीका
  • एरर हैंडलिंग और सुरक्षा विचार (अमान्य इनपुट, एक्सेप्शन मैनेजमेंट)
  • व्यावहारिक उदाहरण (फ़ाइल प्रोसेसिंग, मोड स्विचिंग, लॉग लेवल कंट्रोल)

पहले, यह मूल सिद्धांत याद रखें: सभी आर्ग्युमेंट्स स्ट्रिंग्स के रूप में पास होते हैं और उपयोग से पहले उन्हें सुरक्षित रूप से कन्वर्ट और वैलिडेट किया जाना चाहिए। अगले अध्याय में, हम बेसिक सिंटैक्स और सामान्य पैटर्न को ठोस कोड उदाहरणों के साथ देखेंगे।

2. कमांड‑लाइन आर्ग्युमेंट्स क्या हैं?

मुख्य मेथड और String[] args के बीच संबंध

Java एप्लिकेशन का प्रवेश बिंदु main मेथड है, जो इस प्रकार परिभाषित है:

public static void main(String[] args)

यहाँ, args का अर्थ “आर्ग्युमेंट्स” है और यह एक स्ट्रिंग एरे है जो प्रोग्राम शुरू होने पर बाहर से पास किए गए मानों को संग्रहीत करता है
जब आप कोई प्रोग्राम चलाते हैं, तो java ClassName के बाद स्पेस द्वारा अलग किए गए मान args में क्रमिक रूप से संग्रहीत होते हैं।

उदाहरण: आर्ग्युमेंट्स के साथ चलाना

javac Sample.java
java Sample apple orange banana

इस मामले में, args की सामग्री इस प्रकार है:

IndexValue
args[0]“apple”
args[1]“orange”
args[2]“banana”

दूसरे शब्दों में, args एक चर-लंबाई वाली स्ट्रिंग सूची की तरह व्यवहार करता है, जिससे आप किसी भी संख्या में मान पास कर सकते हैं।
यदि कोई आर्ग्युमेंट निर्दिष्ट नहीं किया गया है, तो args.length 0 हो जाता है (यह कभी null नहीं होता)।

निष्पादन उदाहरण और आउटपुट

public class Sample {
    public static void main(String[] args) {
        System.out.println("Number of arguments: " + args.length);
        for (int i = 0; i < args.length; i++) {
            System.out.println("args[" + i + "] = " + args[i]);
        }
    }
}
java Sample dog cat

आउटपुट:

Number of arguments: 2
args[0] = dog
args[1] = cat

यहाँ मुख्य बिंदु यह है कि सभी आर्ग्युमेंट स्ट्रिंग्स के रूप में प्राप्त होते हैं
यदि आप उन्हें संख्याओं या बूलियन मानों के रूप में उपयोग करना चाहते हैं, तो आपको बाद में स्पष्ट रूप से उन्हें परिवर्तित करना होगा।

आपको कमांड-लाइन आर्ग्युमेंट्स कब उपयोग करने चाहिए?

कमांड-लाइन आर्ग्युमेंट्स आमतौर पर निम्नलिखित स्थितियों में उपयोग किए जाते हैं:

  • ऑपरेशन मोड बदलना उदाहरण: java Server start बनाम java Server stop विभिन्न कार्य करने के लिए।
  • फ़ाइल पाथ या कॉन्फ़िगरेशन मान निर्दिष्ट करना उदाहरण: java ReportGenerator /data/input.csv
  • स्क्रिप्ट निष्पादन के दौरान अस्थायी पैरामीटर पास करना उदाहरण: तिथियां, उपयोगकर्ता नाम, या पर्यावरण वेरिएबल्स के हल्के विकल्प के रूप में।

ये उपयोग मामलों लचीलापन बढ़ाते हैं और प्रोग्राम को बिना पुनः संकलन के बाहरी इनपुट द्वारा नियंत्रित करने की अनुमति देते हैं।

जब कोई आर्ग्युमेंट प्रदान नहीं किया जाता है तो व्यवहार

Java में main मेथड हमेशा String[] args शामिल करता है, भले ही कोई आर्ग्युमेंट पास न किया गया हो।
यदि प्रोग्राम बिना आर्ग्युमेंट के चलाया जाता है, तो args.length == 0 होता है, इसलिए नीचे दिखाए गए जैसा शर्तीय जाँच जोड़ना अनुशंसित है:

if (args.length == 0) {
    System.out.println("No arguments were specified. Exiting.");
    return;
}

यह कमांड-लाइन आर्ग्युमेंट्स की मुख्य विशेषता को दर्शाता है: वे प्रोग्राम को स्टार्टअप पर लचीला, बाहरी इनपुट प्राप्त करने की अनुमति देते हैं

सारांश

  • String[] args प्रोग्राम निष्पादन के समय पास किए गए आर्ग्युमेंट्स की सूची रखता है।
  • सभी आर्ग्युमेंट स्ट्रिंग्स के रूप में संभाले जाते हैं।
  • भले ही कोई आर्ग्युमेंट न दिया गया हो, args null नहीं बल्कि एक खाली एरे होता है।
  • आर्ग्युमेंट्स का उपयोग प्रोग्राम को लचीला, पुन: उपयोग योग्य, और स्वचालित करने में आसान बनाता है।

अगले अध्याय में, हम इस आधार पर निर्माण करेंगे और args से मान निकालने और उपयोग करने के लिए बुनियादी उपयोग पैटर्न और ठोस कोड उदाहरण प्रदर्शित करेंगे।

3. बुनियादी उपयोग और कोड उदाहरण

कमांड-लाइन आर्ग्युमेंट्स की बुनियादी सिंटैक्स

कमांड-लाइन आर्ग्युमेंट्स का उपयोग करने के लिए, आपको पहले String[] args से मान निकालने होते हैं, जो main मेथड को पास किया जाता है।
क्योंकि args एक एरे है, आप प्रत्येक तत्व को उसके इंडेक्स द्वारा एक्सेस कर सकते हैं।

public class CommandExample {
    public static void main(String[] args) {
        System.out.println("Number of arguments: " + args.length);
        if (args.length > 0) {
            System.out.println("First argument: " + args[0]);
        } else {
            System.out.println("No arguments were specified.");
        }
    }
}

प्रोग्राम को इस प्रकार चलाएँ:

javac CommandExample.java
java CommandExample hello

आउटपुट:

Number of arguments: 1
First argument: hello

जैसा कि ऊपर दिखाया गया है, args[0] पहला पास किया गया मान संग्रहीत करता है।
यदि कई आर्ग्युमेंट प्रदान किए जाते हैं, तो उन्हें args[1], args[2], आदि के रूप में एक्सेस किया जा सकता है।

सभी तर्कों को एक साथ प्रोसेस करना

जब तर्कों की संख्या परिवर्तनीय हो, तो उन्हें लूप का उपयोग करके प्रोसेस करना सामान्य है।
निम्नलिखित उदाहरण सभी प्राप्त तर्कों को क्रमिक रूप से प्रिंट करता है।

public class PrintArgs {
    public static void main(String[] args) {
        if (args.length == 0) {
            System.out.println("No arguments were provided.");
            System.out.println("Example: java PrintArgs apple orange banana");
            return;
        }

        System.out.println("Argument list:");
        for (int i = 0; i < args.length; i++) {
            System.out.printf("args[%d] = %s%n", i, args[i]);
        }
    }
}

कार्यान्वयन:

java PrintArgs apple orange banana

आउटपुट:

Argument list:
args[0] = apple
args[1] = orange
args[2] = banana

लूप का उपयोग करने से आपका प्रोग्राम किसी भी संख्या में तर्कों को संभाल सकता है।
सर्वोत्तम अभ्यास के रूप में, तत्वों तक पहुँचने से पहले हमेशा एरे की लंबाई जाँचें।

तर्क क्रम के आधार पर अर्थ निर्धारित करना

आप तर्कों को उनके क्रम के आधार पर विशिष्ट अर्थ दे सकते हैं।
उदाहरण के लिए, एक प्रोग्राम पर विचार करें जो फ़ाइल नाम, मोड, और ओवरराइट फ़्लैग को स्वीकार करता है।

public class FileProcessor {
    public static void main(String[] args) {
        if (args.length < 3) {
            System.out.println("Usage: java FileProcessor <file> <mode> <overwrite>");
            System.out.println("Example: java FileProcessor data.txt verbose true");
            return;
        }

        String fileName = args[0];
        String mode = args[1];
        boolean overwrite = Boolean.parseBoolean(args[2]);

        System.out.println("File name: " + fileName);
        System.out.println("Mode: " + mode);
        System.out.println("Overwrite enabled: " + overwrite);
    }
}

कार्यान्वयन उदाहरण:

java FileProcessor data.txt simple false

आउटपुट:

File name: data.txt
Mode: simple
Overwrite enabled: false

तर्क स्थितियों को भूमिकाएँ सौंपकर, आप लचीला प्रोग्राम नियंत्रण प्राप्त कर सकते हैं।

उदाहरण: तर्कों को संख्याओं के रूप में उपयोग करना

चूँकि सभी तर्क स्ट्रिंग के रूप में पास होते हैं, उन्हें संख्याओं के रूप में उपयोग करने के लिए प्रकार परिवर्तन आवश्यक है।
निम्नलिखित प्रोग्राम दो पूर्णांक प्राप्त करता है और उनका योग प्रिंट करता है।

public class SumArgs {
    public static void main(String[] args) {
        if (args.length < 2) {
            System.out.println("Please specify two integers.");
            return;
        }

        int a = Integer.parseInt(args[0]);
        int b = Integer.parseInt(args[1]);
        int sum = a + b;

        System.out.println("Sum: " + sum);
    }
}

कार्यान्वयन:

java SumArgs 7 13

आउटपुट:

Sum: 20

यदि "abc" जैसी गैर‑संख्यात्मक मान पास किया जाता है, तो NumberFormatException उत्पन्न होगा।
अपने प्रोग्राम को अधिक मजबूत बनाने के लिए, आपको अपवाद संभालना जोड़ना चाहिए।

अपवाद संभालने के साथ सुरक्षित कार्यान्वयन

public class SafeSum {
    public static void main(String[] args) {
        try {
            if (args.length < 2) {
                throw new IllegalArgumentException("Insufficient arguments. Please specify two integers.");
            }
            int a = Integer.parseInt(args[0]);
            int b = Integer.parseInt(args[1]);
            System.out.println("Sum: " + (a + b));
        } catch (NumberFormatException e) {
            System.out.println("One or more arguments cannot be interpreted as numbers.");
        } catch (IllegalArgumentException e) {
            System.out.println(e.getMessage());
        }
    }
}

उचित अपवाद संभालने के साथ, जब अमान्य तर्क प्रदान किए जाएँ, तो प्रोग्राम अचानक समाप्त होने के बजाय स्पष्ट संदेश लौट सकता है।

सारांश

  • कमांड‑लाइन आर्ग्युमेंट्स args एरे में स्ट्रिंग्स के रूप में पास किए जाते हैं।
  • तत्वों तक पहुँचने से पहले हमेशा args.length की जाँच करें।
  • वैरिएबल संख्या में आर्ग्युमेंट्स को संभालने के लिए लूप्स का उपयोग करें।
  • संख्यात्मक मानों को Integer.parseInt() जैसी विधियों से परिवर्तित करें।
  • उपयोगकर्ता‑मित्र व्यवहार के लिए अपवाद हैंडलिंग लागू करें।

अगले अध्याय में, हम सामान्य गलतियों और महत्वपूर्ण सावधानियों की समीक्षा करेंगे, और समझाएंगे कि अधिक सुरक्षित और पुन: उपयोग योग्य कोड कैसे लिखें।

4. सामान्य गलतियाँ और सावधानियाँ

यद्यपि कमांड‑लाइन आर्ग्युमेंट्स एक सरल तंत्र हैं, शुरुआती अक्सर कई कठिनाइयों का सामना करते हैं।
यह अध्याय सामान्य गलतियों और उन्हें रोकने के व्यावहारिक उपायों को प्रस्तुत करता है।

एरे इंडेक्स त्रुटियाँ (ArrayIndexOutOfBoundsException)

सबसे आम गलती वह इंडेक्स एक्सेस करना है जो मौजूद नहीं है।
क्योंकि args एक एरे है, यदि आप सीमा से बाहर का इंडेक्स निर्दिष्ट करते हैं तो निम्नलिखित अपवाद उत्पन्न होता है।

उदाहरण: गलत कोड

public class ErrorExample {
    public static void main(String[] args) {
        System.out.println(args[0]); // Error occurs if no arguments are provided
    }
}

कार्यान्वयन:

java ErrorExample

आउटपुट:

Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 0

उपाय

एरे तत्वों तक पहुँचने से पहले हमेशा args.length की जाँच करें।

if (args.length == 0) {
    System.out.println("No arguments were specified.");
    return;
}
System.out.println("First argument: " + args[0]);

मुख्य बिंदु:
args कभी null नहीं होता।
भले ही कोई आर्ग्युमेंट न दिया गया हो, यह लंबाई 0 वाले एरे के रूप में मौजूद रहता है।

सभी आर्ग्युमेंट्स स्ट्रिंग्स होते हैं

कमांड‑लाइन आर्ग्युमेंट्स हमेशा स्ट्रिंग्स के रूप में प्राप्त होते हैं
इसलिए संख्यात्मक गणनाएँ करने के लिए प्रकार परिवर्तन (type conversion) आवश्यक है।

int num = Integer.parseInt(args[0]);

यदि "abc" जैसी गैर‑संख्यात्मक स्ट्रिंग पास की जाती है, तो NumberFormatException उत्पन्न होगा।

उपाय: अपवाद हैंडलिंग जोड़ें

try {
    int num = Integer.parseInt(args[0]);
    System.out.println("Input value: " + num);
} catch (NumberFormatException e) {
    System.out.println("The argument cannot be interpreted as a number. Please provide a valid value.");
}

मुख्य बिंदु:
आर्ग्युमेंट्स को सीधे संख्याओं के रूप में उपयोग करना जोखिमपूर्ण है।
हमेशा मान लें कि उपयोगकर्ता द्वारा दिया गया इनपुट अमान्य हो सकता है।

स्पेस वाले आर्ग्युमेंट्स

कमांड लाइन में, स्पेस को आर्ग्युमेंट विभाजक माना जाता है
स्पेस वाले स्ट्रिंग को पास करने के लिए आपको उसे डबल कोटेशन मार्क्स में बंद करना होगा।

उदाहरण:

java Message "Hello World"

परिणाम:

args[0] = Hello World

यदि प्रोग्राम को बिना कोटेशन मार्क्स के चलाया जाता है, तो "Hello" और "World" अलग‑अलग आर्ग्युमेंट्स के रूप में माना जाता है।

मल्टीबाइट कैरेक्टर्स का हैंडलिंग

जब मल्टीबाइट कैरेक्टर्स जैसे गैर‑ASCII टेक्स्ट पास किया जाता है, तो कैरेक्टर एन्कोडिंग समस्याएँ उत्पन्न हो सकती हैं।
विशेष रूप से Windows सिस्टम पर, कंसोल एन्कोडिंग अक्सर MS932 (Shift_JIS) होती है, जो UTF‑8‑आधारित जावा प्रोग्राम्स के साथ टकरा सकती है।

उपाय:

  • निष्पादन से पहले कमांड प्रॉम्प्ट को UTF‑8 पर सेट करें (chcp 65001)।
  • IDE रन कॉन्फ़िगरेशन (Eclipse / IntelliJ IDEA) में एन्कोडिंग को UTF‑8 पर समान करें।
  • जावा स्टार्टअप विकल्प -Dfile.encoding=UTF-8 निर्दिष्ट करें।
    java -Dfile.encoding=UTF-8 Sample Hello
    

बहुत अधिक या बहुत लंबे आर्ग्युमेंट्स

ऑपरेटिंग सिस्टम के अनुसार, कमांड‑लाइन आर्ग्युमेंट्स की कुल लंबाई पर एक सीमा होती है।
Windows पर यह सीमा लगभग 8,000 अक्षर है, जबकि Linux पर यह लगभग 128 KB है।
यदि आपको बड़ी मात्रा में डेटा संभालना है, तो कमांड‑लाइन आर्ग्युमेंट्स के बजाय फ़ाइल इनपुट या स्टैंडर्ड इनपुट का उपयोग करें।

विशेष कैरेक्टर्स और एस्केपिंग

शेल्स और कमांड प्रॉम्प्ट्स में <, >, और & जैसे कुछ कैरेक्टर्स का विशेष अर्थ होता है।
इन्हें लिटरल आर्ग्युमेंट्स के रूप में पास करने के लिए, उन्हें कोटेशन मार्क्स में बंद करें या एस्केप करें।

उदाहरण:

java SymbolTest "<tag>" "&value"

यह शेल को इन वर्णों को रीडायरेक्शन या पाइप ऑपरेटर्स के रूप में गलत व्याख्या करने से रोकता है।

गलत तर्क क्रम

जब तर्क क्रम महत्वपूर्ण होता है, उपयोगकर्ता अनजाने में मानों को गलत क्रम में निर्दिष्ट कर सकते हैं।
यह विशेष रूप से इनपुट और आउटपुट फाइल नामों जैसे जोड़ों के साथ सामान्य है।

प्रतिकार उपाय:

  • नामित विकल्पों का उपयोग करें जैसे --input=input.txt (बाद के अध्यायों में कवर किया गया)।
  • एक help विकल्प प्रदान करें जो उपयोग को स्पष्ट रूप से समझाता हो।

सारांश

Error TypeCauseCountermeasure
Out-of-range accessAccessing arguments without checking countValidate with args.length
Number conversion errorDirect conversion of invalid stringsHandle with try-catch
Incorrect splittingNo quotation marks for spaced valuesUse double quotation marks
Encoding issuesCharacter set mismatchUnify to UTF-8
Special character errorsShell interpretationQuote or escape characters
Incorrect orderUser input mistakesNamed options or help output

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

5. व्यावहारिक उपयोग: प्रकार रूपांतरण, विकल्प तर्क, और डिफ़ॉल्ट मान

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

तर्कों को संख्यात्मक और बूलियन प्रकारों में रूपांतरित करना

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

संख्याओं में रूपांतरित करना

int count = Integer.parseInt(args[0]);
double rate = Double.parseDouble(args[1]);

बूलियन में रूपांतरित करना

boolean debugMode = Boolean.parseBoolean(args[2]);

उदाहरण: संख्यात्मक गणना कार्यक्रम

public class Multiply {
    public static void main(String[] args) {
        if (args.length < 2) {
            System.out.println("Usage: java Multiply <number1> <number2>");
            return;
        }

        try {
            double a = Double.parseDouble(args[0]);
            double b = Double.parseDouble(args[1]);
            System.out.println("Result: " + (a * b));
        } catch (NumberFormatException e) {
            System.out.println("One or more arguments are not numeric.");
        }
    }
}

निष्पादन:

java Multiply 4.5 3

आउटपुट:

Result: 13.5

मुख्य बिंदु:

  • अमान्य इनपुट को सुरक्षित रूप से संभालने के लिए रूपांतरणों को हमेशा try-catch ब्लॉकों में लपेटें।
  • Boolean.parseBoolean() केवल तब true लौटाता है जब मान "true" के बराबर हो, केस को अनदेखा करते हुए।

नामित विकल्प तर्कों का डिज़ाइन

तर्क क्रम पर निर्भर डिज़ाइन मानवीय त्रुटि के लिए प्रवण होते हैं।
--key=value जैसे नामित विकल्पों या -v जैसे फ्लैग्स का उपयोग करके कार्यक्रमों को अधिक सहज बनाता है।

उदाहरण: नामित विकल्पों का पार्सिंग

public class OptionParser {
    public static void main(String[] args) {
        boolean verbose = false;
        String mode = "normal";
        String file = "default.txt";

        for (String arg : args) {
            if (arg.equals("-v") || arg.equals("--verbose")) {
                verbose = true;
            } else if (arg.startsWith("--mode=")) {
                mode = arg.substring("--mode=".length());
            } else if (arg.startsWith("--file=")) {
                file = arg.substring("--file=".length());
            }
        }

        System.out.println("Mode: " + mode);
        System.out.println("File: " + file);
        System.out.println("Verbose output: " + verbose);
    }
}

निष्पादन:

java OptionParser --mode=debug --file=log.txt -v

आउटपुट:

Mode: debug
File: log.txt
Verbose output: true

मुख्य बिंदु:

  • startsWith() --key=value प्रारूपों का पता लगाना आसान बनाता है।
  • तर्क किसी भी क्रम में निर्दिष्ट किए जा सकते हैं।
  • शेल स्क्रिप्ट्स और स्वचालित कार्यों के लिए अच्छी तरह से उपयुक्त।

डिफ़ॉल्ट मान प्रदान करना

तर्कों को छोड़ दिए जाने की स्थिति में सुरक्षित डिफ़ॉल्ट मान परिभाषित करना महत्वपूर्ण है।
यह कार्यक्रम को न्यूनतम इनपुट के साथ चलाने की अनुमति देता है और अप्रत्याशित समाप्ति को रोकता है।

उदाहरण: डिफ़ॉल्ट मानों वाला कार्यक्रम

public class Greeting {
    public static void main(String[] args) {
        String name = "Guest";
        String lang = "ja";

        if (args.length > 0) name = args[0];
        if (args.length > 1) lang = args[1];

        if (lang.equals("en")) {
            System.out.println("Hello, " + name + "!");
        } else if (lang.equals("fr")) {
            System.out.println("Bonjour, " + name + "!");
        } else {
            System.out.println("Hello (default), " + name + "!");
        }
    }
}

Execution:

java Greeting Taro en

Output:

Hello, Taro!

Execution without arguments:

java Greeting

Output:

Hello (default), Guest!

Key points:

  • Safely handles missing arguments.
  • Behavior adapts based on the number of provided arguments.

Generalizing Option Parsing

For more complex tools, creating a dedicated option parser improves maintainability compared to manually processing args.

Example: Simple Option Parser

import java.util.HashMap;

public class SimpleParser {
    public static void main(String[] args) {
        HashMap<String, String> options = new HashMap<>();

        for (String arg : args) {
            if (arg.startsWith("--") && arg.contains("=")) {
                String[] pair = arg.substring(2).split("=", 2);
                options.put(pair[0], pair[1]);
            }
        }

        System.out.println("Parsed options:");
        for (String key : options.keySet()) {
            System.out.println(key + " = " + options.get(key));
        }
    }
}

Execution:

java SimpleParser --user=admin --port=8080 --mode=test

Output:

Parsed options:
user = admin
port = 8080
mode = test

Key points:

  • HashMap allows flexible storage of key-value pairs.
  • The parser can serve as a reusable foundation for CLI tools.

Practical Design Patterns

  • Few arguments : positional arguments are sufficient.
  • Many configuration values : use named options ( --key=value ).
  • Many optional values : define default values.
  • System integration and scripting : adopt consistent option conventions (e.g., --help , --config ).

Summary

FeatureApproachBenefit
Numeric/boolean conversionparseInt, parseDouble, parseBooleanEnables calculations and conditions
Named arguments--key=value formatOrder-independent and flexible
Default valuesVariable initialization and branchingSafe and user-friendly
Generic parserStore in HashMapEasy to extend and maintain

In the next chapter, we introduce real-world usage patterns, including file operations, batch processing, and mode switching commonly used in production environments.

6. Applied Examples: Common Real-World Patterns

This chapter demonstrates how command-line arguments are used in real-world scenarios.
By flexibly specifying arguments, you can build highly reusable tools for file operations, mode switching, and logging control.

Processing Files Specified by Command-Line Arguments

The most common use case is receiving a target file as a command-line argument.
This pattern is especially useful for automating file read/write operations.

Example: Reading and Displaying File Contents

import java.nio.file.*;
import java.io.IOException;

public class FileReaderTool {
    public static void main(String[] args) {
        if (args.length == 0) {
            System.out.println("Usage: java FileReaderTool <filePath>");
            return;
        }

        String filePath = args[0];
        try {
            String content = Files.readString(Paths.get(filePath));
            System.out.println("=== Contents of " + filePath + " ===");
            System.out.println(content);
        } catch (IOException e) {
            System.out.println("Failed to read file: " + e.getMessage());
        }
    }
}

Execution example:

java FileReaderTool data.txt

Sample output:

=== Contents of data.txt ===
Sample data line 1
Sample data line 2

Key points:

  • Always include file existence checks and exception handling.
  • Easy to extend for batch processing of multiple files.

Switching Program Behavior by Mode

Using arguments to switch behavior allows a single program to serve multiple roles.

Example: Mode-Based Execution

public class ModeSelector {
    public static void main(String[] args) {
        if (args.length == 0) {
            System.out.println("Usage: java ModeSelector <mode>");
            System.out.println("Available modes: test / prod / debug");
            return;
        }

        String mode = args[0].toLowerCase();

        switch (mode) {
            case "test":
                System.out.println("Running in test mode...");
                break;
            case "prod":
                System.out.println("Running in production mode...");
                break;
            case "debug":
                System.out.println("Running in debug mode with detailed logging...");
                break;
            default:
                System.out.println("Unknown mode: " + mode);
        }
    }
}

निष्पादन:

java ModeSelector debug

आउटपुट:

Running in debug mode with detailed logging...

मुख्य बिंदु:

  • विकास, परीक्षण और उत्पादन परिवेशों के बीच स्विच करने के लिए उपयोगी।
  • ऑटोमेशन स्क्रिप्ट्स और बैच जॉब्स में व्यापक रूप से उपयोग किया जाता है।

एकाधिक तर्कों के साथ गणनाओं का स्वचालन

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

public class Calculator {
    public static void main(String[] args) {
        if (args.length < 3) {
            System.out.println("Usage: java Calculator <num1> <num2> <op>");
            System.out.println("Example: java Calculator 10 5 add");
            return;
        }

        double a = Double.parseDouble(args[0]);
        double b = Double.parseDouble(args[1]);
        String op = args[2];

        switch (op) {
            case "add": System.out.println(a + b); break;
            case "sub": System.out.println(a - b); break;
            case "mul": System.out.println(a * b); break;
            case "div":
                if (b == 0) {
                    System.out.println("Division by zero is not allowed.");
                } else {
                    System.out.println(a / b);
                }
                break;
            default:
                System.out.println("Unknown operation.");
        }
    }
}

निष्पादन:

java Calculator 8 2 mul

आउटपुट:

16.0

यह विधि आपको छोटे, स्क्रिप्ट-मैत्रीपूर्ण टूल बनाने की अनुमति देती है जो ऑटोमेशन वर्कफ़्लो के साथ आसानी से एकीकृत होते हैं।

विकल्प तर्कों के साथ कॉन्फ़िगरेशन निर्दिष्ट करना

अधिक लचीले संचालन के लिए, --key=value जैसे विकल्प-शैली के तर्क अत्यंत उपयोगी होते हैं।

public class ConfigLoader {
    public static void main(String[] args) {
        String config = "default.conf";
        boolean verbose = false;

        for (String arg : args) {
            if (arg.startsWith("--config=")) {
                config = arg.substring("--config=".length());
            } else if (arg.equals("--verbose")) {
                verbose = true;
            }
        }

        System.out.println("Configuration file: " + config);
        System.out.println("Verbose logging: " + (verbose ? "ON" : "OFF"));
    }
}

निष्पादन:

java ConfigLoader --config=prod.conf --verbose

आउटपुट:

Configuration file: prod.conf
Verbose logging: ON

मुख्य बिंदु:

  • नामित विकल्प क्रम की परवाह किए बिना मानवीय त्रुटियों को कम करते हैं।
  • कॉन्फ़िगरेशन पाथ और निष्पादन मोड के लिए सामान्यतः उपयोग किया जाता है।

व्यावहारिक उदाहरण: लॉगिंग के साथ फ़ाइल प्रोसेसिंग टूल

import java.nio.file.*;
import java.io.*;

public class FileCopyTool {
    public static void main(String[] args) {
        if (args.length < 2) {
            System.out.println("Usage: java FileCopyTool <input> <output> [--verbose]");
            return;
        }

        String input = args[0];
        String output = args[1];
        boolean verbose = (args.length > 2 && args[2].equals("--verbose"));

        try {
            Files.copy(Paths.get(input), Paths.get(output), StandardCopyOption.REPLACE_EXISTING);
            if (verbose) {
                System.out.println("File copied successfully: " + input + " → " + output);
            }
        } catch (IOException e) {
            System.out.println("Copy failed: " + e.getMessage());
        }
    }
}

Execution:

java FileCopyTool report.txt backup.txt --verbose

Output:

File copied successfully: report.txt → backup.txt

Key points:

  • Logging can be toggled via options for development or production use.
  • This structure is reusable as a foundation for real-world scripts.

Summary

Use CaseTypical Argument PatternScenario
File specification<file>Input/output processing, automated backups
Mode switching<mode> or --mode=debugEnvironment-specific execution
Configuration selection--config=xxx.confSystem configuration and runtime parameters
Option control--verbose, --dry-runLogging and safe test runs
Batch processing<startDate> <endDate>Scheduled jobs and data aggregation

In the next chapter, we cover how to pass command-line arguments in IDEs and testing environments, including Eclipse and IntelliJ IDEA, along with debugging tips.

7. Testing and Debugging Tips / Configuring Arguments in IDEs

Programs that use command-line arguments can be executed and tested not only from the terminal, but also within development environments such as Eclipse and IntelliJ IDEA.
This chapter explains how to configure arguments during development and introduces tips for efficient debugging.

Setting Arguments in Eclipse

In Eclipse, you can configure command-line arguments using Run Configurations.
This allows you to run programs with predefined arguments without manually typing commands each time.

Steps:

  1. From the menu bar, select Run → Run Configurations… .
  2. From the list on the left, choose the target Java Application.
  3. Open the Arguments tab.
  4. Enter arguments in the Program arguments field, separated by spaces. Example: data.txt debug true
  5. Click Apply , then Run .

The same arguments will be reused the next time you run the program.
You can also save multiple configurations to switch between different test scenarios.

Tips:

  • Arguments may be written on separate lines; Eclipse treats them as space-separated values.
  • Strings containing spaces must be enclosed in double quotation marks (e.g., "Hello World" ).
  • To change character encoding, specify -Dfile.encoding=UTF-8 in the VM arguments field.

Setting Arguments in IntelliJ IDEA

IntelliJ IDEA provides an even more streamlined configuration process.

Steps:

  1. Open Run → Edit Configurations… .
  2. Select the configuration for the target class.
  3. Enter arguments in the Program arguments field. Example: --mode=debug --file=log.txt --verbose
  4. Click OK or Apply , then run the program.

Tips:

  • Run configurations are saved per project.
  • The same configuration is used for both Run and Debug executions.
  • You can define environment variables alongside arguments to closely simulate production environments.

Understanding Differences from Command-Line Execution

There may be differences between running a program in an IDE and running it directly from the terminal, particularly regarding environment variables and working directories.

AspectIDE ExecutionTerminal Execution
Working directoryProject root (configurable)Current shell directory
Environment variablesDefined per run configurationInherited from the shell
EncodingIDE default or configuredDepends on OS and console

Being aware of these differences helps prevent issues that only occur after deployment.

Debugging Tips for Argument-Based Programs

  • Print all received arguments at startup to verify correct input.
  • Log parsed values after validation and type conversion.
  • Use breakpoints at argument parsing logic to inspect runtime values.
  • Test edge cases such as missing arguments, invalid values, and empty strings.

Summary

  • Command-line arguments can be tested efficiently within IDEs.
  • Eclipse and IntelliJ IDEA provide built-in support for argument configuration.
  • Be mindful of differences between IDE and terminal environments.
  • Effective debugging starts with validating and logging argument values.

इन तकनीकों के साथ, आप आत्मविश्वास से जावा प्रोग्राम विकसित, परीक्षण और डिबग कर सकते हैं जो कमांड‑लाइन आर्ग्युमेंट्स पर निर्भर होते हैं, जिससे विकास और उत्पादन वातावरण में निरंतर व्यवहार सुनिश्चित होता है।