定义 IOS 来自 C 的日志
Define IOS Logs From C
如何从 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 存根,并仅为 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()
等提供特定于平台的代码。
如何从 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 存根,并仅为 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()
等提供特定于平台的代码。