खोज…


वाक्य - विन्यास

  • सार्वजनिक स्थैतिक शून्य main (String [] args)

पैरामीटर

पैरामीटर विवरण
आर्ग कमांड लाइन तर्क। यह मानते हुए कि main विधि जावा लॉन्चर द्वारा लगाई गई है, args गैर-अशक्त होगा, और इसमें कोई null तत्व नहीं होंगे।

टिप्पणियों

जब java कमांड (या समतुल्य) का उपयोग करके एक नियमित जावा एप्लिकेशन लॉन्च किया जाता है, तो एक main विधि कहा जाता है, कमांड लाइन से args सरणी में तर्क पारित करना।

दुर्भाग्य से, जावा एसई वर्ग पुस्तकालय कमांड तर्क प्रसंस्करण के लिए कोई प्रत्यक्ष समर्थन प्रदान नहीं करते हैं। यह आपको दो विकल्प देता है:

  • जावा में तर्क प्रसंस्करण को हाथ से लागू करें।
  • 3-पार्टी लाइब्रेरी का उपयोग करें।

यह विषय कुछ अधिक लोकप्रिय 3-पार्टी पुस्तकालयों को कवर करने का प्रयास करेगा। विकल्पों की एक विस्तृत सूची के लिए, यह उत्तर देखें StackOverflow प्रश्न "जावा में कमांड लाइन के तर्कों को कैसे पार्स करें?"

GWT टूलबेस का उपयोग करते हुए तर्क प्रसंस्करण

यदि आप अधिक जटिल कमांड-लाइन तर्कों को पार्स करना चाहते हैं, जैसे कि वैकल्पिक मापदंडों के साथ, तो Google के GWT दृष्टिकोण का उपयोग करना सबसे अच्छा है। सभी कक्षाएं सार्वजनिक रूप से उपलब्ध हैं:

https://gwt.googlesource.com/gwt/+/2.8.0-beta1/dev/core/src/com/google/gwt/util/tools/ToolBase.java

कमांड-लाइन myprogram -dir "~/Documents" -port 8888 को संभालने के लिए एक उदाहरण है:

public class MyProgramHandler extends ToolBase {
   protected File dir;
   protected int port;
   // getters for dir and port
   ...

   public MyProgramHandler() {
       this.registerHandler(new ArgHandlerDir() {
            @Override
            public void setDir(File dir) {
                this.dir = dir;
            }
       });
       this.registerHandler(new ArgHandlerInt() {
            @Override
            public String[] getTagArgs() {
               return new String[]{"port"};
            }
            @Override
            public void setInt(int value) {
               this.port = value;
            }
       });
   }
   public static void main(String[] args) {
      MyProgramHandler myShell = new MyProgramHandler();
      if (myShell.processArgs(args)) {
         // main program operation
         System.out.println(String.format("port: %d; dir: %s",
            myShell.getPort(), myShell.getDir()));
      }
      System.exit(1);
   }
}

ArgHandler में एक विधि भी है। isRequired() जो यह कहने के लिए अधिलेखित किया जा सकता है कि कमांड-लाइन तर्क की आवश्यकता है (डिफ़ॉल्ट रिटर्न false ताकि तर्क वैकल्पिक हो।

प्रसंस्करण तर्क हाथ से

जब किसी एप्लिकेशन के लिए कमांड-लाइन सिंटैक्स सरल होता है, तो कमांड तर्क प्रसंस्करण पूरी तरह से कस्टम कोड में करना उचित है।

इस उदाहरण में, हम सरल केस स्टडीज की एक श्रृंखला प्रस्तुत करेंगे। प्रत्येक मामले में, कोड त्रुटि संदेश उत्पन्न करेगा यदि तर्क अस्वीकार्य हैं, और फिर कमांड को विफल करने वाले शेल को बताने के लिए System.exit(1) को कॉल करें। (हम प्रत्येक मामले में मान लेंगे कि जावा कोड एक रैपर का उपयोग करके लागू किया गया है जिसका नाम "myapp" है।)

एक तर्क जिसके पास कोई तर्क नहीं है

इस केस-स्टडी में, कमांड को किसी तर्क की आवश्यकता नहीं है। कोड बताता है कि args.length हमें कमांड लाइन तर्कों की संख्या देती है।

public class Main {
    public static void main(String[] args) {
        if (args.length > 0) {
            System.err.println("usage: myapp");
            System.exit(1);
        }
        // Run the application
        System.out.println("It worked");
    }
}

दो तर्कों वाली एक कमान

इस केस-स्टडी में, कमांड को ठीक दो तर्कों की आवश्यकता होती है।

public class Main {
    public static void main(String[] args) {
        if (args.length != 2) {
            System.err.println("usage: myapp <arg1> <arg2>");
            System.exit(1);
        }
        // Run the application
        System.out.println("It worked: " + args[0] + ", " + args[1]);
    }
}

ध्यान दें कि अगर हमने args.length जांच करने के लिए उपेक्षा की है, तो कमांड क्रैश हो जाएगा यदि उपयोगकर्ता इसे बहुत कम कमांड-लाइन तर्कों के साथ चलाता है।

"ध्वज" विकल्पों के साथ एक कमांड और कम से कम एक तर्क

इस केस-स्टडी में, कमांड में कुछ (वैकल्पिक) ध्वज विकल्प होते हैं, और विकल्पों के बाद कम से कम एक तर्क की आवश्यकता होती है।

package tommy;
public class Main {
    public static void main(String[] args) {
        boolean feelMe = false;
        boolean seeMe = false;
        int index;
        loop: for (index = 0; index < args.length; index++) {
            String opt = args[index];
            switch (opt) {
            case "-c":
               seeMe = true;
               break;
            case "-f":
               feelMe = true;
               break;
            default:
               if (!opts.isEmpty() && opts.charAt(0) == '-') {
                   error("Unknown option: '" + opt + "');
               }
               break loop;
            }
        }
        if (index >= args.length) {
            error("Missing argument(s)");
        }      
        
        // Run the application
        // ...
    }

    private static void error(String message) {
        if (message != null) {
            System.err.println(message);
        }
        System.err.println("usage: myapp [-f] [-c] [ <arg> ...]");
        System.exit(1);
   }
}

जैसा कि आप देख सकते हैं, कमांड सिंटैक्स जटिल होने पर तर्कों और विकल्पों को संसाधित करना बोझिल हो जाता है। "कमांड लाइन पार्सिंग" लाइब्रेरी का उपयोग करना उचित है; अन्य उदाहरण देखें।



Modified text is an extract of the original Stack Overflow Documentation
के तहत लाइसेंस प्राप्त है CC BY-SA 3.0
से संबद्ध नहीं है Stack Overflow