You should just need to set the dataSource and delegate properties of your UITableView to the object(s) that you want to perform those roles. Make sure that your new class implements the UITableViewDelegate and UITableViewDataSource protocols in its header file:
@interface MyTableDelegate : NSObject <UITableViewDelegate, UITableViewDataSource>
Where you allocate this object is dependent on your app architecture. The object could be contained in a NIB file or it could be allocated at the same time you allocate the table view controller or in the viewDidLoad method of the controller that allocates your table:
// Create the delegate object and retain a reference to it
MyTableDelegate *tableDelegate = [[MyTableDelegate alloc] init];
self.tableDelegate = tableDelegate;
Then for example, if you are using a navigation controller you might so something like this to create your table and push it onto the stack:
// Create the table view controller
MyTableViewController *viewController = [[MyTableViewController alloc] initWithNibName:@"MyTableView" bundle:nil];
// Set the delegate and data source
viewController.tableView.delegate = tableDelegate;
viewController.tableView.dataSource = tableDelegate;
// push the table view controller onto the naviagtion controller stack
[[self navigationController] pushViewController:viewController animated:YES];
// Clean up resources
[viewController release];
The MyTableDelegate class must as a minimum contain the mandatory methods:
tableView:cellForRowAtIndexPath
tableView.numberOfRowsInSection