FBMemoryProfiler alternatives and similar libraries
Based on the "Code Quality" category.
Alternatively, view FBMemoryProfiler alternatives based on common mentions on social networks and blogs.
-
OCLint
A static source code analysis tool to improve quality and reduce defects for C, C++ and Objective-C -
IBAnalyzer
DISCONTINUED. Find common xib and storyboard-related problems without running your app or writing unit tests. -
SwiftCop
SwiftCop is a validation library fully written in Swift and inspired by the clarity of Ruby On Rails Active Record validations. -
Warnings-xcconfig
An xcconfig (Xcode configuration) file for easily turning on a boatload of warnings in your project or its targets. -
PSTModernizer
Makes it easier to support older versions of iOS by fixing things and adding missing methods -
Trackable
DISCONTINUED. Trackable is a simple analytics integration helper library. It’s especially designed for easy and comfortable integration with existing projects.
InfluxDB - Purpose built for real-time analytics at any scale.
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest.
Do you think we are missing an alternative of FBMemoryProfiler or a related project?
README
FBMemoryProfiler
An iOS library providing developer tools for browsing objects in memory over time, using FBAllocationTracker and FBRetainCycleDetector.
About
This library shows how FBAllocationTracker
and FBRetainCycleDetector
can cooperate together, and how they can be used in real app.
It uses FBAllocationTracker to gather information about the objects. It supports generations and retain cycle detection.
Here is a small demo (project is [available in Example directory](Example/))
Installation
Carthage
To your Cartfile add:
github "facebook/FBMemoryProfiler"
FBMemoryProfiler
is built out from non-debug builds, so when you want to test it, use
carthage update --configuration Debug
CocoaPods
To your podspec add:
pod 'FBMemoryProfiler'
You'll be able to use FBMemoryProfiler
fully only in Debug
builds. This is controlled by [compilation flag](FBMemoryProfiler/FBMemoryProfiler.h#L29) that can be provided to the build to make it work in other configurations.
Usage
To start using FBMemoryProfiler
you'll first need to enable FBAllocationTracker
.
#import <FBAllocationTracker/FBAllocationTrackerManager.h>
int main(int argc, char * argv[]) {
[[FBAllocationTrackerManager sharedManager] startTrackingAllocations];
[[FBAllocationTrackerManager sharedManager] enableGenerations];
@autoreleasepool {
return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class]));
}
}
To enable memory profiler:
#import <FBMemoryProfiler/FBMemoryProfiler.h>
FBMemoryProfiler *memoryProfiler = [FBMemoryProfiler new];
[memoryProfiler enable];
// Store memory profiler somewhere to extend it's lifetime
_memoryProfiler = memoryProfiler;
FBMemoryProfiler
will show up as a button on the screen. Once tapped, it will open memory profiler in full size mode.
We can also define plugins (check below) and filters for retain cycle detector, that we pass to configuration.
_memoryProfiler = [[FBMemoryProfiler alloc] initWithPlugins:@[[IncredibleCacheCleaningPlugin new],
[AwesomeLoggerPlugin new]]
retainCycleDetectorConfiguration:someConfigurationWithCustomFilters];
[_memoryProfiler enable];
Plugins
Plugins are objects that conform to [FBMemoryProfilerPluggable](FBMemoryProfiler/Options/FBMemoryProfilerPluggable.h) protocol. Example usage: [custom cache cleaners](Example/ExampleApp/CacheCleanerPlugin.h), [loggers that log data to server](Example/ExampleApp/RetainCycleLoggerPlugin.h).
Contributing
See the [CONTRIBUTING](CONTRIBUTING.md) file for how to help out.
License
See (LICENSE)
*Note that all licence references and agreements mentioned in the FBMemoryProfiler README section above
are relevant to that project's source code only.