У вас проблема с пулом автоматического выпуска.Во-первых, как сказал Николай, освобождение никогда не происходит, потому что это после возвращения.Я поражен, что вы не видите предупреждений компилятора.Убедитесь, что вы установили -Wall
в «другие флаги предупреждения» и у вас установлена опция сборки «Запустить статический анализатор».
Поскольку вы хотите использовать возвращаемую строку вне функции, пул автоматического выпуска также должен быть вне функции, иначе строка может быть освобождена до того, как ваш журнал попадет в нее.Ваша структура кода должна выглядеть примерно так:
+(void)startthread:(id)param
{
while (true)
{
NSAutoreleasePool* pool = [[NSAutoreleasePool alloc] init];
//NSLog(@"Test threads");
sleep(5);
NSLog(@"%@",[self getDatafromServer]);
[pool drain]; // use instead of release in case you move to GC
}
}
Другая проблема, с которой вы столкнулись, заключается в том, что вы не выполняете никакой проверки ошибок.Как вы можете быть уверены, что:
- запрос к серверу работает?
- ответ от сервера закодирован как UTF-8.
Вам нужно проверить, равен ли returnData ноль после того, как вы его получили, и вам нужно проверить, есть ли ошибка NSE.Поэтому вам нужно что-то вроде этого:
NSError* error = nil;
NSData *returnData = [NSURLConnection sendSynchronousRequest:request returningResponse:nil error:&error];
if (returnData == nil)
{
the error object will be set and contain useful info.
}
Вам также необходимо проверить, имеет ли myString значение nil.Если это так, то это будет потому, что ответ не был закодирован как UTF-8.Для HTTP кодировкой по умолчанию является не UTF-8, а ISO-8859-1.Кроме того, тело ответа может вообще не быть символьными данными.Вам нужно изучить ответ, чтобы узнать, как декодировать данные.Поэтому приведенный выше фрагмент кода должен выглядеть следующим образом:
NSError* error = nil;
NSURLResponse* response = nil;
NSData *returnData = [NSURLConnection sendSynchronousRequest:request returningResponse:&response error:&error];
if (returnData == nil)
{
// the error object will be set and contain useful info.
}
else
{
// You can get the content type and encoding from the response here.
}
Редактировать
Кроме того, ваш код нарушает Правила управления памятью .Вы не получили myRequestString
или returnData
через alloc, copy или new, а также не сохранили их, поэтому вы не должны выпускать их.