gpt4 book ai didi

android - 线程卡在 WifiManager.enableNetwork()

转载 作者:塔克拉玛干 更新时间:2023-11-02 21:40:28 26 4
gpt4 key购买 nike

在调用 WifiManager.enableNetwork() 时,我看到我的调用线程在 native 代码中挂起。到目前为止,我只能在运行 Android 3.2.1 的 Motorola Xoom 平板电脑上重现此挂起。我已经在其他几款手机和平板电脑(都运行 Froyo 或 Gingerbread)上进行了测试,但没有发现问题。 Xoom 是我必须测试的唯一双核设备(我已经在 2 个不同的 Xoom 上重现了这个问题),所以我觉得在与 WifiManager 交互时我遇到了一些非常微妙的 Android 线程要求。我的调用线程挂起的堆栈跟踪是:

    BinderProxy.transact(int, Parcel, Parcel, int) line: not available [native method]
IWifiManager$Stub$Proxy.enableNetwork(int, boolean) line: 513
WifiManager.enableNetwork(int, boolean) line: 587

我的应用程序正在尝试连接到已知的 wifi 接入点,执行一些测试,然后将设备重新连接到其原始接入点(如果之前已连接)。在建立连接之前,我们已经验证了 wifi 已启用,并且我们执行了扫描以验证是否找到了我们的接入点 SSID。这段建立连接的代码在 AsyncTask 中运行,看起来像这样:

... 
private WifiManager mWifiManager;
private List<WifiConfiguration> mConfiguredNets = new ArrayList<WifiConfiguration>();
private Object mConnectMonitor = new Object();
private NetworkInfo.State mNetworkState = State.UNKNOWN;

private final BroadcastReceiver mConnectionStateReceiver = new BroadcastReceiver() {
@Override
public void onReceive(Context inContext, final Intent inIntent) {
final String action = inIntent.getAction();
if (WifiManager.NETWORK_STATE_CHANGED_ACTION.equals(action)) {
NetworkInfo ni =
(NetworkInfo)inIntent.getParcelableExtra(WifiManager.EXTRA_NETWORK_INFO);
State state = ni.getState();
if (state == State.CONNECTED) {
synchronized (mConnectMonitor) {
mNetworkState = state;
mConnectMonitor.notify();
}
}
}
}
};

public void runninInAsyncTask(Context activityContext, int networkID) {

mWifiManager = (WifiManager)activityContext.getSystemService(Context.WIFI_SERVICE);

// Register our broadcast receiver to get network state change events
IntentFilter ifilter = new IntentFilter();
ifilter.addAction(WifiManager.NETWORK_STATE_CHANGED_ACTION);
activityContext.registerReceiver(mConnectionStateReceiver, ifilter);

// Get a list of our currently configured networks so we can re-enable
// them after connecting to the desired network
mConfiguredNets = mWifiManager.getConfiguredNetworks();

// Enable our network and disable all others
mWifiManager.enableNetwork(networkId, true);

// Start the reconnection process to connect to our desired network
synchronized (mConnectMonitor) {
mWifiManager.reconnect();
mConnectMonitor.wait(60000);
if (mNetworkState != State.CONNECTED) {
Log.e(TAG, "Problems connecting to desired network!");
}
else {
Log.e(TAG, "Successfully connected to desired network!");
}
}

// Re-enable all of our previously configured networks
for (WifiConfiguration wifiConfig : mConfiguredNets)
{
if (wifiConfig.status != Status.ENABLED) {
mWifiManager.enableNetwork(wifiConfig.networkId, false);
}
}
}
...

此代码基于Android Gingerbread 开源代码中的Wifi 设置菜单代码。关于调用 WifiManager.enableNetwork() 有什么我遗漏的吗?它是否必须在特定线程上运行?我已尝试确保在 UI 线程上调用 enableNetwork()(通过将逻辑移至广播接收器)。这似乎有点帮助,但我仍然能够重现挂起。也许这是 Honeycomb 特有的东西?现在,这 2 个 Xoom 是我唯一可用于测试的 Honeycomb 设备,因此它们是我仅有的数据点。

G

最佳答案

这确实是 3.* 特有的固件问题(看起来)。

我曾在 Asus Transformer TF101 和 Sony Tablet S(均带有 3.*,那是前一段时间)上看到过这种情况。

从 3.0 开始,有新的连接 WiFi 的 API,不需要批量使用 enableNetwork(以启用除当前网络之外的所有网络)。

关于这些 API 的更多信息,我可以从 4.0 源代码中收集到的信息:

  • 它们被标记为“@hide”
  • 它们被“设置”应用使用
  • 到 4.1 为止,它们仍未记录
  • 它们在 3.* 和 4.* 运行时之间有些变化

我的建议是尝试通过反射使用这些 API。由于它们由“设置”应用程序使用,因此它们可以正常工作。

关于android - 线程卡在 WifiManager.enableNetwork(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7957299/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com