Unity 打印log时,使用StringBuilder比String好,String会产生垃圾,使用StringBuilder能避免String产生垃圾

using System;

using System.Diagnostics;

using System.Reflection;

using System.Text;

using UnityEngine;

public class Log

{

// private static StringBuilder _builder = new StringBuilder(1024);

public static void I(string tag, string format, params object[] args)

{

UnityEngine.Debug.Log(buildString(tag, format, args));

}

复制代码
public static void W(string tag, string format, params object[] args)
{
    UnityEngine.Debug.LogWarning(buildString(tag, format, args));
}

public static void E(string tag, string format, params object[] args)
{
    UnityEngine.Debug.LogError(buildString(tag, format, args));
}

private static StringBuilder buildString(string tag, string format, params object[] args)
{
    StringBuilder _builder = new StringBuilder(1024);
    _builder.Clear();
    _builder.Append("Snake_");
    _builder.Append(tag);
    _builder.Append(": ");
    if (args != null && args.Length > 0)
    {
        _builder.AppendFormat(format, args);
    }
    else
    {
        _builder.Append(format);
    }

    return _builder;
}

}

namespace Banma.Unity.Log

{

public static class Xlog

{

private const string c_str_project_name = "Snake";

复制代码
    public static void Log(this MonoBehaviour mono, string _str_log, bool _b_is_error = false)
    {
        // 获取传入实例所属类的名称
        string className = mono.GetType().Name;

        // 获取当前执行的函数的名称
        string methodName = new System.Diagnostics.StackTrace().GetFrame(1).GetMethod().Name;
        if (_b_is_error)
        {
            UnityEngine.Debug.LogError($"【{c_str_project_name}】/【{className}】/【{methodName}】:){_str_log}");
        }
        else
        {
            UnityEngine.Debug.Log($"【{c_str_project_name}】/【{className}】/【{methodName}】:){_str_log}");
        }
    }

    public static void Log(string _str_log, bool _b_is_error = false)
    {
        StackTrace stackTrace = new StackTrace();
        StackFrame[] stackFrames = stackTrace.GetFrames();

        if (stackFrames.Length >= 2)
        {
            // 获取调用堆栈的第一个方法(当前方法是第二个)
            StackFrame callerFrame = stackFrames[1];
            MethodBase callerMethod = callerFrame.GetMethod();
            Type callerType = callerMethod.DeclaringType;

            if (_b_is_error)
            {
                // 打印调用类和函数的信息
                UnityEngine.Debug.LogError($"【Snake】/【{callerType.Name} 】/【{callerMethod.Name}】:){_str_log}");
            }
            else
            {
                // 打印调用类和函数的信息
                UnityEngine.Debug.Log($"【Snake】/【{callerType.Name} 】/【{callerMethod.Name}】:){_str_log}");
            }
        }
    }
}

}

相关推荐
枯萎穿心攻击2 小时前
响应式编程入门教程第二节:构建 ObservableProperty<T> — 封装 ReactiveProperty 的高级用法
开发语言·unity·c#·游戏引擎
X_StarX10 小时前
【Unity笔记02】订阅事件-自动开门
笔记·学习·unity·游戏引擎·游戏开发·大学生
霸王•吕布14 小时前
游戏引擎中顶点着色&像素着色
游戏引擎·顶点着色器·像素着色器·顶点颜色·顶点uv·顶点法向
Thomas_YXQ17 小时前
Unity URP法线贴图实现教程
开发语言·unity·性能优化·游戏引擎·unity3d·贴图·单一职责原则
徐子竣1 天前
[学习记录]Unity-Shader-几何着色器
unity·游戏引擎·着色器
EQ-雪梨蛋花汤1 天前
【Part 3 Unity VR眼镜端播放器开发与优化】第四节|高分辨率VR全景视频播放性能优化
unity·音视频·vr
与火星的孩子对话1 天前
Unity进阶课程【六】Android、ios、Pad 终端设备打包局域网IP调试、USB调试、性能检测、控制台打印日志等、C#
android·unity·ios·c#·ip
幻世界1 天前
【Unity智能模型系列】Unity + MediaPipe + Sentis + ArcFace模型:构建高效人脸识别比对系统
unity·游戏引擎
漫游者Nova2 天前
虚幻引擎Unreal Engine5恐怖游戏设计制作教程,从入门到精通从零开始完整项目开发实战详细讲解中英字幕
ue5·游戏引擎·虚幻·游戏开发完整教程·恐怖游戏开发
死也不注释2 天前
【Unity 编辑器工具开发:GUILayout 与 EditorGUILayout 对比分析】
unity·编辑器·游戏引擎