如何从 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)
但我没有在设备日志中看到日志。
您可以提供一个实现为 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/
欢迎光临 OStack程序员社区-中国程序员成长平台 (https://ostack.cn/) | Powered by Discuz! X3.4 |