誰かにとって楽しいこと間違いなしの1枚です。オブジェクトの配列があり (ここのテスト/デモ コードでは、簡単にするために double にしています)、これらのオブジェクトへのポインターの配列を作成します。
これを行う理由は、オブジェクトを交換するつもりであり、オブジェクト自体を交換するとコストがかかりますが、ポインター (セカンダリ配列内) を交換するのは安価だからです。
ボックス データ型内に多数のサブインデックスがあります。基本的に、私の目標は、ボックスが「所有する」オブジェクトへのポインターの連続したストレッチを維持できるようにすることです。これを行うには、あるボックスから別のボックスに転送するときに、マスター ポインター配列内で多数のスワップを実行する必要があります。ボックス構造内のサブインデックスを使用してこれを行いますが、エラーが発生するのはそこです...エラーについてはコメント行を参照してください。
#include <iostream>
typedef struct box_s {
double * TestArrayPointer;
} box_t;
main () {
double * TestArray;
double ** TestPointerArray;
TestArray = new double [100];
TestPointerArray = new double * [100];
for (unsigned int Counter = 0; Counter<100; Counter++)
{
TestArray[Counter]=Counter;
TestPointerArray[Counter]=&(TestArray[Counter]);
}
for (unsigned int Counter = 0; Counter<100; Counter++)
std::cout << "P: " << TestPointerArray[Counter] << " V: "
<< *(TestPointerArray[Counter]) << std::endl;
box_t Boxes[10];
for (unsigned int Counter = 0; Counter<10; Counter++)
Boxes[Counter].TestArrayPointer = TestPointerArray[Counter*10];
for (unsigned int Counter = 0; Counter<10; Counter++)
std::cout << "P: " << Boxes[Counter].TestArrayPointer << " V: "
<< *(Boxes[Counter].TestArrayPointer)
<< " P+1: " << (Boxes[Counter].TestArrayPointer)+1 << " V+1: "
<< *((Boxes[Counter].TestArrayPointer)+1)
<< " P: " << Boxes[Counter].TestArrayPointer <<std::endl;
for (unsigned int Counter = 0; Counter<10; Counter++)
std::cout << "P: " << &(Boxes[0].TestArrayPointer[Counter]) << " V: "
<< Boxes[0].TestArrayPointer[Counter] << std::endl;
unsigned int ExitBox = 1;
unsigned int EntranceBox=9;
unsigned int OldIndex = 12;
double * TempPtr = TestPointerArray[OldIndex];
if (ExitBox < EntranceBox)
{
//Swap final element of this box into old position
TestPointerArray[OldIndex] = Boxes[ExitBox+1].TestArrayPointer-1;
//Keep swapping start for end
for(unsigned int BoxNum = ExitBox+1; BoxNum<EntranceBox &&
BoxNum+1<=9;BoxNum++)
{
//Fill in new first with last element of old array.
(Boxes[BoxNum-1].TestArrayPointer-1)=
Boxes[BoxNum+1].TestArrayPointer-1; //darn l-value error!
//Change array head pointer to match.
Boxes[BoxNum].TestArrayPointer=Boxes[BoxNum-1].TestArrayPointer-1;
}
Boxes[EntranceBox].TestArrayPointer = TempPtr;
}
for (unsigned int Counter = 0; Counter<100; Counter++)
std::cout << "P: " << TestPointerArray[Counter] << " V: "
<< *(TestPointerArray[Counter]) << std::endl;
}
「-1」が原因だと思いますが、上記のループで「+1」を使用して同様のことを行うと、なぜそれが有効でないのかわかりません。
PS これは REAL テスト コードです。私はコンパイルします
g++ main.cpp
. 私はコメントと大文字小文字に細心の注意を払いませんでした。MSDN の提案する大文字小文字スキームに固執しようとしただけなので、判断しないでください... それはただの簡単で汚いテストです!!
編集1
これが気にする人のための作業コードです... PMG使用法をc++
考慮してこれを変更しました。new
そしてヒース、あなたの答えは根本的な問題を解決しませんでしたが、私はあなたに信用を与えています.
これが本当の解決策です:
#include <iostream>
typedef struct box_s {
double ** TestArrayPointer;
unsigned int NumberPoints;
} box_t;
main () {
double * TestArray;
double ** TestPointerArray;
TestArray = new double [100];
TestPointerArray = new double * [100];
for (unsigned int Counter = 0; Counter<100; Counter++)
{
TestArray[Counter]=Counter;
TestPointerArray[Counter]=&(TestArray[Counter]);
}
for (unsigned int Counter = 0; Counter<100; Counter++)
std::cout << "P: " << TestPointerArray[Counter] << " V: "
<< *(TestPointerArray[Counter]) << std::endl;
box_t Boxes[10];
for (unsigned int Counter = 0; Counter<10; Counter++)
{
Boxes[Counter].TestArrayPointer = TestPointerArray+Counter*10;
Boxes[Counter].NumberPoints=10;
}
for (unsigned int Counter = 0; Counter<10; Counter++)
std::cout << "P: " << Boxes[Counter].TestArrayPointer << " V: "
<< *(Boxes[Counter].TestArrayPointer)
<< " P+1: " << (Boxes[Counter].TestArrayPointer)+1 << " V+1: "
<< *((Boxes[Counter].TestArrayPointer)+1)
<< " P: " << Boxes[Counter].TestArrayPointer <<std::endl;
for (unsigned int Counter = 0; Counter<10; Counter++)
std::cout << "P: " << &(Boxes[0].TestArrayPointer[Counter]) << " V: "
<< Boxes[0].TestArrayPointer[Counter] << std::endl;
unsigned int ExitBox = 1;
unsigned int EntranceBox=9;
unsigned int OldIndex = 12;
double * TempPtr = TestPointerArray[OldIndex];
if (ExitBox < EntranceBox)
{
Boxes[ExitBox].NumberPoints--;
Boxes[EntranceBox].NumberPoints++;
//Swap final element of this box into old position
TestPointerArray[OldIndex] = *(Boxes[ExitBox+1].TestArrayPointer-1);
//Keep swapping start for end
for(unsigned int BoxNum = ExitBox+1; BoxNum<EntranceBox &&
BoxNum+1<=9;BoxNum++)
{
Boxes[BoxNum].TestArrayPointer=
Boxes[BoxNum].TestArrayPointer-1;
//Fill in new first with last element of old array.
*(Boxes[BoxNum].TestArrayPointer)=
*(Boxes[BoxNum+1].TestArrayPointer)-1;
std::cout <<"---------------------" << std::endl;
for (unsigned int Counter = 0; Counter<100; Counter++)
std::cout << "P: " << TestPointerArray[Counter] << " V: "
<< *(TestPointerArray[Counter]) << std::endl;
}
Boxes[EntranceBox].TestArrayPointer=
Boxes[EntranceBox].TestArrayPointer-1;
*(Boxes[EntranceBox].TestArrayPointer) = TempPtr;
}
for(unsigned int BoxNum = 0; BoxNum<=9;BoxNum++)
{
std::cout <<"---------------------" << std::endl;
for(unsigned int Counter = 0; Counter<Boxes[BoxNum].NumberPoints;
Counter++)
std::cout << "P: " <<Boxes[BoxNum].TestArrayPointer[Counter]
<< " V: "
<< *(Boxes[BoxNum].TestArrayPointer[Counter])
<< std::endl;
}
}
適切なスワッピングに注意してください!!