Hi Nethra,

> On Feb 7, 2017, at 11:44 PM, Nethra Ravindran via swift-corelibs-dev 
> <swift-corelibs-dev@swift.org> wrote:
> 
> 
> 
> 
> Hi everyone,
> 
> I am working on https://bugs.swift.org/browse/SR-3536 
> <https://bugs.swift.org/browse/SR-3536>
> There is a memory leak when searching for the substring of a string using 
> regular expression.
> 
> 
> import Foundation
> 
> let myString = "Foo"
> for _ in 1...10000 {
>   let _ = myString.range(of: "bar", options: .regularExpression)
> }
> 
> 
> From the above test case i could see that over a period of time, around 60 Mb 
> of memory was leaked. 
> 
> I see in String.range we eventually call NSString._createRegexForPattern. 
> Here we maintain a mapping between NSString and NSRegularExpression object in 
> NSCache<NSString, NSRegularExpression>. All the entries in the cache are 
> maintained in a dictionary ( _entries ) which takes the UnsafeRawPointer as 
> the key, which seems to be the address of the NSString Object and 
> NSCachedEntry as value.
> 
> Though the pattern is of type String, it is stored in the NSCache as 
> NSString. And since we are storing the NSCachedEntry objects in a dictionary 
> indexed by the address (UnsafeRawPointer) of the NSString object, there is a 
> new cache entry created for each iteration ( in the test case ) though the 
> pattern string remains the same.
> 
> Can someone guide me about how to go about resolving this issue.
> 
> 

Looks like you’ve done most of the analysis, so you’re already pretty much 
there. =)

Is there some other way we could be caching the results here?

- Tony
> Thank you.
> 
> - Nethra Ravindran
> 
> 
> _______________________________________________
> swift-corelibs-dev mailing list
> swift-corelibs-dev@swift.org
> https://lists.swift.org/mailman/listinfo/swift-corelibs-dev

_______________________________________________
swift-corelibs-dev mailing list
swift-corelibs-dev@swift.org
https://lists.swift.org/mailman/listinfo/swift-corelibs-dev

Reply via email to