xcode から iPad で実行すると動作するアプリがありますが、AdHoc 配布用に準備すると正しく機能しません。
私のスレッドは次のとおりです。
[NSThread detachNewThreadSelector:@selector(wifiBackground) toTarget:self withObject:nil];
wifiBackground は次のとおりです。
-(void)wifiBackground
{
[self setupSocket];
[NSThread sleepForTimeInterval:1.0f];
while (YES) {
[NSThread sleepForTimeInterval:3.0f];
if (mNetAlive == [NSNumber numberWithInt:TCP_PORT_OK]) //is connected (can send messages through internet)
{
//setup for sending tcp msg, grab network info
NSString *mWifiname = [self fetchSSIDInfo];
NSLog(@"mWifiname %@", mWifiname);
[self writeToCSV:autoErrLogg :[[NSString alloc] initWithFormat:@"mWifiname %@,,,,",mWifiname] :YES :YES];
//send messages if new or changed
if ((wifi_name == nil || wifi_name == (id)[NSNull null] || ([wifi_name length] == 0)) ) { //is null
NSLog(@"is null");
[self sendMsgType:WIFI_UDP_CX msgArg1:WIFI_CX_NEW msgArg2:[NSNumber numberWithInt:0] wifiName:mWifiname buffer:nil];
} else if ([wifi_name containsString:mWifiname]) {
[self sendMsgType:WIFI_UDP_CX msgArg1:WIFI_CX_CHANGE msgArg2:[NSNumber numberWithInt:0] wifiName:mWifiname buffer:nil];
}
wifi_name = mWifiname;
mTcpState = [NSNumber numberWithInt:TCP_PORT_OPEN];
retrycount = 0;
[NSThread sleepForTimeInterval:1.0f];
while (mTcpState == [NSNumber numberWithInt:TCP_PORT_OPEN] && ([mWifiname containsString:mCurrentSSID])) {
[self setupSocket];
[NSThread sleepForTimeInterval:2.0f];
mTcpAlive = [NSNumber numberWithInt:TCP_PORT_OK];
mWifiAlert = [NSNumber numberWithInt:0];
[self writeToCSV:autoErrLogg :[[NSString alloc] initWithFormat:@"connected %d,mwifiName %@,current ssid %@,,",[asyncSocket isConnected],mWifiname,mCurrentSSID] :YES :YES];
while ([asyncSocket isConnected] && ([mWifiname containsString:mCurrentSSID])) {
if (reading == NO) {
NSMutableArray *mytx = tx;
[self send:mytx];
}
//recieve info
reading = YES;
[self startRead];
while (reading == YES) {} //wait
}
retrycount++;
if (retrycount >= 3) {
NSLog(@"in retry");
[self writeToCSV:autoErrLogg :[[NSString alloc] initWithFormat:@"in retry,,,,"] :YES :YES];
if (([mWifiAlert intValue] == 0) && ![mWifiname containsString:mCurrentSSID]) { mWifiAlert = [NSNumber numberWithInt:1]; }
[asyncSocket disconnect];
[NSThread sleepForTimeInterval:1.5f];
//obviously not connected to internet so shut down
mTcpAlive = [NSNumber numberWithInt:TCP_PORT_OFF];
[self sendMsgType:WIFI_UDP_CX msgArg1:WIFI_CX_RX_ERROR msgArg2:[NSNumber numberWithInt:0] wifiName:mWifiname buffer:nil];
break; //breaks out of while
}
}
if (!([mWifiname containsString:mCurrentSSID])) {
NSLog(@"not correct wifi");
[self writeToCSV:autoErrLogg :[[NSString alloc] initWithFormat:@"not correct wifi,,,,"] :YES :YES];
if ([mWifiAlert intValue] == 0) {
mWifiAlert = [NSNumber numberWithInt:1];
}
[NSThread sleepForTimeInterval:5.0f];
}
} else {
noWifiOn++;
NSLog(@"in else mNetAlive");
[self writeToCSV:autoErrLogg :[[NSString alloc] initWithFormat:@"in else mNetAlive,,,,"] :YES :YES];
if (noWifiOn >= 5) {
if ([mWifiAlert intValue] == 0) {
mWifiAlert = [NSNumber numberWithInt:2];
}
NSLog(@"alert view");
noWifiOn = 0;
[NSThread sleepForTimeInterval:5.0f];
}
mTcpAlive = [NSNumber numberWithInt:TCP_PORT_FAIL];
}
[NSThread sleepForTimeInterval:2.0f];
}
}
socketDidRead:
- (void)socket:(GCDAsyncSocket *)sock didReadData:(NSData *)data withTag:(long)tags
{
reading = YES;
const unsigned char *dataBytes = [data bytes];
NSUInteger dataLength = [data length];
if (buf_ptr == 0) {
TCP_size = [self strintvalue:[NSString stringWithFormat:@"%02x%02x",dataBytes[2],dataBytes[1]]];
}
buf_ptr = buf_ptr + (int)dataLength;
//NSLog(@"buf ptr = %i",buf_ptr);
if ((buf_ptr < TCP_size) && (TCP_size <=12000)) {
[ds appendData:data];
[self startRead];
} else if (buf_ptr == TCP_size){
[ds appendData:data]; //append the final bit for this package
//NSLog(@"ds = %@",ds);
[self writeToCSV:autoErrLogg :[[NSString alloc] initWithFormat:@"socketDidRead,,,,"] :YES :YES];
NSLog(@"tcp size = buf_ptr");
[self writeToCSV:autoErrLogg :[[NSString alloc] initWithFormat:@"tcp size = buf_ptr,,,,"] :YES :YES];
const unsigned char *allDataBytes = [ds bytes];
[self processRead:allDataBytes];
reading = NO;
mTcpAlive = [NSNumber numberWithInt:TCP_PORT_OK];
retrycount = 0;
buf_ptr = 0;
[ds setLength:0];
} else {
[self sendMsgType:WIFI_UDP_CX msgArg1:WIFI_CX_RX_ERROR msgArg2:0 wifiName:wifi_name buffer:nil];
buf_ptr = 0;
[ds setLength:0];
}
}
本質的に: wifiBackground は、インターネットに接続されているかどうかを確認し、ソケットを接続し、ネットワークにパケットを送信し (5 秒のタイムアウト)、読み取りが完了するまで待機し (5 秒のタイムアウト)、送信されたパケットが更新されることを繰り返します。 . ネットワークが閉じている場合は、接続を再試行する必要があります。
AdHocとして実行すると、すぐに接続できない場合はループしますが、processReadに行かずに読み取りが完了すると(スレッド全体が)停止します。例えば)
socketDidDisconnect
socketDidDisconnect
socketDidRead
tcp size = but_ptr
socketDidDisconnect (error = null)
processRead が呼び出されないのはなぜですか? これは xcode から機能しますが、現在機能しない理由がわかりません。
私が試してみました:
dispatch_async(dispatch_get_main_queue(), ^{
[self processRead:allDataBytes];
});
しかし、上記と同じことが起こります。
performSelectorOnMainThread を試すつもりでしたが、processRead が使用const unsigned char
しているため、正しいオブジェクトではないというエラーが表示されます。