
next 메서드가 레코드를 가져오지 못할 때 에러가 발생하는 이유는 다음 두 가지 경우에 해당합니다.
1. 레코드가 존재하지 않는 경우: next 메서드는 이전에 가져온 레코드의 다음 레코드를 가져오기 때문에, 레코드가 존재하지 않는 경우 에러가 발생합니다. 예를 들어, 레코드가 1, 2, 3 순서로 저장되어 있으면, 레코드 3을 가져온 후 next 메서드를 호출하면 에러가 발생합니다.
2. 레코드가 삭제된 경우: 레코드가 삭제된 경우 next 메서드는 삭제된 레코드의 다음 레코드를 가져오려고 하므로 에러가 발생합니다.
이러한 문제를 해결하는 방법은 다음과 같습니다.
* 레코드를 가져올 때 next 메서드를 사용하지 말고, get 메서드를 사용하여 레코드를 가져오고, 레코드가 존재하지 않는 경우 false를 반환하도록 하세요.
* 레코드를 삭제할 때 delete 메서드를 사용하여 레코드를 삭제하세요. delete 메서드는 레코드가 삭제된 경우 true를 반환하므로, 레코드가 삭제된 경우 next 메서드를 호출하지 않도록 하세요.
예를 들어, 다음 코드와 같이 사용할 수 있습니다.
#hostingforum.kr
php
$table = new SwooleTable(100, 2);
$table->create("id", SwooleTable::TYPE_INT, 11);
$table->create("name", SwooleTable::TYPE_STRING, 50);
$table->set(1, ["id" => 1, "name" => "John"]);
$table->set(2, ["id" => 2, "name" => "Jane"]);
while (true) {
$row = $table->get(1);
if ($row === false) {
break;
}
echo $row["id"] . " " . $row["name"] . "n";
$table->delete(1); // 레코드 삭제
}
이 코드에서는 get 메서드를 사용하여 레코드를 가져오고, 레코드가 삭제된 경우 delete 메서드를 사용하여 레코드를 삭제합니다.
2025-05-18 08:25