當前位置: 首頁>>代碼示例>>Java>>正文


Java ServerSocket.bind方法代碼示例

本文整理匯總了Java中java.net.ServerSocket.bind方法的典型用法代碼示例。如果您正苦於以下問題:Java ServerSocket.bind方法的具體用法?Java ServerSocket.bind怎麽用?Java ServerSocket.bind使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.net.ServerSocket的用法示例。


在下文中一共展示了ServerSocket.bind方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: printSockets

import java.net.ServerSocket; //導入方法依賴的package包/類
@Test
public void printSockets() throws IOException {
	
	ServerSocket ss = new ServerSocket();
	ss.bind(sock(5000));
	
	Socket s1 = new Socket();
	Socket s2 = new Socket();
	
	s1.connect(sock(5000));
	s2.connect(sock(5000));
	
	ss.close();
	s1.close();
	// s2 remains unclosed
	
	HeapImage hi = HeapUnit.captureHeap();
	
	for(HeapInstance i: hi.instances(SocketImpl.class)) {
		// fd field in SocketImpl class is nullified when socket gets closed
		boolean open = i.value("fd") != null;
		System.out.println(i.rehydrate() + (open ? " - open" : " - closed"));
	}
}
 
開發者ID:aragozin,項目名稱:heapunit,代碼行數:25,代碼來源:DumpSocketsExample.java

示例2: getAvailablePort

import java.net.ServerSocket; //導入方法依賴的package包/類
private int getAvailablePort(int fromPort, int toPort) {
	if (toPort <= fromPort) return fromPort;
	int count = 50;
	int step = (toPort - fromPort) / count;
	while (count > 0) {
		int port = fromPort + (50-count) * step + random.nextInt(step);
		try {
		    ServerSocket s = new ServerSocket();
		    s.bind(new InetSocketAddress("localhost", port));
		    s.close();			    
		} catch (IOException ex) {
			--count;
		    continue;
		}
		return port;
	}
	return random.nextInt((toPort-fromPort)) + fromPort;
	
}
 
開發者ID:kefik,項目名稱:Pogamut3,代碼行數:20,代碼來源:UT2004TCServer.java

示例3: listen

import java.net.ServerSocket; //導入方法依賴的package包/類
private void listen() throws IOException {
	ServerSocket ss = new ServerSocket();
	ss.bind(listenAddress);
	TokenBucket bucket = new TokenBucket();
	bucket.start();
	try {
		while (true) {
			Socket s = ss.accept();
			System.out.println("Incoming connection");
			bucket.waitForToken();
			new ReportSaver(s).start();
		}
	} catch (InterruptedException e) {
		System.err.println("Interrupted while listening");
	} finally {
		tryToClose(ss);
	}
}
 
開發者ID:rafjordao,項目名稱:Nird2,代碼行數:19,代碼來源:DevReportServer.java

示例4: openServerSocket

import java.net.ServerSocket; //導入方法依賴的package包/類
public final void openServerSocket(InetAddress address, int tcpPort) throws IOException
{
	final ServerSocketChannel selectable = ServerSocketChannel.open();
	selectable.configureBlocking(false);
	
	final ServerSocket ss = selectable.socket();
	
	if (address != null)
	{
		ss.bind(new InetSocketAddress(address, tcpPort));
	}
	else
	{
		ss.bind(new InetSocketAddress(tcpPort));
	}
	
	selectable.register(_selector, SelectionKey.OP_ACCEPT);
}
 
開發者ID:rubenswagner,項目名稱:L2J-Global,代碼行數:19,代碼來源:SelectorThread.java

示例5: testBind

