Variable arguments in Objective-C methods
Q: How can I write a method that takes a variable number of arguments, like NSString's +stringWithFormat:?
A: How can I write a method that takes a variable number of arguments, like NSString's +stringWithFormat:?
Methods that take variable arguments are known as variadic methods.
Keep in mind that the implementation of an Objective-C method is just a block of code, like a C function. The variadic argument macros described in the stdarg(3) manual page work the same way in a method as they do in an ordinary function.
Here's an example of an Objective-C category, containing a variadic method that appends all the objects in a nil-terminated list of arguments to an NSMutableArray instance:
Listing 1 A typical variadic method.
#import <Cocoa/Cocoa.h>
@interface NSMutableArray (variadicMethodExample)
- (void) appendObjects:(id) firstObject, ...; // This method takes a nil-terminated list of objects.
@end
@implementation NSMutableArray (variadicMethodExample)
- (void) appendObjects:(id) firstObject, ...
{
id eachObject;
va_list argumentList;
if (firstObject) // The first argument isn't part of the varargs list,
{ // so we'll handle it separately.
[self addObject: firstObject];
va_start(argumentList, firstObject); // Start scanning for arguments after firstObject.
while (eachObject = va_arg(argumentList, id)) // As many times as we can get an argument of type "id"
[self addObject: eachObject]; // that isn't nil, add it to self's contents.
va_end(argumentList);
}
}
@end |
See the stdarg(3) manual page for the full documentation of the va_list type, and the va_start(), va_arg(), and va_end() macros.
Document Revision History
| Date | Notes |
|---|---|
| 2005-01-13 | New document that how to implement methods which take a variable number of arguments. |
Copyright © 2005 Apple Computer, Inc. All Rights Reserved. Terms of Use | Privacy Policy | Updated: 2005-01-13