如何从 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-推荐答案 strong>
您可以提供一个实现为 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/
|