Я читаю Мышление в Java * Брюса Экеля , и есть упражнение, которое я просто не получаю:
Pg. 161: Упражнение 8: (4)
форма примера Lunch.java,
создать класс под названием
ConnectionManager, который управляет фиксированным
массив объектов Connection. The
клиентский программист не должен быть в состоянии
явно создать объекты подключения ,
но может получить их только через статический
метод в ConnectionManager. Когда
ConnectionManager заканчивается объектов,
возвращает нулевую ссылку. Проверьте
классы в main ().
Я придумал следующее решение:
// TestConnection.java
import java.util.*;
public class TestConnections {
public static void main( String[] args ) {
Connection cn = Connection.makeConnection();
for (int i = 0; i != 6; ++i) {
Connection tmp = ConnectionManager.newConnectiton();
if ( tmp == null )
System.out.println("Out of Connection objects");
else {
System.out.println("Got object: " + tmp );
}
}
}
}
И второй файл в том же каталоге, означающий, что все заканчивается в одном пакете по умолчанию:
// ConnectionManager.java
class Connection {
private Connection() {}
static Connection makeConnection() {
return new Connection();
}
}
public class ConnectionManager {
static private Connection[] _connections = new Connection[5];
private ConnectionManager() {}
static public Connection newConnectiton() {
for ( int i = 0; i != _connections.length; ++i ) {
if ( _connections[i] == null ) {
_connections[i] = Connection.makeConnection();
return _connections[i];
}
}
return null;
}
}
Дело в том, что клиентская программа может напрямую создавать объекты Connection через статическую фабрику Connection.makeConnection
, которая, кажется, нарушает цели упражнений. Тем не менее, если я создаю ConnectionManager.java отдельным пакетом, то импортирую его, жалуется, что не может найти определение для Connection
.
Я чувствую, что что-то происходит у меня над головой, но я не уверен, что.
Вот код для Lunch.java, на который ссылается вопрос:
//: access/Lunch.java
// Demonstrates class access specifiers. Make a class
// effectively private with private constructors:
class Soup1 {
private Soup1() {}
// (1) Allow creation via static method:
public static Soup1 makeSoup() {
return new Soup1();
}
}
class Soup2 {
private Soup2() {}
// (2) Create a static object and return a reference
// upon request.(The "Singleton" pattern):
private static Soup2 ps1 = new Soup2();
public static Soup2 access() {
return ps1;
}
public void f() {}
}
// Only one public class allowed per file:
public class Lunch {
void testPrivate() {
// Can't do this! Private constructor:
//! Soup1 soup = new Soup1();
}
void testStatic() {
Soup1 soup = Soup1.makeSoup();
}
void testSingleton() {
Soup2.access().f();
}
} ///:~