Steam API调试

时间:2018-04-22 10:43:21   收藏:0   阅读:1218

概览

经过这些年,Steam 已经成长为一款大型应用程序,提供多款调试用单独模块及方法。本文将尽量向您呈现这些模块与方法,帮助您充分利用 Steam 与 Steamworks,减少烦恼。

Steam 会自动将数个调试结果输出至日志文件夹,其他结果需通过 Steam 命令行参数 或 console_commands 启用。

ISteamUtils::SetWarningMessageHook 可让 Steamworks 应用程序注册一种函数,从而在出错时使得 Steamworks API 将开发人员可读的错误信息发送至应用程序。大多数的 Stem API 都使用该函数,因此请记得将此连接,方便在出错时进行检查。

Steam 命令行参数

Steam 使用命令行参数来提供开发者详情。

Steam 控制台命令

除额外输出错误报告或错误日志,Steam 控制台还可用于发送令命至 Steam 客户端或服务器。以下为调试时可派上用场的一些命令:

Steamworks API 记录

(在 Steam 控制台输入)log_ipc 命令会将对 Steam 客户端内部接口所进行的全部 IPC 调用进行转储。该命令使用筛选器参数,可为您想监控的接口或进程名称。请注意所提供的名称不总是与 ISteam*版 1:1 匹配,但通常非常相近。可选择指定“counts”或“verbose”,默认为“counts”。

默认流通常如下所示:

00000009 my_exe_name.exe:05 > IClientUser::GetSteamID( ) = [U:2:172006], 00000009 my_exe_name.exe:05 > IClientUser::BLoggedOn( ) = 1, 00000009 my_exe_name.exe:05 > IClientNetworking::IsP2PPacketAvailable( 0,) = 0,0, 00000009 my_exe_name.exe:05 > IClientNetworking::IsP2PPacketAvailable( 1,) = 0,0, 00000009 my_exe_name.exe:05 > IClientFriends::GetPersonaName( ) = "user", 00000009 my_exe_name.exe:05 > IClientUser::GetSteamID( ) = [U:2:123456],

监控特定接口

如您想跟踪特定问题,请在 log_ipc 中筛选特定接口。

如:log_ipc IClientUser

输出示例:

00000009 my_exe_name.exe:05 > IClientUser::GetSteamID( ) = [U:2:172006], 00000009 my_exe_name.exe:05 > IClientUser::BLoggedOn( ) = 1, 00000009 my_exe_name.exe:05 > IClientUser::GetSteamID( ) = [U:2:123456],

IPC报告

在 Steam 客户端中,通过log_ipc可取得汇总报告。

您可以在汇总报告中快速阅览 IPC 调用的摘要。下方示例显示调用 GetSteamID/BLoggedOn/GetPersonaNam过于频繁。报告会于停用或重新开始记录时输出,因此如想获取报告,请按照以下步骤进行:


输出示例:

Calls over the last 42144 milliseconds: Process MethodCalls First Last -------------------- ---------------------------------------- ---------- ---------- ------- my_exe_name.exe IClientNetworking::IsP2PPacketAvailable 15272 9 42145 my_exe_name.exe IClientUser::GetSteamID 42652 9 42145 my_exe_name.exe IClientUser::BLoggedOn42652 9 42145 my_exe_name.exe IClientFriends::GetPersonaName38209 42145 my_exe_name.exe IClientUser::RequestEncryptedAppTicket2 21032441 my_exe_name.exe IClientUtils::GetAPICallResult2 21252441 my_exe_name.exe IClientUser::GetEncryptedAppTicket1 21362136

IPC 日志输出

完整的 IPC 日志将输出至您的 Steam 安装目录:logs\\ipc_SteamClient.log

评论(0
© 2014 mamicode.com 版权所有 京ICP备13008772号-2  联系我们:gaon5@hotmail.com
迷上了代码!