Objective C Char数组问题

时间:2012-11-15 19:48:31

标签: objective-c arrays char symbols

嘿伙计们所以我正在努力学习目标c作为我学校的一项独立研究,我的一个项目就是练习计算机程序,用户输入一串数字和操作符,程序将它分开并进行计算。现在我有输入,我试图让它找到运算符并将它们全部放在一个数组中,以便它可以对它们进行排序以查找操作顺序并使用索引来查找不同的术语;然而,当我尝试打印出数组以查看它是否持有字符时,它会输出一些奇怪的符号,如苹果徽标或倒置的问号。我已经提出了我的问题的SSCCE - 有谁知道发生了什么?

int main(int argc, const char * argv[])
{
@autoreleasepool {

    NSString *calculation;
    char str[50] = {0};
    int count = 0;

    NSLog(@"What would you like to calculate?");
    scanf("%s", str);
    calculation = [NSString stringWithUTF8String:str];

    for (int i = 0; i < [calculation length]; i++) {
        NSRange range = NSMakeRange (i, 1);
        if([[calculation substringWithRange: range] isEqualToString: @"*"] ||
           [[calculation substringWithRange: range] isEqualToString: @"/"])
            count++;
    }

    char operators[count];
    for (int i = 0; i < count; i++) {
        for (int j = 0; j < [calculation length]; j++) {
            NSRange range = NSMakeRange (j, 1);
            NSString *s = [s initWithString:[calculation substringWithRange: range]];
            if([s isEqualToString:@"*"]){
                operators[i] = '*';
                break;
            }
            if([s isEqualToString:@"/"]){
                operators[i] = '/';
                break;
            }
        }
        NSLog(@"%c", operators[i]);
    }

}
return 0;
}

2 个答案:

答案 0 :(得分:1)

回答关于代码中发生了什么的问题。您看到的“奇怪符号”是operators[]数组内存中未初始化的值。

要查看char []留下垃圾值的原因,请查看代码的这一部分:

    ...
    NSString *s = [s initWithString:[calculation substringWithRange: range]];
    if([s isEqualToString:@"*"]){
        operators[i] = '*';
        break;
    }
    ...

您正在向initWithString发送ss尚未分配。这导致snil。由于向isEqualToString:发送nil这样的消息,基本评估NO,即使@"*"在该范围内,您的作业也会operators[i] 1}}永远不会发生。

轻松修复,只需将s作业替换为:

NSString *s = [calculation substringWithRange:range];

答案 1 :(得分:0)

你不需要任何花哨的东西。但是:使用东西来实现它的目的。

#import <Foundation/Foundation.h>

int main()
{
    NSAutoreleasePool *pool = [NSAutoreleasePool new];

    char str[128];
    printf("Enter formula:\n");
    scanf("%s", str); // this is DAMN unsafe, btw

    NSMutableArray *arr = [NSMutableArray array];

    char *s = str;
    while (*s) {
        if (*s == '*') {
            [arr addObject:@"*"];
        } else if (*s == '/') {
            [arr addObject:@"/"];
        }
        s++;
    }
    printf("\n");

    [arr enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) {
        NSLog(@"%@", obj);
    }];

    [pool drain];
    return 0;
}