- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在设置一个 TCP 多通信,并希望从每个服务器获取所有响应的消息。实际方法是什么?
我尝试发送 ip 数组 4 项。在日志猫上显示“添加新项目”4 次,但在“onPostExecute”显示“完成::”有时 4 次或 3 次,与“添加新项目”的次数不匹配。
MultiReadingWiFiModule.class
public class MultiReadingWiFiModule extends AsyncTask<String, Integer, List<AirItem>>{
private List<AirItem> items;
private String[] ipList;
private OnReadingResult result;
private static final int CONNECT_TIMEOUT = 1000;
private static final int RESPONSE_TIMEOUT = 1000;
private static final int DATA_SIZE = 7;
private static final String TAG = "Reading";
public MultiReadingWiFiModule(String[]ipList){
this.ipList = ipList;
}
public void startReading(){
this.executeOnExecutor(AsyncTask.SERIAL_EXECUTOR);
}
public void setOnReadingResult(OnReadingResult result){
this.result = result;
}
@Override
protected void onPreExecute() {
super.onPreExecute();
Log.w(TAG, "Start reading IP list :: "+ Arrays.toString(ipList));
items = new ArrayList<>(); //Initial air items
}
@Override
protected List<AirItem> doInBackground(String... strings) {
// Start Threads which read WiFi module from ip list
Thread[] scanThreads = new Thread[ipList.length];
for (int i=0; i<scanThreads.length; i++){
scanThreads[i] = startIPScanThread(ipList[i]);
}
// Wait for threads to finish
Log.w(TAG, "Waiting for Threads...");
int count = 0;
for (Thread t : scanThreads){
try {
if (t != null){
t.join();
}
}catch (InterruptedException e){
e.printStackTrace();
}
count++; //Count ip test finish
publishProgress(count*100/ipList.length); //Update progress
}
// Short pause seems to be necessary for ARP cache to update
// More: https://en.wikipedia.org/wiki/ARP_cache
Log.w(TAG, "Threads finished. "+count);
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
return items;
}
@Override
protected void onPostExecute(List<AirItem> items) {
super.onPostExecute(items);
for (AirItem i : items){
Log.w(TAG, "Finish :: "+i.getIp());
}
if (result!=null){
result.onFinish(items);
}
}
private Thread startIPScanThread(final String host){
final Thread t = new Thread(new Runnable() {
@Override
public void run() {
//Declare result object
Log.w(TAG, "Try connect "+host);
try {
Socket socket = new Socket();
socket.connect(new InetSocketAddress(host, Constant.PORT), CONNECT_TIMEOUT);
// Create PrintWriter object for sending messages to server.
PrintWriter outWrite = new PrintWriter(new BufferedWriter(
new OutputStreamWriter(socket.getOutputStream())), true);
//Send message
outWrite.print(Constant.SCAN_INFO+","); //Request status
outWrite.flush();
Log.w(TAG, "Send request success!");
//Create object for receiving message response from server.
InputStreamReader inputStream = new InputStreamReader(socket.getInputStream());
//Read response message
StringBuilder s = new StringBuilder("");
int i=0; String[]buffer = new String[Constant.BUFF_MAX];
long start = System.currentTimeMillis(); boolean timeout = false;
while (!timeout){
timeout = !((System.currentTimeMillis() - start)<RESPONSE_TIMEOUT);
//Convert int to char
char data = (char)inputStream.read();
//Check syntax ',' mean ending each word. So Server must send Ex: Hello,You
if (data==','){
buffer[i] = s.toString(); ///Add message to String array
s = new StringBuilder(""); ///Clear string
i++;
}else {
s.append(data); //Create word string
}
//Check InputSteam read finish
if (!inputStream.ready()) {
buffer = i > 0 ? Arrays.copyOf(buffer, i) : new String[]{s.toString()}; //Re-size buffer
Log.w(TAG, "Server response :: " + Arrays.toString(buffer));
if (buffer.length >= DATA_SIZE) {
Log.w(TAG, "Add new item");
//Show only read success
items.add(new AirItem(host, buffer[0], buffer[1], buffer[2], buffer[4], buffer[5], buffer[6], buffer[9]));
}
break; //Out of loop
}
}
socket.close(); //Disconnect server
} catch (IOException e) {
e.printStackTrace();
}
}
});
t.start();
return t;
}
interface OnReadingResult{
void onFinish(List<AirItem> itemsSuccess);
}
}
登录猫
12-25 18:49:21.619 18842-18842/com.apyeng.tasakicentral W/Reading: Start
reading IP list :: [192.168.1.204, 192.168.1.202, 192.168.1.205, 192.168.1.203]
12-25 18:49:21.630 18842-21156/com.apyeng.tasakicentral W/Reading: Waiting for Threads...
12-25 18:49:21.957 18842-21159/com.apyeng.tasakicentral W/Reading: Add new item :: 192.168.1.205
12-25 18:49:21.959 18842-21157/com.apyeng.tasakicentral W/Reading: Add new item :: 192.168.1.204
12-25 18:49:21.960 18842-21158/com.apyeng.tasakicentral W/Reading: Add new item :: 192.168.1.202
12-25 18:49:21.962 18842-21160/com.apyeng.tasakicentral W/Reading: Add new item :: 192.168.1.203
12-25 18:49:21.963 18842-21156/com.apyeng.tasakicentral W/Reading: Threads finished. 4
12-25 18:49:22.966 18842-18842/com.apyeng.tasakicentral W/Reading:
Finish :: 192.168.1.205
Finish :: 192.168.1.204
Finish :: 192.168.1.202
Finish :: 192.168.1.203
12-25 18:49:31.278 18842-18842/com.apyeng.tasakicentral W/Reading: Start reading IP list :: [192.168.1.203, 192.168.1.205, 192.168.1.202, 192.168.1.204]
12-25 18:49:31.291 18842-21448/com.apyeng.tasakicentral W/Reading: Waiting for Threads...
12-25 18:49:31.598 18842-21449/com.apyeng.tasakicentral W/Reading: Add new item :: 192.168.1.203
12-25 18:49:31.598 18842-21452/com.apyeng.tasakicentral W/Reading: Add new item :: 192.168.1.204
12-25 18:49:31.600 18842-21450/com.apyeng.tasakicentral W/Reading: Add new item :: 192.168.1.205
12-25 18:49:31.606 18842-21451/com.apyeng.tasakicentral W/Reading: Add new item :: 192.168.1.202
12-25 18:49:31.607 18842-21448/com.apyeng.tasakicentral W/Reading: Threads finished. 4
12-25 18:49:32.609 18842-18842/com.apyeng.tasakicentral W/Reading: Finish :: 192.168.1.203
Finish :: 192.168.1.205
Finish :: 192.168.1.202
最佳答案
完成此任务的一种方法是将 ArrayList 替换为向量作为线程安全的向量。
试试下面的代码,我创建了一个同步函数来将项目添加到列表中(如果不使用向量,这是另一种选择)
public class MultiReadingWiFiModule extends AsyncTask<String, Integer, List<AirItem>>{
private List<AirItem> items;
private String[] ipList;
private OnReadingResult result;
private static final int CONNECT_TIMEOUT = 1000;
private static final int RESPONSE_TIMEOUT = 1000;
private static final int DATA_SIZE = 7;
private static final String TAG = "Reading";
public MultiReadingWiFiModule(String[]ipList){
this.ipList = ipList;
}
public void startReading(){
this.executeOnExecutor(AsyncTask.SERIAL_EXECUTOR);
}
public void setOnReadingResult(OnReadingResult result){
this.result = result;
}
@Override
protected void onPreExecute() {
super.onPreExecute();
Log.w(TAG, "Start reading IP list :: "+
Arrays.toString(ipList));
items = new ArrayList<>(); //Initial air items
}
@Override
protected List<AirItem> doInBackground(String... strings) {
// Start Threads which read WiFi module from ip list
Thread[] scanThreads = new Thread[ipList.length];
for (int i=0; i<scanThreads.length; i++){
scanThreads[i] = startIPScanThread(ipList[i]);
}
// Wait for threads to finish
Log.w(TAG, "Waiting for Threads...");
int count = 0;
for (Thread t : scanThreads){
try {
if (t != null){
t.join();
}
}catch (InterruptedException e){
e.printStackTrace();
}
count++; //Count ip test finish
publishProgress(count*100/ipList.length); //Update progress
}
// Short pause seems to be necessary for ARP cache to update
// More: https://en.wikipedia.org/wiki/ARP_cache
Log.w(TAG, "Threads finished. "+count);
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
return items;
}
@Override
protected void onPostExecute(List<AirItem> items) {
super.onPostExecute(items);
for (AirItem i : items){
Log.w(TAG, "Finish :: "+i.getIp());
}
if (result!=null){
result.onFinish(items);
}
}
private Thread startIPScanThread(final String host){
final Thread t = new Thread(new Runnable() {
@Override
public void run() {
//Declare result object
Log.w(TAG, "Try connect "+host);
try {
Socket socket = new Socket();
socket.connect(new InetSocketAddress(host, Constant.PORT), CONNECT_TIMEOUT);
// Create PrintWriter object for sending messages to server.
PrintWriter outWrite = new PrintWriter(new BufferedWriter(
new OutputStreamWriter(socket.getOutputStream())), true);
//Send message
outWrite.print(Constant.SCAN_INFO+","); //Request status
outWrite.flush();
Log.w(TAG, "Send request success!");
//Create object for receiving message response from server.
InputStreamReader inputStream = new InputStreamReader(socket.getInputStream());
//Read response message
StringBuilder s = new StringBuilder("");
int i=0; String[]buffer = new String[Constant.BUFF_MAX];
long start = System.currentTimeMillis(); boolean timeout = false;
while (!timeout){
timeout = !((System.currentTimeMillis() - start)<RESPONSE_TIMEOUT);
//Convert int to char
char data = (char)inputStream.read();
//Check syntax ',' mean ending each word. So Server must send Ex: Hello,You
if (data==','){
buffer[i] = s.toString(); ///Add message to String array
s = new StringBuilder(""); ///Clear string
i++;
}else {
s.append(data); //Create word string
}
//Check InputSteam read finish
if (!inputStream.ready()) {
buffer = i > 0 ? Arrays.copyOf(buffer, i) : new String[]{s.toString()}; //Re-size buffer
Log.w(TAG, "Server response :: " + Arrays.toString(buffer));
if (buffer.length >= DATA_SIZE) {
Log.w(TAG, "Add new item");
//Show only read success
AirItemAdd(host, buffer[0], buffer[1], buffer[2], buffer[4], buffer[5], buffer[6], buffer[9]));
}
break; //Out of loop
}
}
socket.close(); //Disconnect server
} catch (IOException e) {
e.printStackTrace();
}
}
});
t.start();
return t;
}
interface OnReadingResult{
void onFinish(List<AirItem> itemsSuccess);
}
public synchronized void AirItemAdd(String... buffer){
items.add(new AirItem(buffer[0], buffer[1], buffer[2], buffer[4], buffer[5], buffer[6], buffer[9],buffer[10] ));
}
}
关于android - 如何从android中的ansys任务 "doInBackground"获取列表数组?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53922197/
我最近在/ drawable中添加了一些.gifs,以便可以将它们与按钮一起使用。这个工作正常(没有错误)。现在,当我重建/运行我的应用程序时,出现以下错误: Error: Gradle: Execu
Android 中有返回内部存储数据路径的方法吗? 我有 2 部 Android 智能手机(Samsung s2 和 s7 edge),我在其中安装了一个应用程序。我想使用位于这条路径中的 sqlit
这个问题在这里已经有了答案: What's the difference between "?android:" and "@android:" in an android layout xml f
我只想知道 android 开发手机、android 普通手机和 android root 手机之间的实际区别。 我们不能从实体店或除 android marketplace 以外的其他地方购买开发手
自Gradle更新以来,我正在努力使这个项目达到标准。这是一个团队项目,它使用的是android-apt插件。我已经进行了必要的语法更改(编译->实现和apt->注释处理器),但是编译器仍在告诉我存在
我是android和kotlin的新手,所以请原谅要解决的一个非常简单的问题! 我已经使用导航体系结构组件创建了一个基本应用程序,使用了底部的导航栏和三个导航选项。每个导航选项都指向一个专用片段,该片
我目前正在使用 Facebook official SDK for Android . 我现在正在使用高级示例应用程序,但我不知道如何让它获取应用程序墙/流/状态而不是登录的用户。 这可能吗?在那种情
我在下载文件时遇到问题, 我可以在模拟器中下载文件,但无法在手机上使用。我已经定义了上网和写入 SD 卡的权限。 我在服务器上有一个 doc 文件,如果用户单击下载。它下载文件。这在模拟器中工作正常但
这个问题在这里已经有了答案: What is the difference between gravity and layout_gravity in Android? (22 个答案) 关闭 9
任何人都可以告诉我什么是 android 缓存和应用程序缓存,因为当我们谈论缓存清理应用程序时,它的作用是,缓存清理概念是清理应用程序缓存还是像内存管理一样主存储、RAM、缓存是不同的并且据我所知,缓
假设应用程序 Foo 和 Eggs 在同一台 Android 设备上。任一应用程序都可以获取设备上所有应用程序的列表。一个应用程序是否有可能知道另一个应用程序是否已经运行以及运行了多长时间? 最佳答案
我有点困惑,我只看到了从 android 到 pc 或者从 android 到 pc 的例子。我需要制作一个从两部手机 (android) 连接的 android 应用程序进行视频聊天。我在想,我知道
用于使用 Android 以编程方式锁定屏幕。我从 Stackoverflow 之前关于此的问题中得到了一些好主意,并且我做得很好,但是当我运行该代码时,没有异常和错误。而且,屏幕没有锁定。请在这段代
文档说: android:layout_alignParentStart If true, makes the start edge of this view match the start edge
我不知道这两个属性和高度之间的区别。 以一个TextView为例,如果我将它的layout_width设置为wrap_content,并将它的width设置为50 dip,会发生什么情况? 最佳答案
这两个属性有什么关系?如果我有 android:noHistory="true",那么有 android:finishOnTaskLaunch="true" 有什么意义吗? 最佳答案 假设您的应用中有
我是新手,正在尝试理解以下 XML 代码: 查看 developer.android.com 上的文档,它说“starStyle”是 R.attr 中的常量, public static final
在下面的代码中,为什么当我设置时单选按钮的外观会发生变化 android:layout_width="fill_parent" 和 android:width="fill_parent" 我说的是
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 9
假设我有一个函数 fun myFunction(name:String, email:String){},当我调用这个函数时 myFunction('Ali', 'ali@test.com ') 如何
我是一名优秀的程序员,十分优秀!