Java で文字列が整数を表しているかどうかを効果的に検証する方法
文字列に整数値が含まれているかどうかを検証する必要があるのは一般的なことです。プログラミングにおけるタスク。 Integer.parseInt() を使用し、潜在的な例外を処理する従来のアプローチは信頼性がありますが、やや面倒であると認識される場合があります。この記事では、パフォーマンスを向上させる代替ソリューションを検討します。
代替アプローチ
Jonas Klemming の提案は、従来の方法に代わる効率的な方法を提供します。この関数は、文字列内の各文字を順番にチェックし、それが数字の範囲 (0 ~ 9) 内にあることを確認します。コードは次のとおりです:
public static boolean isInteger(String str) { if (str == null) { return false; } int length = str.length(); if (length == 0) { return false; } int i = 0; if (str.charAt(0) == '-') { if (length == 1) { return false; } i = 1; } for (; i < length; i++) { char c = str.charAt(i); if (c < '0' || c > '9') { return false; } } return true; }
パフォーマンス分析
広範なベンチマークを通じて、この代替アプローチは、特に処理時に Integer.parseInt() よりも大幅に優れていることがわかりました。非整数データを使用します。このパフォーマンスの向上は、関数が文字列の文字を直接検査し、解析や例外処理に関連するオーバーヘッドをバイパスしているためです。
結論
一方、従来の Integer .parseInt() メソッドは整数検証のための簡単なオプションですが、Jonas Klemming の代替ソリューションは、パフォーマンス上の利点を提供します。精度が犠牲になります。効率が重要なアプリケーション、特に大量の非整数データを処理する場合には、代替アプローチが適切な選択です。
以上がJava文字列が整数を表しているかどうかを確認するより効率的な方法はありますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。