Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/objective-c/27.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Objective c 一元表达式的参数类型无效_Objective C_Uisearchbar_Tableview - Fatal编程技术网

Objective c 一元表达式的参数类型无效

Objective c 一元表达式的参数类型无效,objective-c,uisearchbar,tableview,Objective C,Uisearchbar,Tableview,我有这个程序,第一个视图是tableView。我还实现了(或至少尝试了)视图顶部的搜索栏。已经花了几个小时寻找解决方案,但没有积极的结果 #import "FirstViewController.h" #import "NSDictionary-MutableDeepCopy.h" @implementation FirstViewController @synthesize listData, table, search, allNames, names, keys; #pragma

我有这个程序,第一个视图是tableView。我还实现了(或至少尝试了)视图顶部的搜索栏。已经花了几个小时寻找解决方案,但没有积极的结果

#import "FirstViewController.h"
#import "NSDictionary-MutableDeepCopy.h"


@implementation FirstViewController

@synthesize listData, table, search, allNames, names, keys;

#pragma mark -
#pragma mark Custom Methods 

- (void)resetSearch {
    NSMutableDictionary *allNamesCopy = [self.allNames mutableDeepCopy];
    self.names = allNamesCopy;
    [allNamesCopy release];
    NSMutableArray *keyArray = [[NSMutableArray alloc] init];
    [keyArray addObjectsFromArray:[[self.allNames allKeys]
                                   sortedArrayUsingSelector:@selector(compare:)]];
    self.keys = keyArray;
   [keyArray release];
}

-(void)handleSearchForTerm:(NSString *)searchTerm {
    NSMutableArray *sectionsToRemove = [[NSMutableArray alloc] init];
    [self resetSearch];

    for (NSString *key in self.keys) {
        NSMutableArray *array = [names valueForKey:key];
        NSMutableArray *toRemove = [[NSMutableArray alloc] init];
        for (NSString *name in listData) {
            if ([name rangeOfString:searchTerm
                options:NSCaseInsensitiveSearch].location == NSNotFound)
                [toRemove addObject:name];
        }

        if ([array count] == [toRemove count])
            [sectionsToRemove addObject:key];

        [array removeObjectsInArray:toRemove];

        [toRemove release];

    }
    [self.keys removeObjectsInArray:sectionsToRemove];
    [sectionsToRemove release];
    [table reloadData];

}


