- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
这是 this question 的延续因为它回答了我的原始问题,但没有解决错误。
问题:
我的 Intent :
问题:
现在发生了什么:
附加信息: - 连接后,我可以在“发送”框中输入,提交(更新 outMessage 值),然后断开连接。重新连接后,它将读取值并再次执行序列,直到卡在同一行上。
自引用问题以来的变化:- 使 outMessage 和 connectionStatus 都“不稳定”- 在必要的地方添加了行尾定界符。
代码:
public void run() {
while (connectionStatus != TCP_SOCKET_STATUS_CONNECTED) {
try {
Thread.sleep(500);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
while (connectionStatus == TCP_SOCKET_STATUS_CONNECTED) {
try {
if (outMessage != null){
OutStream.writeBytes(outMessage + "\n");
OutStream.flush();
sendMessageToAllUI(0, MAINACTIVITY_SET_TEXT_STATE, "appendText" , "OUT TO SERVER: " + outMessage);
outMessage = "x";
}
Thread.sleep(100);
// if (InStream.readLine().length() > 0) {
String modifiedSentence = InStream.readLine();
sendMessageToAllUI(0, MAINACTIVITY_SET_TEXT_STATE, "appendText" , "IN FROM SERVER: " + modifiedSentence);
// }
Thread.sleep(1000);
} catch (IOException e) {
connectionLost();
break;
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
制作套接字的线程:
public void run() {
setName("AttemptConnectionThread");
connectionStatus = TCP_SOCKET_STATUS_CONNECTING;
try {
SocketAddress sockaddr = new InetSocketAddress(serverIP, port);
tempSocketClient = new Socket(); // Create an unbound socket
// This method will block no more than timeoutMs. If the timeout occurs, SocketTimeoutException is thrown.
tempSocketClient.connect(sockaddr, timeoutMs);
OutStream = new DataOutputStream(tempSocketClient.getOutputStream());
InStream = new BufferedReader(new InputStreamReader(tempSocketClient.getInputStream()));
socketClient = tempSocketClient;
socketClient.setTcpNoDelay(true);
connected();
} catch (UnknownHostException e) {
connectionFailed();
} catch (SocketTimeoutException e) {
connectionFailed();
} catch (IOException e) {
// Close the socket
try {
tempSocketClient.close();
} catch (IOException e2) {
}
connectionFailed();
return;
}
}
服务器:
public static void main(String[] args) throws IOException {
String clientSentence;
String capitalizedSentence;
try {
ServerSocket welcomeSocket = new ServerSocket(8888);
SERVERIP = getLocalIpAddress();
System.out.println("Connected and waiting for client input!\n Listening on IP: " + SERVERIP +"\n\n");
Socket connectionSocket = welcomeSocket.accept();
BufferedReader inFromClient = new BufferedReader(new InputStreamReader(connectionSocket.getInputStream()));
DataOutputStream outToClient = new DataOutputStream(connectionSocket.getOutputStream());
while(true)
{
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
clientSentence = inFromClient.readLine();
System.out.println("clientSentance == " + clientSentence);
String ip = connectionSocket.getInetAddress().toString().substring(1);
if(clientSentence != null)
{
System.out.println("In from client ("+ip+")("+ System.currentTimeMillis() +"): "+clientSentence);
capitalizedSentence = clientSentence.toUpperCase() + '\n';
outToClient.writeBytes(capitalizedSentence + '\n');
System.out.println("Out to client ("+ip+"): "+capitalizedSentence);
}
}
} catch (IOException e) {
//if server is already running, it will not open new port but instead re-print the open ports information
SERVERIP = getLocalIpAddress();
System.out.println("Connected and waiting for client input!\n");
System.out.println("Listening on IP: " + SERVERIP +"\n\n");
}
}
提前致谢!
编辑:
最佳答案
您的服务器经过专门设计,可以从客户端接收一行并返回一行。看代码:
while (true) {
Socket connectionSocket = welcomeSocket.accept();
BufferedReader inFromClient = new BufferedReader(
new InputStreamReader(connectionSocket.getInputStream()));
DataOutputStream outToClient = new DataOutputStream(
connectionSocket.getOutputStream());
clientSentence = inFromClient.readLine();
String ip = connectionSocket.getInetAddress().toString()
.substring(1);
System.out.println("In from client (" + ip + "): "
+ clientSentence);
if (clientSentence != null) {
capitalizedSentence = clientSentence.toUpperCase() + '\n';
System.out.println("Out to client (" + ip + "): "
+ capitalizedSentence);
outToClient.writeBytes(capitalizedSentence + "\n");
}
请注意,在循环内它接受一个新连接,准确读取一行,然后准确写入一行。它不会关闭连接。它并没有理智地结束谈话。它只是停止读取。
与此服务器一起工作的客户端必须连接、发送一行、读回一行,然后客户端必须关闭连接。你的客户不会那样做。为什么?因为你不知道那是你必须要做的。为什么?因为您没有设计……没有计划。
这就是您的具体问题。但是,请让我敦促您向后退一步巨大并彻底改变您的方法。在您编写一行代码之前,请在字节级别实际设计和指定一个协议(protocol)。协议(protocol)应该说明发送什么数据、消息如何定界、谁在何时发送、谁关闭连接等等。
否则,无法调试您的代码。查看上面的服务器代码,是否正确?好吧,谁知道呢。因为不清楚它应该做什么。当您编写客户端时,您假设服务器以一种方式运行。这个假设有效吗?服务器坏了吗?谁知道呢,因为没有关于服务器应该做什么的规范。
关于卡在 inStream.readline() 上的 Android TCP 应用程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11873366/
下面是我的代码 ifstream& operator>>(ifstream &input,Line3D &line3d) { int x1,y1,z1,x2,y2,z2; x1=0; y1=0; z1
我对setText(TextView)有问题。 view = EgridView.getChildAt( iterator ); parameter = (TextView) vie
如何在 IntStream 或 list 流中添加增量值? List testInstances = IntStream.range(0, rankedItem.size())
我正在尝试在 Modelica 中构建一个非常简单的分布式热流体体积模型,并且正在努力使用流运算符正确实现它。本卷使用 DryAirNasa 作为介质,我希望它没有海量存储、没有压降、也没有能量存储(
所以我试图从 YouTube API 运行示例代码.我正在尝试运行 Search sample code for Java .但是,在第 70 行和第 71 行,它说 InputStream in =
我一直在努力使用 Netty 将字节流传输到 ClamAV 服务的配置。我正在 Apache Camel 路线上运行。 使用 Netty,我无法拦截“超出 INSTREAM 大小限制”消息。 INST
这是 this question 的延续因为它回答了我的原始问题,但没有解决错误。 问题: 如何修复卡在这一行的代码 inStream.readline() 我的 Intent : 这是一个循环检查是
我正在努力在 Ruby 中实现 clamd 守护进程的 INSTREAM 命令。这是clamd的文档 @file = File.open("input.txt") socket = TCPSocket
我正在尝试从实时提要的片段中获取字幕。我正在运行命令ffmpeg -i seg-1077853030-v1-a1.ts 输出 `输入#0,mpegts,来自'seg-109853030-v1-a1.t
当 TrueView InStreams ad 时触发哪些事件开始和结束? YouTube iFrame API reference没有给出任何提示。 我需要知道真正的视频何时开始。 由于这些广告是“
我正在使用 Apache HttpClient 获取一个页面,我想将服务器回复的 http 正文存储到一个字符串中,这样我就可以操作这个字符串并将它打印到控制台。 不幸的是,当运行这个方法时,我收到了
我是一名优秀的程序员,十分优秀!