28

このコードを使用して2つのNSNumberオブジェクトを比較しましたが、if条件を通過しませんでした。

listItems = [appDelegate.productStatus componentsSeparatedByString:@","];


for (int i=0;i<[appDelegate.productArray count]; i++)
{

    for (int j=0; j<[listItems count]; j++) 
    {
        number=[NSNumber numberWithInt:[[listItems objectAtIndex:j] intValue]];
        NSLog(@"number %@",number);
        productObject=[appDelegate.productArray objectAtIndex:i];           
        NSLog(@"%@,%@",productObject.pid,number);
        if (productObject.pid == number) 
        {
            NSLog(@"BUY it!!!");
            [purchasArray addObject:productObject];
        }

    }
}

なにが問題ですか?

4

4 に答える 4

50

私の推測はそれを次のように比較することです

if([productObject.pid intValue] == [number intValue])
{
 NSLog(@"BUY it!!!");
        [purchasArray addObject:productObject];
}

乾杯。

オブジェクトの比較は避けたい

于 2012-05-03T09:30:52.947 に答える
30

次のコードを変更します。

if ([productObject.pid isEqualToNumber number]) 
    {
        NSLog(@"BUY it!!!");
        [purchasArray addObject:productObject];
    }

うまくいけば、これはあなたを助けるでしょう..

于 2012-05-03T09:26:58.623 に答える
13

'=='の代わりにcompareメソッドを試してください。

if([1stNum compare:secNum] == NSOrderedSame) 
  {
      // do something
  }

それが今役立つかどうか教えてください!

于 2012-05-03T09:25:03.050 に答える
2

このように使用してくださいこれはあなたに役立つと思います

NSNumber *n=[[NSNumber alloc]init];
if([n isEqualToNumber:somenumber])
 {
 }
于 2012-05-03T09:27:50.587 に答える