OGeek|极客世界-中国程序员成长平台

标题: ios - 从 C 定义 IOS 日志 [打印本页]

作者: 菜鸟教程小白    时间: 2022-12-12 18:32
标题: ios - 从 C 定义 IOS 日志

如何从 C 代码定义 Apple 的 NSLOG 打印? 对于Android,它会是

#if _ANDROID__
#   include <android/log.h>
#   define LOGFUNC(level, fmt, args) __android_log_vprint(level, "andorid", fmt, args)

但是如何使用 Apple 和 NSLOG 呢?

我知道我可以做类似的事情

#elif __APPLE__
#    define LOGFUNC(level, fmt, args) vprintf(fmt, args)

但我没有在设备日志中看到日志。



Best Answer-推荐答案


您可以提供一个实现为 Objective-C 的 C-stub 并仅为 OSX/iOS 编译它,为 Android、Windows 等提供等效项。这就是我在编写跨平台代码时通常会做的事情。

Log.h:

#pragma once

#ifdef __cplusplus
extern "C" {
#endif

extern void logMsg(const char *fmt, ...);

#ifdef __cplusplus
}
#endif

AppleLog.m:

#import <Foundation/Foundation.h>
#import "Log.h"

void logMsg(const char *fmt, ...)
{
    va_list va;
    va_start(va, fmt);
    NSString *message = [[NSString alloc] initWithFormat(fmt) arguments:va];
    va_end(va);

    NSLog(@"%@", message);
}

您还可以以几乎相同的方式为 getHomeDirectory()getTempDirectory() 等提供特定于平台的代码。

关于ios - 从 C 定义 IOS 日志,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35345224/






欢迎光临 OGeek|极客世界-中国程序员成长平台 (http://sqlite.in/) Powered by Discuz! X3.4