The hasNextLong() method of java.util.Scanner class returns true if the next token in this scanner’s input can be assumed as a Long value of the given radix. The scanner does not advance past any input. In case no radix is passed as a parameter, the function interprets the radix to be default radix and functions accordingly. Syntax:
public boolean hasNextLong(int radix) or public boolean hasNextLong()
Parameters: The function accepts a single parameter radix which is not a mandatory one. It specifies the radix used to interpret the token as a Long value. Return Value: This function returns true if and only if this scanner’s next token is a valid Long value in the default radix. Exceptions: The function throws IllegalStateException if this scanner is closed. Below programs illustrate the above function: Program 1:
Java
// Java program to illustrate the // hasNextLong() method of Scanner class in Java // with parameter import java.util.*; public class GFG1 { public static void main(String[] argv) throws Exception { String s = "gfg 2 geeks!"; // new scanner with the // specified String Object Scanner scanner = new Scanner(s); // use US locale to interpret Longs in a string scanner.useLocale(Locale.US); // iterate till end while (scanner.hasNext()) { // check if the scanner's // next token is a Long with a radix 3 System.out.print("" + scanner.hasNextLong( 3 )); // print what is scanned System.out.print(" -> " + scanner.next() + "\n"); } // close the scanner scanner.close(); } } |
false -> gfg true -> 2 false -> geeks!
Program 2:
Java
// Java program to illustrate the // hasNextLong() method of Scanner class in Java // without parameter import java.util.*; public class GFG1 { public static void main(String[] argv) throws Exception { String s = "gfg 2 geeks!"; // new scanner with the // specified String Object Scanner scanner = new Scanner(s); // use US locale to interpret Longs in a string scanner.useLocale(Locale.US); // iterate till end while (scanner.hasNext()) { // check if the scanner's // next token is a Long with the default radix System.out.print("" + scanner.hasNextLong()); // print what is scanned System.out.print(" -> " + scanner.next() + "\n"); } // close the scanner scanner.close(); } } |
false -> gfg true -> 2 false -> geeks!
Program 3: Program to demonstrate IllegalStateException
Java
// Java program to illustrate the // hasNextLong() method of Scanner class in Java // Exception case import java.util.*; public class GFG1 { public static void main(String[] argv) throws Exception { try { String s = "gfg 2 geeks!"; // new scanner with the // specified String Object Scanner scanner = new Scanner(s); // use US locale to interpret Longs in a string scanner.useLocale(Locale.US); scanner.close(); // iterate till end while (scanner.hasNext()) { // check if the scanner's // next token is a Long with the default radix System.out.print("" + scanner.hasNextLong()); // print what is scanned System.out.print(" -> " + scanner.next() + "\n"); } // close the scanner scanner.close(); } catch (IllegalStateException e) { System.out.println("Exception: " + e); } } } |
Exception: java.lang.IllegalStateException: Scanner closed
Reference: https://docs.oracle.com/javase/7/docs/api/java/util/Scanner.html#hasNextLong()