# C++
提示
在接入前, 请先阅读接入前准备。
最新版本:1.2.7
更新时间:2023-04-07
Beta版本为: v1.2.8-beta.2
# 一、集成SDK
# Ⅰ. 编译源码,获取libthinkingdata.a文件
- TE SDK 依赖 rapidjson (opens new window)解析库,你需要下载 rapidjson 库到本地。
- 下载 C++ SDK 源码,修改 SDK 中的
CMakeLists.txt
文件,选择你需要的数据消费者进行打包(详细内容可以参考SDK源码内的CMakeLists.txt
文件)。这里以最常用的log
consumer
举例:
cmake_minimum_required(VERSION 3.12)
project(ThinkingEngine)
set(CMAKE_CXX_STANDARD 11)
if(NOT CMAKE_BUILD_TYPE)
set(CMAKE_BUILD_TYPE release CACHE STRING "Build Type" FORCE)
endif()
message(STATUS "[ThinkingEngine] current cmake version: ${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION}.${CMAKE_PATCH_VERSION}")
message(STATUS "[ThinkingEngine] CMAKE_HOST_SYSTEM: ${CMAKE_HOST_SYSTEM} ")
message(STATUS "[ThinkingEngine] Build type:${CMAKE_BUILD_TYPE}")
message(STATUS "[ThinkingEngine] Debug configuration:${CMAKE_CXX_FLAGS_DEBUG}")
message(STATUS "[ThinkingEngine] release configuration:${CMAKE_CXX_FLAGS_RELEASE}")
message(STATUS "[ThinkingEngine] release configuration with debug info:${CMAKE_CXX_FLAGS_RELWITHDEBINFO}")
message(STATUS "[ThinkingEngine] minimal release configuration:${CMAKE_CXX_FLAGS_MINSIZEREL}")
include_directories(include)
#
# log consumer. Recommended for production environments
#
set(TE_LIB_NAME thinkingdata)
add_library(${TE_LIB_NAME} src/ThinkingAnalyticsAPI.cpp src/TAUtils.cpp src/TALoggerConsumer.cpp src/TAConsumer.cpp)
if(UNIX)
find_package(Threads REQUIRED)
target_link_libraries(${TE_LIB_NAME} Threads::Threads)
endif()
rapidjson 库是一个纯
.h
库,所以以头文件的形式引入到你的工程。如果你的工程没有引入 rapidjson 库,那么请导入如下头文件即可:
如果你的工程之前已经引入了 rapidjson 库,那么请只需导入 TE SDK 的头文件。然后需要修改并确认
TAJsonParse.h
文件内的内容,核对文件内对 rapidjson 库的引入路径是否正确:
# Ⅱ. 安装Logbus
我们推荐使用SDK+LogBus的形式,完成服务端数据的采集上报.您可以参考以下文档完成Logbus的安装:LogBus使用指南
# 二、初始化
导入头文件:
#include "../include/ThinkingAnalyticsAPI.h"
#include "../include/TALoggerConsumer.h"
#include "../include/TADebugConsumer.h"
#include "../include/TABatchConsumer.h"
以下是SDK初始化的示例代码:
LoggerConsumer::Config config = LoggerConsumer::Config("H:/log", 20, 1000, LoggerConsumer::HOURLY);
config.fileNamePrefix = "te";
config.rotateMode = LoggerConsumer::HOURLY;
TAConsumer *consumer = new LoggerConsumer(config);
ThinkingDataAnalytics te(*consumer, false);
LOG_DIRECTORY
为写入本地的文件夹地址。您只需将 LogBus 的监听文件夹地址设置为此处的地址,即可使用 LogBus 进行数据的监听上传。
# 三、常用功能
为了保证访客 ID 与账号 ID 能够顺利进行绑定,如果您的游戏中会用到访客 ID 与账号 ID,我们极力建议您同时上传这两个 ID,否则将会出现账号无法匹配的情况,导致用户重复计算,具体的 ID 绑定规则可参考用户识别规则一章。
# 3.1 发送事件
您可以调用track
来上传事件,建议您根据先前梳理的文档来设置事件的属性以及发送信息的条件,以下是发送事件的示例代码:
TaSDK::PropertiesNode event_properties;
event_properties.SetString("name1", "XZ_debug");
event_properties.SetString("name2", "logbugs");
event_properties.SetString("name3", "name3");
event_properties.SetString("#uuid", "1234567890");
event_properties.SetNumber("test_number_int", 3);
event_properties.SetNumber("test_number_double", 3.14);
event_properties.SetBool("test_bool", true);
std::string test_string = "test_string";
event_properties.SetString("test_stl_string1", test_string);
event_properties.SetDateTime("test_time1", time(nullptr), 0);
timeb t = {};
ftime(&t);
event_properties.SetDateTime("#time", t.time, t.millitm);
std::vector<std::string> test_list;
test_list.push_back("item11");
test_list.push_back("item21");
event_properties.SetList("test_list1", test_list);
// track event
te.track(accountId, distincId, eventName, event_properties);
- 事件的名称是字符串类型,只能以字母开头,可包含数字,字母和下划线 "_",长度最大为 50 个字符。
- Key 为该属性的名称,为字符串类型,规定只能以字母开头,包含数字,字母和下划线 "_",长度最大为 50 个字符,对字母大小写不敏感,TE会统一转化为小写字母
- Value 为该属性的值,支持字符串、数字、布尔、时间、对象、对象组、数组
用户属性的要求与事件属性保持一致
# 3.2 设置用户属性
对于一般的用户属性,您可以调用 user_set
来进行设置,使用该接口上传的属性将会覆盖原有的属性值,如果之前不存在该用户属性,则会新建该用户属性,类型与传入属性的类型一致,此处以设置用户名为例:
// user_set
TaSDK::PropertiesNode userSet_properties;
userSet_properties.SetString("userName", "test");
//上传用户属性
te.user_set(accountId, distincId, userSet_properties);
# 四、最佳实践
以下示例代码包含以上所有操作,我们推荐按照如下步骤使用:
// 导入头文件(每个平台以及IDE的路径不一样,自行适合调整)
#include "cpp/include/ThinkingAnalyticsAPI.h"
string LOG_DIRECTORY = "../trackLog";
TaSDK::LoggerConsumer::Config config = TaSDK::LoggerConsumer::Config(LOG_DIRECTORY);
TaSDK::LoggerConsumer logConsumer = TaSDK::LoggerConsumer(config);
TaSDK::ThinkingDataAnalytics te = TaSDK::ThinkingDataAnalytics(logConsumer);
//上传事件
TaSDK::PropertiesNode event_properties;
event_properties.SetString("name1", "XZ_debug");;
event_properties.SetNumber("test_number_int", 3);
event_properties.SetBool("test_bool", true);
te.track(accountId, distincId, eventName, event_properties);
//上传用户属性
TaSDK::PropertiesNode userSet_properties;
userSet_properties.SetString("userName", "test");
te.user_set(accountId, distincId, userSet_properties);
// 调用flush接口数据会立即写入文件,生产环境注意避免频繁调用flush引发IO或网络开销问题
// 一般情况不需要手动调用
te.flush();