Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 63275
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 10, 20262026-05-10T18:36:26+00:00 2026-05-10T18:36:26+00:00

I have an method which save files to the internet, it works but just

  • 0

I have an method which save files to the internet, it works but just slow. Then I’d like to make the user interface more smooth, so I create an NSThread to handle the slow task.

I am seeing a list of errors like:

_NSAutoreleaseNoPool(): Object 0x18a140 of class NSCFString autoreleased with no pool in place - just leaking 

Without NSThread, I call the method like:

[self save:self.savedImg]; 

And I used the following to use NSThread to call the method:

NSThread* thread1 = [[NSThread alloc] initWithTarget:self                                         selector:@selector(save:)                                               object:self.savedImg]; [thread1 start]; 

Thanks.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. 2026-05-10T18:36:26+00:00Added an answer on May 10, 2026 at 6:36 pm

    Well first of all, you are both creating a new thread for your saving code and then using NSUrlConnection asynchronously. NSUrlConnection in its own implementation would also spin-off another thread and call you back on your newly created thread, which mostly is not something you are trying to do. I assume you are just trying to make sure that your UI does not block while you are saving…

    NSUrlConnection also has synchronous version which will block on your thread and it would be better to use that if you want to launch your own thread for doing things. The signature is

    + sendSynchronousRequest:returningResponse:error: 

    Then when you get the response back, you can call back into your UI thread. Something like below should work:

    - (void) beginSaving {    // This is your UI thread. Call this API from your UI.    // Below spins of another thread for the selector 'save'    [NSThread detachNewThreadSelector:@selector(save:) toTarget:self withObject:nil];      }  - (void) save {    NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];       // ... calculate your post request...    // Initialize your NSUrlResponse and NSError     NSUrlConnection *conn = [NSUrlConnection sendSyncronousRequest:postRequest:&response error:&error];    // Above statement blocks until you get the response, but you are in another thread so you     // are not blocking UI.        // I am assuming you have a delegate with selector saveCommitted to be called back on the    // UI thread.    if ( [delegate_ respondsToSelector:@selector(saveCommitted)] ) {     // Make sure you are calling back your UI on the UI thread as below:     [delegate_ performSelectorOnMainThread:@selector(saveCommitted) withObject:nil waitUntilDone:NO];    }     [pool release]; } 
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have a method which never returns a null object. I want to make
I have a method to save an image, which is meant to deal gracefully
I have a method which takes params object[] such as: void Foo(params object[] items)
I have a method which should be executed in an exclusive fashion. Basically, it's
I have a method which is given the parameter bool sortAscending. Now I want
I have a method which should be delayed from running for a specified amount
I have a method which constructs an object, calls an Execute method, and frees
I have a method which takes String argument. In some cases I want to
My problem is the following. I have a method which simply takes an XML
I have a C# method which accepts a Predicate<Foo> and returns a list of

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.