Advertise Mobile SDKs Books Events Forum News Social Networking Support Us
Follow @iphonedevsdk on Twitter

Interface 2, Advanced iOS
Mockup & Code Gen
($9.99)

Make your own iPhone apps
and run them live!
(free)

Pic Frame Dynamo: Photo Editing
($0.99)

Abiliator
($1.99)

Want your application or service advertised on iPhone Dev SDK?

Go Back   iPhone Dev SDK Forum > iPhone SDK Development Forums > iPhone SDK Development

Reply
 
LinkBack Thread Tools Display Modes
Old 02-01-2012, 09:17 PM   #1 (permalink)
Registered Member
 
Join Date: Feb 2012
Posts: 3
tnava2 is on a distinguished road
Default Potential leak of an object allocated on line … and stored into 'path' (Memory Leak)

Code:
CGPathRef NewPathWithRoundRect(CGRect rect, CGFloat cornerRadius)
    {

    CGMutablePathRef path = CGPathCreateMutable();
    CGPathMoveToPoint(path, NULL, rect.origin.x,
        rect.origin.y + rect.size.height - cornerRadius);

    CGPathAddArcToPoint(path, NULL,
        rect.origin.x,
        rect.origin.y,
        rect.origin.x + rect.size.width,
        rect.origin.y,
        cornerRadius);

    CGPathAddArcToPoint(path, NULL,
        rect.origin.x + rect.size.width,
        rect.origin.y,
        rect.origin.x + rect.size.width,
        rect.origin.y + rect.size.height,
        cornerRadius);

    CGPathAddArcToPoint(path, NULL,
        rect.origin.x + rect.size.width,
        rect.origin.y + rect.size.height,
        rect.origin.x,
        rect.origin.y + rect.size.height,
        cornerRadius);

    CGPathAddArcToPoint(path, NULL,
        rect.origin.x,
        rect.origin.y + rect.size.height,
        rect.origin.x,
        rect.origin.y,
        cornerRadius);

    CGPathCloseSubpath(path);

    return path; //this seems to be the culprit.. Any answers...
    }

Last edited by tnava2; 02-01-2012 at 09:21 PM. Reason: added code tags
tnava2 is offline   Reply With Quote
Old 02-01-2012, 09:25 PM   #2 (permalink)
Cocoa Junkie
 
Duncan C's Avatar
 
Join Date: Dec 2008
Location: Northern Virginia
Posts: 6,003
Duncan C has a spectacular aura about
Default

Quote:
Originally Posted by tnava2 View Post
<pre>
CGPathRef NewPathWithRoundRect(CGRect rect, CGFloat cornerRadius)
{

CGMutablePathRef path = CGPathCreateMutable();
CGPathMoveToPoint(path, NULL, rect.origin.x,
rect.origin.y + rect.size.height - cornerRadius);

CGPathAddArcToPoint(path, NULL,
rect.origin.x,
rect.origin.y,
rect.origin.x + rect.size.width,
rect.origin.y,
cornerRadius);

CGPathAddArcToPoint(path, NULL,
rect.origin.x + rect.size.width,
rect.origin.y,
rect.origin.x + rect.size.width,
rect.origin.y + rect.size.height,
cornerRadius);

CGPathAddArcToPoint(path, NULL,
rect.origin.x + rect.size.width,
rect.origin.y + rect.size.height,
rect.origin.x,
rect.origin.y + rect.size.height,
cornerRadius);

CGPathAddArcToPoint(path, NULL,
rect.origin.x,
rect.origin.y + rect.size.height,
rect.origin.x,
rect.origin.y,
cornerRadius);

CGPathCloseSubpath(path);

return path; //this seems to be the culprit.. Any answers...
}

</pre>
When I analyze the app I get a Potential leak of an object allocated on line … and stored into 'path'. Does anyone have any ideas?

Your method is returning a retained CGPath object.

Change the method name to createPathWithRoundRect and you will be following Apple's naming convention for methods that return CF objects.

Then in the method that calls this method, make sure you do a CGPathRelease() on the path once you are done with it.

With NSObjects, the LLVM compiler enforces the rule that methods who's names start with “alloc”, “new”, “copy”, or “mutableCopy” should return retained NSObjects, and other methods should return non-owning references.

I don't know if it does the same thing with CF objects or not, but you should follow the naming convention just the same. (and method names should always start with a lower case letter. Only class names should be capitalized.)
__________________
Regards,

Duncan C
WareTo

Check out our apps in the Apple App store


Check out this password generator app that shows various techniques including using a data container singleton object to share data between objects in your project.

See this tutorial on using UIView animations and layer animations:

See this thread on generating random, non-repeating text

Check out a very cool Macintosh Kaleidoscopes app called ScopeWorks that we released to the Mac App store.
Duncan C is offline   Reply With Quote
Old 02-06-2012, 09:40 PM   #3 (permalink)
Registered Member
 
Join Date: Feb 2012
Posts: 3
tnava2 is on a distinguished road
Default

Quote:
Originally Posted by Duncan C View Post
Your method is returning a retained CGPath object.

Change the method name to createPathWithRoundRect and you will be following Apple's naming convention for methods that return CF objects.

Then in the method that calls this method, make sure you do a CGPathRelease() on the path once you are done with it.

With NSObjects, the LLVM compiler enforces the rule that methods who's names start with “alloc”, “new”, “copy”, or “mutableCopy” should return retained NSObjects, and other methods should return non-owning references.

I don't know if it does the same thing with CF objects or not, but you should follow the naming convention just the same. (and method names should always start with a lower case letter. Only class names should be capitalized.)
Perfect! 10/10 It worked flawlessly! Will I have the same issues if I convert to ARC?
tnava2 is offline   Reply With Quote
Reply

Bookmarks

Tags
memory leak, potential leak of object

Thread Tools
Display Modes

Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off
Trackbacks are On
Pingbacks are On
Refbacks are On



» Advertisements
» Online Users: 414
16 members and 398 guests
Atatator, chiataytuday, dre, FrankWeller, imac74, ipodphone, jeroenkeij, kukat, LunarMoon, MAMN84, n00b, PowerGoofy, QuantumDoja, Retouchable, tim0504, VinceYuan
Most users ever online was 1,387, 04-10-2012 at 04:21 AM.
» Stats
Members: 175,675
Threads: 94,124
Posts: 402,909
Top Poster: BrianSlick (7,990)
Welcome to our newest member, Retouchable
Powered by vBadvanced CMPS v3.1.0

All times are GMT -5. The time now is 06:03 AM.
Powered by vBulletin® Version 3.8.0
Copyright ©2000 - 2012, Jelsoft Enterprises Ltd.
Search Engine Friendly URLs by vBSEO 3.3.0