我创建了一个 C 扩展,其目的是确定一系列牌是否会导致顺子。该示例可能比显示问题所需的复杂一些,但本质上 foo 应该在其中存储所有已评估的卡片(每个卡片都有一个分配的索引)。所以 bar 应该有一套完全独立的卡片和索引。但似乎当我开始将卡片分配给 bar 时,它正在覆盖 foo。我将在下面包含我的代码,以防我对指针做错了什么。
>> require 'ext/straight_count' #=> true
>> foo = EV::StraightCount.new;
>> foo.evaluate(6,0);
>> foo.evaluate(5,1);
>> foo.evaluate(4,2);
>> foo.evaluate(3,3);
>> foo.evaluate(3,4);
>> foo.evaluate(3,5);
>> foo.evaluate(3,6);
>> foo.straight_cards
=> []
>> bar = EV::StraightCount.new;
>> bar.evaluate(11,0);
>> bar.evaluate(10,1);
>> bar.evaluate(9,2);
>> bar.evaluate(8,3);
>> bar.evaluate(7,4);
>> bar.evaluate(2,5);
>> bar.evaluate(2,6);
>> bar.straight_cards
=> [11, 10, 9, 8, 7]
>> foo.evaluate(3,6);
>> foo.straight_cards
=> [11, 10, 9, 8, 7]
.h 文件
static int *pCards;
static int *pSortedCards[NUM_CARDS];
static int i, rMadeHandIndex, cCards[NUM_CARDS], begin_straight, end_straight;
VALUE rIsFound = Qfalse;
static VALUE EV, StraightCount;
static void reset_score();
static VALUE found();
static VALUE score();
static VALUE straight_cards();