В Java все переменные, которые вы объявляете, на самом деле являются «ссылками» на объекты (или примитивы), а не самими объектами.
При попытке выполнить один метод объекта , ссылка просит живой объект выполнить этот метод. Но если ссылка ссылается на NULL (ничего, нуль, void, nada), то нет способа, которым метод будет выполнен. Тогда runtime сообщит вам об этом, выбросив исключение NullPointerException.
Ваша ссылка «указывает» на нуль, таким образом, «Null -> Pointer».
Объект живет в памяти виртуальной машины пространство и единственный способ доступа к нему - использовать ссылки this
. Возьмем этот пример:
public class Some {
private int id;
public int getId(){
return this.id;
}
public setId( int newId ) {
this.id = newId;
}
}
И в другом месте вашего кода:
Some reference = new Some(); // Point to a new object of type Some()
Some otherReference = null; // Initiallly this points to NULL
reference.setId( 1 ); // Execute setId method, now private var id is 1
System.out.println( reference.getId() ); // Prints 1 to the console
otherReference = reference // Now they both point to the only object.
reference = null; // "reference" now point to null.
// But "otherReference" still point to the "real" object so this print 1 too...
System.out.println( otherReference.getId() );
// Guess what will happen
System.out.println( reference.getId() ); // :S Throws NullPointerException because "reference" is pointing to NULL remember...
Это важно знать - когда больше нет ссылок на объект (в пример выше, когда reference
и otherReference
оба указывают на null), тогда объект «недоступен». Мы не можем работать с ним, поэтому этот объект готов к сбору мусора, и в какой-то момент VM освободит память, используемую этим объектом, и выделит другую.
Сохраните положение окна перед завершением работы программы и восстановите их на запуске. Мультиконтрольные дисплеи просто увеличивают размер рабочего стола; другие поверхности монитора просто имеют другой раздел той же плоскости X/Y с ее источником в верхнем левом из основного монитора.
Это может быть сделано автоматически для Вас любой из нескольких компонентов .
BTW, Экранная переменная в единице Форм имеет свойство под названием MonitorCount и другое индексируемое свойство, Мониторы [Индекс: Целое число]: TMonitor. TMonitor имеет свойства, указывающие на левых, вершину, ширину, высота и т.д., таким образом, вся информация Вам нужно, там.
Глобальный Объект на экране (часть Форм) имеет понятие Мониторов. Я думаю, что это было добавлено приблизительно Delphi 6 или 7. Следующий код будет работать:
// Put the form in the upper left corner of the 2nd monitor
// if more then one monitor is present.
if Screen.MonitorCount > 1 then
begin
Left := Screen.Monitors[1].Left;
Top := Screen.Monitors[1].Top;
end;
Вы могли использовать любое положительное смещение от того положения для помещения его где угодно в тот монитор. Можно заставить ширину и высоту оттуда также знать размеры.
Я сделал подобную вещь только что в Delphi 5:
procedure TForm18.FormCreate(Sender: TObject);
var
Mon: TMonitor;
MonitorIdx: Integer;
begin
MonitorIdx := 1; // better read from configuration
if (MonitorIdx <> Monitor.MonitorNum) and (MonitorIdx < Screen.MonitorCount) then begin
Mon := Screen.Monitors[MonitorIdx];
Left := Left + Mon.Left - Monitor.Left;
Top := Top + Mon.Top - Monitor.Top;
end;
end;
Windows позволит Вам указать координаты окна в вызове API CreateWindow. Я не знаю достаточно о Delphi или Разработчике C++, чтобы знать, есть ли у Вас доступ к той части процесса.
Вы могли бы также смочь переместить окно в обработчик WM_CREATE.
EnumDisplayMonitors даст Вам координаты каждого монитора в системе.
<час> Очевидно у Delphi и Разработчика C++ есть средства, которые делают этот ответ несколько не важным. Я оставлю его здесь в случае, если кто-то сталкивается с этим вопросом, но нуждается в нем, ответил за другую среду.Я не делаю многого с системами окон, таким образом, я предложил бы взлом как это.
Захват ширина видимого рабочего стола (оба объединенные монитора), разделите его наполовину и сделайте ту свою стартовую позицию.
можно также изучить, какой API говорит Вам размеры monitor2.
Едва ли ответ, который подразумевает Ваш вопрос, но разве Вы не могли сохранить настройки окна (размер, положение, Максимизируемое состояние), когда когда-нибудь приложение закрывается и затем применяет их при запуске?