Наверное, я очень опаздываю на вечеринку.
Как уже говорилось ранее, вызов input.nextLine()
после получения вашего значения int решит вашу проблему. Причина, по которой ваш код не работал, заключается в том, что с вашего ввода (куда вы ввели int) ничего не оставалось хранить в string1
.
Рассмотрим nextLine () как нечетный среди методов nextFoo () в классе Scanner. Давайте возьмем быстрый пример. Скажем, у нас есть две строки кода, подобные приведенным ниже:
int firstNumber = input.nextInt();
int secondNumber = input.nextInt();
Если мы вводим значение ниже (как одну строку ввода)
54 234
blockquote>Значение нашей переменной
firstNumber
иsecondNumber
становится 54 и 234 соответственно. Причина, по которой это работает, заключается в том, что новый канал ( i.e\n ) НЕ НЕ автоматически генерируется, когда метод nextInt () принимает значения. Он просто берет «следующий int» и движется дальше. Это то же самое для остальных методов nextFoo (), за исключением nextLine ().nextLine () генерирует новый фид строки сразу после принятия значения; это то, что означает @RohitJain, говоря, что новый канал «потребляется».
Наконец, метод next () просто берет ближайшую строку без создания новой строки; это делает это предпочтительным методом для взятия отдельных строк в одной и той же строке.
Надеюсь, это поможет ... Веселая кодировка!
Почему использование UDF приводит к декартовому продукту вместо полного внешнего соединения?
blockquote>Причина, по которой использование UDF требует декартового произведения, довольно проста. Поскольку вы передаете произвольную функцию с возможно бесконечным доменом и не детерминированным поведением, единственным способом определить его значение является передача аргументов и оценка. Это означает, что вам просто нужно проверить все возможные пары.
Простое равенство, с другой стороны, имеет предсказуемое поведение. Если вы используете условие
t1.foo = t2.bar
, вы можете просто перетасоватьt1
иt2
строки с помощьюfoo
иbar
соответственно, чтобы получить ожидаемый результат.И, если быть точным, в реляционной алгебре внешний соединение фактически выражается с помощью естественного соединения. Все, что за этим стоит, - это просто оптимизация.
Любой способ заставить внешнее объединение над декартовым произведением
blockquote>На самом деле, если вы не хотите модифицировать движок Spark SQL.