In der Go-Dokumentation heißt es, dass der FlagSet-Typ die Erstellung unabhängiger FlagSets ermöglicht, was für die Implementierung von Unterbefehlen in einem Befehl nützlich ist. Leitungsschnittstelle. Die Implementierung dieser Funktionalität kann jedoch eine Herausforderung darstellen.
Beim Definieren von zwei FlagSets kann das Parsen eines davon zu Fehlern oder Warnungen führen, wenn die Befehlszeile Flags enthält, die für das zweite FlagSet bestimmt sind. Betrachten Sie beispielsweise den folgenden Code:
f1 := flag.NewFlagSet("f1", flag.ContinueOnError) apply := f1.Bool("apply", false, "") silent := f1.Bool("silent", false, "") if err := f1.Parse(os.Args[1:]); err == nil { fmt.Println(*apply, *silent) } f2 := flag.NewFlagSet("f2", flag.ContinueOnError) reset := f2.Bool("reset", false, "") if err := f2.Parse(os.Args[1:]); err == nil { fmt.Println(*reset) }
Das Ausführen von cmd -apply oder cmd -reset generiert verschiedene Warnungen. Dieses Verhalten ist auf die fehlende Differenzierung zwischen Unterbefehlen zurückzuführen. Um diese FlagSets effektiv zu trennen, ist es notwendig, zuerst die Unterbefehle zu unterscheiden und dann das richtige FlagSet zu analysieren.
Ein Beispiel, wie dies erreicht werden kann:
f1 := flag.NewFlagSet("f1", flag.ContinueOnError) silent := f1.Bool("silent", false, "") f2 := flag.NewFlagSet("f2", flag.ContinueOnError) loud := f2.Bool("loud", false, "") switch os.Args[1] { case "apply": if err := f1.Parse(os.Args[2:]); err == nil { fmt.Println("apply", *silent) } case "reset": if err := f2.Parse(os.Args[2:]); err == nil { fmt.Println("reset", *loud) } }
Dieser Code ermöglicht das -silent Flag, das ausschließlich mit dem Unterbefehl „apply“ verwendet werden soll, und das Flag „-loud“, das ausschließlich mit dem Unterbefehl „reset“ verwendet werden soll.
Das obige ist der detaillierte Inhalt vonWie definiere und parse ich unabhängige FlagSets in Go for-Unterbefehlen richtig?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!