import java.net.ServerSocket; //導入方法依賴的package包/類
@Test
public void testBind() throws Exception {
  Configuration conf = new Configuration();
  ServerSocket socket = new ServerSocket();
  InetSocketAddress address = new InetSocketAddress("0.0.0.0",0);
  socket.bind(address);
  try {
    int min = socket.getLocalPort();
    int max = min + 100;
    conf.set("TestRange", min+"-"+max);
    

    ServerSocket socket2 = new ServerSocket();
    InetSocketAddress address2 = new InetSocketAddress("0.0.0.0", 0);
    Server.bind(socket2, address2, 10, conf, "TestRange");
    try {
      assertTrue(socket2.isBound());
      assertTrue(socket2.getLocalPort() > min);
      assertTrue(socket2.getLocalPort() <= max);
    } finally {
      socket2.close();
    }
  } finally {
    socket.close();
  }
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:27,代碼來源:TestServer.java

示例6: GroupOwnerSocketHandler

import java.net.ServerSocket; //導入方法依賴的package包/類
public GroupOwnerSocketHandler(Handler handler) throws IOException {
    try {
        server_socket = new ServerSocket();
        server_socket.setReuseAddress(true);
        server_socket.bind(new InetSocketAddress(WiFiDirectCommunicator.PORT));
        this.handler = handler;
        Log.d(TAG, "Socket Started");
    } catch (IOException e) {
        e.printStackTrace();
        pool.shutdownNow();
        throw e;
    }

}
 
開發者ID:jphacks,項目名稱:TK_1701,代碼行數:15,代碼來源:GroupOwnerSocketHandler.java

示例7: getSocketPair

import java.net.ServerSocket; //導入方法依賴的package包/類
private static Socket getSocketPair() throws IOException {
    ServerSocket ss = new ServerSocket();
    ss.bind(null);
    InetSocketAddress endPoint = (InetSocketAddress) ss
            .getLocalSocketAddress();
    Socket s = new Socket(endPoint.getAddress(), endPoint.getPort());
    s.setSoTimeout(5000);
    return s;
}
 
開發者ID:l294265421,項目名稱:ZooKeeper,代碼行數:10,代碼來源:QuorumCnxManagerTest.java

示例8: ConnectionListener

import java.net.ServerSocket; //導入方法依賴的package包/類
public ConnectionListener() throws IOException
{
	socket = new ServerSocket();
	socket.bind(null);

	group = new ThreadGroup("Connections");
	setDaemon(true);
	setName("Connection Listener");
}
 
開發者ID:nickbattle,項目名稱:FJ-VDMJ,代碼行數:10,代碼來源:ConnectionListener.java

示例9: testWildcardAddressBound

import java.net.ServerSocket; //導入方法依賴的package包/類
@Test
public void testWildcardAddressBound() throws IOException {
  // assumeFalse(SystemUtils.isWindows()); // See bug #39368
  socket = new ServerSocket();
  int port = AvailablePort.getRandomAvailablePort(AvailablePort.SOCKET);
  socket.bind(new InetSocketAddress((InetAddress) null, port));
  System.out.println(
      "bind addr=" + System.getProperty(DistributionConfig.GEMFIRE_PREFIX + "bind-address"));
  assertFalse(AvailablePort.isPortAvailable(port, AvailablePort.SOCKET));
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:11,代碼來源:AvailablePortJUnitTest.java

示例10: createServerSocket

import java.net.ServerSocket; //導入方法依賴的package包/類
protected ServerSocket createServerSocket() throws IOException {
    ServerSocket ss = new ServerSocket();
    InetSocketAddress address = new InetSocketAddress(InetAddress
            .getByName("localhost"), port);
    ss.bind(address);
    return ss;
}
 
開發者ID:Vitaliy-Yakovchuk,項目名稱:ramus,代碼行數:8,代碼來源:Server.java

示例11: getSocketPair

import java.net.ServerSocket; //導入方法依賴的package包/類
static Socket[] getSocketPair() throws IOException {
    ServerSocket ss = new ServerSocket();
    ss.bind(null);
    InetSocketAddress endPoint = (InetSocketAddress) ss.getLocalSocketAddress();
    Socket s = new Socket(endPoint.getAddress(), endPoint.getPort());
    return new Socket[] { s, ss.accept() };
}
 
開發者ID:l294265421,項目名稱:ZooKeeper,代碼行數:8,代碼來源:Zab1_0Test.java

示例12: SocketRunnable

import java.net.ServerSocket; //導入方法依賴的package包/類
public SocketRunnable(int port, String pluginName, File pluginsFolder) {
	this.pluginName = pluginName;
	this.pluginsFolder = pluginsFolder;
	try  {
		serverSocket = new ServerSocket();
		serverSocket.bind(new InetSocketAddress("localhost", port));
	} catch (IOException e) {
		e.printStackTrace();
	}
	Bukkit.getLogger().info("Waiting...");
}
 
開發者ID:syuchan1005,項目名稱:MCPluginDebuggerforMC,代碼行數:12,代碼來源:SocketRunnable.java

示例13: testFollowerConversation

import java.net.ServerSocket; //導入方法依賴的package包/類
public void testFollowerConversation(FollowerConversation conversation) throws Exception {
    File tmpDir = File.createTempFile("test", "dir", testData);
    tmpDir.delete();
    tmpDir.mkdir();
    Thread followerThread = null;
    ConversableFollower follower = null;
    QuorumPeer peer = null;
    try {
        peer = createQuorumPeer(tmpDir);
        follower = createFollower(tmpDir, peer);
        peer.follower = follower;
        
        ServerSocket ss = new ServerSocket();
        ss.bind(null);
        QuorumServer leaderQS = new QuorumServer(1,
                (InetSocketAddress) ss.getLocalSocketAddress());
        follower.setLeaderQuorumServer(leaderQS);
        final Follower followerForThread = follower;
        
        followerThread = new Thread() {
            public void run() {
                try {
                    followerForThread.followLeader();
                } catch (InterruptedException e) {
                    LOG.info("Follower thread interrupted", e);
                } catch (Exception e) {
                    LOG.warn("Unexpected exception in follower thread", e);
                }
            }
        };
        followerThread.start();
        Socket leaderSocket = ss.accept();
        
        InputArchive ia = BinaryInputArchive.getArchive(leaderSocket
                .getInputStream());
        OutputArchive oa = BinaryOutputArchive.getArchive(leaderSocket
                .getOutputStream());

        conversation.converseWithFollower(ia, oa, follower);
    } finally {
        if (follower != null) {
            follower.shutdown();
        }
        if (followerThread != null) {
            followerThread.interrupt();
            followerThread.join();
        }
        if (peer != null) {
            peer.shutdown();
        }
        recursiveDelete(tmpDir);
    }
}
 
開發者ID:l294265421,項目名稱:ZooKeeper,代碼行數:54,代碼來源:Zab1_0Test.java

示例14: ServerWorker

import java.net.ServerSocket; //導入方法依賴的package包/類
/**
 * Opens {@link ServerWorker#serverSocket}.
 * 
 * @throws IOException
 */
public ServerWorker() throws IOException {
	serverSocket = new ServerSocket();
	serverSocket.bind (new InetSocketAddress (0));
    //serverSocket.configureBlocking(true);
}
 
開發者ID:kefik,項目名稱:Pogamut3,代碼行數:11,代碼來源:NetworkLogManager.java

示例15: start

import java.net.ServerSocket; //導入方法依賴的package包/類
/**
 * Starts the server
 * <p/>
 * Throws an IOException if the socket is already in use
 */
public void start() throws IOException {
    Log.i("NanoHTTPD", "server start");
    myServerSocket = new ServerSocket();
    myServerSocket.bind((hostname != null) ? new InetSocketAddress(
            hostname, myPort) : new InetSocketAddress(myPort));

    myThread = new Thread(new Runnable() {
        @Override
        public void run() {
            do {
                try {
                    final Socket finalAccept = myServerSocket.accept();
                    Log.i("NanoHTTPD",
                            "accept request from "
                                    + finalAccept.getInetAddress());
                    InputStream inputStream = finalAccept.getInputStream();
                    OutputStream outputStream = finalAccept
                            .getOutputStream();
                    TempFileManager tempFileManager = tempFileManagerFactory
                            .create();
                    final HTTPSession session = new HTTPSession(
                            tempFileManager, inputStream, outputStream);
                    asyncRunner.exec(new Runnable() {
                        @Override
                        public void run() {
                            session.run();
                            if (finalAccept != null) {
                                try {
                                    finalAccept.close();
                                } catch (IOException ignored) {
                                }
                            }
                        }
                    });
                } catch (IOException e) {
                }
            } while (!myServerSocket.isClosed());
        }
    });
    myThread.setDaemon(true);
    myThread.setName("NanoHttpd Main Listener");
    myThread.start();
}
 
開發者ID:ynztlxdeai,項目名稱:TextReader,代碼行數:49,代碼來源:NanoHTTPD.java


注:本文中的java.net.ServerSocket.bind方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。