Нужна помощь и идеи в решении проблемы сбора - PullRequest
0 голосов
/ 28 июля 2010

Я уже отправил вопрос сегодня.Этот вопрос о том же проекте, но не связан.Я занимаюсь разработкой приложения для робота Lego NXT Mindstorm.У меня есть два робота и графический пользовательский интерфейс, работающий на ПК.

В leJOS NXJ вы можете использовать только один считыватель ввода.Это означает, что вы не можете подключить ПК к двум роботам напрямую и позволить двум роботам подключаться друг к другу напрямую.Так вот что я сделал.Я подключил ПК к двум роботам напрямую, и когда два робота хотят общаться напрямую, я отправляю их сообщения через графический интерфейс.

Между графическим пользовательским интерфейсом и роботами также существует большая связькак между самими роботами.По этой причине каждый раз, когда я записываю данные в выходной поток, кажется, что некоторые данные перезаписываются другими, и система не работает должным образом.

Мне посоветовали написать класс, который будет содержатьобъект коллекции (Очередь), так что в любое время, когда робот хочет что-то отправить, он добавляет это в коллекцию (Очередь) и из того класса, который содержит объект коллекции, будет метод, позволяющий проверять коллекцию постоянно и всякий раз, когда онне является пустым, он отправляет данные из коллекции в выходной поток.

Это означает, что всякий раз, когда данные из коллекции отправляются в выходной поток, возможно добавление новых данных.

Некоторые люди предлагали мне использовать ArrayBlockQueue и т. Д., Но эти классы недоступны в файле class.jar, который использует робот.

Классы коллекций, которые я знаю в этом jar-файлеявляются векторами и очередью.

Я спрашиваю, может ли кто-нибудь помочь мне, дав мне идеюо том, как реализовать такой класс.Метод в классе будет время от времени проверять наличие данных в коллекции и отправлять их через выходной поток.Во время отправки возможно добавление новых элементов.

Поскольку данные отправляются из одного места, никакие данные не будут перезаписывать другое.Это звучит как хорошая идея.

Все ваши предложения приветствуются.

Спасибо.

1 Ответ

0 голосов
/ 28 июля 2010

Вектор хорош, потому что (по крайней мере, в JavaSE - я не знаю, что использует Mindstorms) он синхронизирован, поэтому все вызовы являются атомарными - если другой поток пытается добавить что-то в вектор при удалении из него, он будет блокироваться до тех пор, пока вы не закончите, избегая проблемы, из-за которой данные могут быть потеряны.

Кроме того, вы можете взглянуть на оболочки синхронизации в классе Collections.

В качестве альтернативы, вы могли бы сделать собственную реализацию очереди блокировки, создав подкласс стандартной очереди. Хотя и более сложная, блокирующая очередь является лучшим решением, так как она позволяет избежать занятого ожидания, когда вы неоднократно проверяете очередь и каждый раз получаете сообщение, что она пуста.

...