- (void)viewDidLoad {    

    NSString *path = [[NSBundle mainBundle] pathForResource:@"sortednames" ofType:@"plist"];
    NSDictionary *dict = [[NSDictionary alloc] initWithContentsOfFile:path];

    self.names = dict;
    self.allNames = dict;

    [dict release];

    [self resetSearch];
    [table reloadData];
    [table setContentOffset:CGPointMake(0.0, 44.0)animated:NO];

    self.parentViewController.view.backgroundColor = [UIColor colorWithPatternImage:[UIImage imageNamed:@"background.png"]];

    NSArray *array = [[NSArray alloc] initWithObjects:

// A larger amount of objects here.

self.listData = array;

    [array release];
    [super viewDidLoad];

}

/*
 // The designated initializer. Override to perform setup that is required before the view is loaded.
 - (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil {
 if ((self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil])) {
 // Custom initialization
 }
 return self;
 }
 */

/*
 // Implement loadView to create a view hierarchy programmatically, without using a nib.
 - (void)loadView {
 }
 */

/*
 // Implement viewDidLoad to do additional setup after loading the view, typically from a nib.
 - (void)viewDidLoad {
 [super viewDidLoad];
 }
 */

/*
 // Override to allow orientations other than the default portrait orientation.
 - (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation {
 // Return YES for supported orientations
 return (interfaceOrientation == UIInterfaceOrientationPortrait);
 }
 */

- (void)didReceiveMemoryWarning {
    // Releases the view if it doesn't have a superview.
    [super didReceiveMemoryWarning];

    // Release any cached data, images, etc that aren't in use.
}

- (void)viewDidUnload {
    // Release any retained subviews of the main view.
    // e.g. self.myOutlet = nil;

    self.listData =  nil;
    self.table = nil;
    self.search = nil;
    self.allNames = nil;
    self.names = nil;
    self.keys = nil;

}


- (void)dealloc {
    [listData release];
    [search release];
    [table release];
    [allNames release];
    [keys release];
    [names release];
    [super dealloc];
}

#pragma mark -
#pragma mark Table View Data Source Methods

- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {
    return ([keys count] > 0) ? [keys count] : 1;

}

- (NSInteger)tableView:(UITableView *)aTableView
 numberOfRowsInSection: (NSInteger)section {
    return [self.listData count];
    if ([keys count] == 0)
        return 0;
    NSString *key = [keys objectAtIndex:section];
    NSArray *nameSection = [names objectForKey:key];
    return [nameSection count];
}

- (UITableViewCell *) extracted_method: (UITableViewCell *) cell  {
  return cell;

}
- (UITableViewCell *)tableView:(UITableView *)aTableView

cellForRowAtIndexPath:(NSIndexPath *)indexPath {

    NSUInteger section = [indexPath section];
    NSUInteger row = [indexPath row];   

    NSString *key = [keys objectAtIndex:section];
    NSArray *nameSection = [names objectForKey:key];

    static NSString *sectionsTableIdentifier = @"sectionsTableIdentifier";

    UITableViewCell *cell = [aTableView dequeueReusableCellWithIdentifier:
                             sectionsTableIdentifier];

    if (cell == nil) {
        cell = [[[UITableViewCell alloc]initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier: sectionsTableIdentifier] autorelease];

}

    cell.backgroundColor = [UIColor clearColor];
    cell.textColor = [UIColor whiteColor]; 
    cell.detailTextLabel.textColor = [UIColor whiteColor];
    cell.text = [nameSection objectAtIndex:row];

    [self extracted_method: cell].text = [listData objectAtIndex:row];

    return cell;

} 

     - (NSString *)tableView:(UITableView *)tableView 
    titleForHeaderInSection:(NSInteger)section {
    if ([keys count] == 0)
        return nil;


     NSString *key = [keys objectAtIndex:section];
     return key;    

     }

     -(NSArray *)sectionIndexTitlesForTableView:(UITableView *)tableView {
        return keys;

     }

#pragma mark -
#pragma mark Table View Delegate Methods
        - (NSIndexPath *)tableView:(UITableView *)tableView
    willSelectRowAtIndexPath:(NSIndexPath *)indexPath {
            [search resignFirstResponder];
            return indexPath;
    }


#pragma mark -
#pragma mark Search Bar Delegate Methods

- (void)searchBarSearchButtonClicked:(UISearchBar *)searchBar {
        NSString *searchTerm = [searchBar text];
        [self handleSearchForTerm:searchTerm];
}

- (void)searchBar:(UISearchBar *)searchBar
textDidChange:(NSString *)searchTerm {
    if ([searchTerm length] == 0) {
    [self resetSearch];
    [table reloadData];
    return;
}

  [self handleSearchForTerm:searchTerm];
}


    - (void)searchBarCancelButtonClicked:(UISearchBar *)searchBar {
        search.text = @"";
        [self resetSearch];
        [table reloadData];
        [searchBar resignFirstResponder];

}
@end
好的,伙计们。我的问题是,这无法使搜索功能正常工作。此外,我在这条线路上收到信号SIGABRT:

    NSString *key = [keys objectAtIndex:section];
所以我需要两件事的帮助:

他说:我得把那个条子拿开

错误日志消息:*由于未捕获异常而终止应用程序 “NSRangeException”,原因:'*-[NSMutableArray objectAtIndex:]: 索引0超出空数组“”的边界

也就是说,我不在密钥中存储任何数据。我该怎么做?我会储存什么

2:希望搜索功能在我的listData数组中搜索


提前谢谢-希望你能帮忙

您尚未完成
sectionIndexTitlesForTableView:
方法。现在是:

-(NSArray *)sectionIndexTitlesForTableView:(UITableView *)tableView {
        return keys;
没有关闭
}
,因此编译器认为之后的所有内容仍然是该方法的一部分。当您尝试定义下一个方法时,请使用
-(nsindepath*)
指示它是一个返回nsindepath*的实例方法,但编译器认为您正在尝试减法

解决方案很简单:将}添加到
节index xtitlesfortableview:
的末尾

-(NSArray *)sectionIndexTitlesForTableView:(UITableView *)tableView {
        return keys;
}

错误消息表明,当编译器看到引入方法的“-”时,它认为它正在解析表达式。检查此点以上的大括号是否正确匹配。如果他们确实发布了更多的上下文代码。添加了更多的代码。我不太明白你的意思:)是的,我自己也想到了。但是,当我把}放在该方法的末尾时,它会将程序中的其余行变成错误。。。A感谢您的帮助:)