0

由于我找到了dart-sqlite无法正常工作的原因,因此修改了此问题。

以下是原始问题:

我将 Dart 与 sqlite 一起使用,我使用的驱动程序是dart-sqlite

简单的代码:

库 seg_tests;

import 'package:dart-sqlite/sqlite.dart';

main() {
    var db = new Database.inMemory();
    db.execute("""
        CREATE TABLE Topic (
          id           text PRIMARY KEY,
          title        text NOT NULL,
          content      text,
          categoryId   text NOT NULL,
          createdAt    int  NOT NULL,
          updatedAt    int,
          tags         text,
          state        text,
          viewCount    int,
          commentCount int
        );
    """, []);
    db.close();
}

当我运行它时,它运行但报告错误:

➜  test git:(master) ✗ dart TestSqliteSegFault.dart
[1]    24904 segmentation fault  dart TestSqliteSegFault.dart

然后我删除了 sql 的一些内容,使其更短:

import 'package:dart-sqlite/sqlite.dart';

main() {
    var db = new Database.inMemory();
    db.execute("""
        CREATE TABLE Topic (
          id           text PRIMARY KEY,
          title        text NOT NULL,
          content      text
        );
    """, []);
    db.close();
}

它报告了另一个错误:

➜  test git:(master) ✗ dart TestSqliteSegFault.dart
Warning: sqlite.Statement was not closed before garbage collection.

我检查了来源,但我找不到该语句未关闭的原因。


更新:

代码 dart_sqlite.cc不能用最新的 Dark-SDK 编译(我的意思是 0.6.5.0_r25017 (Mon Jul 15 14:58:03 2013)),因为已经dart_api.h改变了。

以前只有一个Dark_Handler,现在有三个:Dark_Handler, Dart_PersistentHandle, Dart_WeakPersistentHandle。它们可以直接从一种转换为另一种。

我试图自己修复这一切,但我发现三个手柄有不同的生命周期。我可以编译它,但不能很好地工作。

4

1 回答 1

1

我刚刚发现它已在另一个分支中修复:https ://github.com/zoidrr/dart-sqlite

感谢 zoidrr。

于 2013-07-27T14:53:37.517 回答