我正在根據本教程將sqlcipher整合到一個iOS項目中:https://www.zetetic.net/sqlcipher/ios-tutorial/ 有一個小貼士說:如果libsqlite3.dylib或其他SQLite框架列在Link Binary With Libraries列表中,請務必將其刪除,或者你會看到重複的符號錯誤。
但我試圖將libsqlite3.tbd(xcode 7中沒有dylib)和libsqlcipher.a添加到鏈接二進制文件庫,不會出現重複符號錯誤!爲什麼?
我注意到如果我點擊#import <sqlite3.h>
行,xcode顯示xcode的lib文件夾中的sqlite3.h文件,而不是sqlcipher中的。 但是,sqlcipher確實有效,數據庫真的是加密的。爲什麼鏈接libsqlite3.dylib和libsqlcipher.a時不會出現重複符號錯誤?
0
A
回答
0
libsqlite3.tbd
只是一個文本文件,它定義了庫,目標平臺,dylib安裝路徑和導出符號所支持的平臺體系結構。使用.tbd
文件,可以減少捆綁的應用程序大小,因爲庫二進制文件已包含在平臺設備中,因此無需將其鏈接到應用程序映像中。
libsqlite3.tbd
看起來是這樣的:
---
archs: [ armv7, armv7s, arm64 ]
platform: ios
install-name: /usr/lib/libsqlite3.dylib
current-version: 216.4
compatibility-version: 9.0
exports:
- archs: [ armv7, armv7s, arm64 ]
symbols: [ __sqlite3_lockstate, __sqlite3_purgeEligiblePagerCacheMemory,
__sqlite3_system_busy_handler, __sqlite_auto_profile,
__sqlite_auto_profile_syslog, __sqlite_auto_trace,
__sqlite_auto_trace_syslog, _sqlite3OsShmHasMultipleLinks,
_sqlite3OsShmRenamedWhileOpen, _sqlite3OsShmWasTruncated,
_sqlite3OsShmWasUnlinkedWhileOpen, _sqlite3VersionNumber,
_sqlite3VersionString, _sqlite3_aggregate_context,
_sqlite3_aggregate_count, _sqlite3_auto_extension,
_sqlite3_backup_finish, _sqlite3_backup_init, _sqlite3_backup_pagecount,
_sqlite3_backup_remaining, _sqlite3_backup_step,
_sqlite3_bind_blob, _sqlite3_bind_blob64, _sqlite3_bind_double,
_sqlite3_bind_int, _sqlite3_bind_int64, _sqlite3_bind_null,
_sqlite3_bind_parameter_count, _sqlite3_bind_parameter_index,
_sqlite3_bind_parameter_name, _sqlite3_bind_text,
_sqlite3_bind_text16, _sqlite3_bind_text64, _sqlite3_bind_value,
_sqlite3_bind_zeroblob, _sqlite3_blob_bytes, _sqlite3_blob_close,
_sqlite3_blob_open, _sqlite3_blob_read, _sqlite3_blob_reopen,
_sqlite3_blob_write, _sqlite3_busy_handler, _sqlite3_busy_timeout,
_sqlite3_cancel_auto_extension, _sqlite3_changes,
_sqlite3_clear_bindings, _sqlite3_close, _sqlite3_close_v2,
_sqlite3_collation_needed, _sqlite3_collation_needed16,
_sqlite3_column_blob, _sqlite3_column_bytes, _sqlite3_column_bytes16,
_sqlite3_column_count, _sqlite3_column_decltype,
_sqlite3_column_decltype16, _sqlite3_column_double,
_sqlite3_column_int, _sqlite3_column_int64, _sqlite3_column_name,
_sqlite3_column_name16, _sqlite3_column_text, _sqlite3_column_text16,
_sqlite3_column_type, _sqlite3_column_value, _sqlite3_commit_hook,
_sqlite3_compileoption_get, _sqlite3_compileoption_used,
_sqlite3_complete, _sqlite3_complete16, _sqlite3_config,
_sqlite3_context_db_handle, _sqlite3_create_collation,
_sqlite3_create_collation16, _sqlite3_create_collation_v2,
_sqlite3_create_function, _sqlite3_create_function16,
_sqlite3_create_function_v2, _sqlite3_create_module,
_sqlite3_create_module_v2, _sqlite3_data_count,
_sqlite3_data_directory, _sqlite3_db_config, _sqlite3_db_filename,
_sqlite3_db_handle, _sqlite3_db_mutex, _sqlite3_db_readonly,
_sqlite3_db_release_memory, _sqlite3_db_status,
_sqlite3_declare_vtab, _sqlite3_enable_shared_cache,
_sqlite3_errcode, _sqlite3_errmsg, _sqlite3_errmsg16,
_sqlite3_errstr, _sqlite3_exec, _sqlite3_expired,
_sqlite3_extended_errcode, _sqlite3_extended_result_codes,
_sqlite3_file_control, _sqlite3_finalize, _sqlite3_free,
_sqlite3_free_table, _sqlite3_get_autocommit, _sqlite3_get_auxdata,
_sqlite3_get_table, _sqlite3_global_recover, _sqlite3_initialize,
_sqlite3_intarray_bind, _sqlite3_intarray_create,
_sqlite3_interrupt, _sqlite3_last_insert_rowid,
_sqlite3_libversion, _sqlite3_libversion_number,
_sqlite3_limit, _sqlite3_log, _sqlite3_malloc, _sqlite3_malloc64,
_sqlite3_memory_alarm, _sqlite3_memory_highwater,
_sqlite3_memory_used, _sqlite3_mprintf, _sqlite3_msize,
_sqlite3_mutex_alloc, _sqlite3_mutex_enter, _sqlite3_mutex_free,
_sqlite3_mutex_leave, _sqlite3_mutex_try, _sqlite3_next_stmt,
_sqlite3_open, _sqlite3_open16, _sqlite3_open_v2,
_sqlite3_os_end, _sqlite3_os_init, _sqlite3_overload_function,
_sqlite3_prepare, _sqlite3_prepare16, _sqlite3_prepare16_v2,
_sqlite3_prepare_v2, _sqlite3_profile, _sqlite3_progress_handler,
_sqlite3_randomness, _sqlite3_realloc, _sqlite3_realloc64,
_sqlite3_release_memory, _sqlite3_reset, _sqlite3_reset_auto_extension,
_sqlite3_result_blob, _sqlite3_result_blob64, _sqlite3_result_double,
_sqlite3_result_error, _sqlite3_result_error16,
_sqlite3_result_error_code, _sqlite3_result_error_nomem,
_sqlite3_result_error_toobig, _sqlite3_result_int,
_sqlite3_result_int64, _sqlite3_result_null, _sqlite3_result_text,
_sqlite3_result_text16, _sqlite3_result_text16be,
_sqlite3_result_text16le, _sqlite3_result_text64,
_sqlite3_result_value, _sqlite3_result_zeroblob,
_sqlite3_rollback_hook, _sqlite3_rtree_geometry_callback,
_sqlite3_rtree_query_callback, _sqlite3_set_authorizer,
_sqlite3_set_auxdata, _sqlite3_shutdown, _sqlite3_sleep,
_sqlite3_snprintf, _sqlite3_soft_heap_limit, _sqlite3_soft_heap_limit64,
_sqlite3_sourceid, _sqlite3_sql, _sqlite3_status,
_sqlite3_status64, _sqlite3_step, _sqlite3_stmt_busy,
_sqlite3_stmt_readonly, _sqlite3_stmt_status, _sqlite3_strglob,
_sqlite3_stricmp, _sqlite3_strnicmp, _sqlite3_table_column_metadata,
_sqlite3_temp_directory, _sqlite3_test_control,
_sqlite3_thread_cleanup, _sqlite3_threadsafe, _sqlite3_total_changes,
_sqlite3_trace, _sqlite3_transfer_bindings, _sqlite3_update_hook,
_sqlite3_uri_boolean, _sqlite3_uri_int64, _sqlite3_uri_parameter,
_sqlite3_user_data, _sqlite3_value_blob, _sqlite3_value_bytes,
_sqlite3_value_bytes16, _sqlite3_value_double, _sqlite3_value_int,
_sqlite3_value_int64, _sqlite3_value_numeric_type,
_sqlite3_value_text, _sqlite3_value_text16, _sqlite3_value_text16be,
_sqlite3_value_text16le, _sqlite3_value_type, _sqlite3_version,
_sqlite3_vfs_find, _sqlite3_vfs_register, _sqlite3_vfs_unregister,
_sqlite3_vmprintf, _sqlite3_vsnprintf, _sqlite3_vtab_config,
_sqlite3_vtab_on_conflict, _sqlite3_wal_autocheckpoint,
_sqlite3_wal_checkpoint, _sqlite3_wal_checkpoint_v2,
_sqlite3_wal_hook ]
...
您不會收到重複的符號鏈接錯誤,因爲你只包括一個單一的二進制庫,libsqlcipher.a
。如果您希望在iOS應用程序中使用SQLCipher,則需要刪除libsqlite3.tbd
參考,幷包含libsqlcipher.a
。
相關問題
- 1. 爲什麼鏈接時會出現多重定義錯誤?
- 2. 鏈接多個靜態庫時出現重複符號錯誤。
- 3. 爲什麼在Windows上使用CMake構建時會出現重複的符號鏈接器錯誤?
- 4. 鏈接器錯誤嘗試鏈接libFlurryAds時出現重複符號
- 5. 「重複的符號」鏈接錯誤
- 6. SMCalloutView重複符號鏈接錯誤iOS
- 7. 重複符號鏈接器錯誤
- 8. 鏈接錯誤重複符號
- 9. iOS - 鏈接器錯誤,重複符號
- 10. 爲什麼當沒有重複輸入時會出現重複輸入錯誤?
- 11. sqlite3 xcode libsqlite3.dylib
- 12. GoogleCast.framework出現重複的符號錯誤
- 13. libsqlite3.dylib和libsqlite3.0.dylib有何區別?
- 14. 爲模擬器構建OpenEars時出現重複符號錯誤
- 15. 鏈接libz.dylib和libsqlite3.dylib在Xamarin的iOS項目
- 16. 爲什麼在C上對動態鏈接符號執行指針算術時會出現錯誤結果?
- 17. 當我進行可選鏈接時,爲什麼會出現錯誤?
- 18. 使用[]運算符時爲什麼會出現編譯錯誤?
- 19. 爲什麼在g ++中編譯時會出現符號引用錯誤?
- 20. 從鏈接上從錯誤的dylib中拾取的符號
- 21. 從外部鏈接重複提取時出現錯誤91
- 22. 爲什麼會出現分段錯誤?
- 23. 爲什麼會出現語法錯誤?
- 24. 爲什麼會出現段錯誤11
- 25. 爲什麼會出現錯誤?
- 26. 爲什麼會出現名稱錯誤?
- 27. 爲什麼會出現MySQL錯誤1064
- 28. 爲什麼會出現錯誤?
- 29. 爲什麼會出現分析錯誤?
- 30. 爲什麼會出現分段錯誤?
非常感謝!但我做了另一個實驗......我從www.sqlite.org下載sqlite源代碼並將sqlite3.h sqlite3.c添加到項目中。重複的符號錯誤仍然不會發生... –
你確定你正在正確鏈接libsqlcipher.a嗎? –
是的。 libsqlcipher.a是Link Binary With Libraries中唯一添加的。我用hexdump檢查創建的sqlite數據庫文件,它真的是加密的。 –