[英]static bool defined in header works for one file only, why?
我是Objective-C的新手
我尝试集成asl_log
。 由于某些原因,静态布尔在其他文件中始终NO
值。
我创建了带有内容的标头MyLogger.h
:
#import <Foundation/Foundation.h>
#import <asl.h>
static bool gLoggingEnabled = NO;
#define __AF_MAKE_LOG_FUNCTION(LEVEL, NAME) \
static inline void NAME(NSString *format, ...)\
{ \
if (!gLoggingEnabled) return; \
va_list arg_list; \
va_start(arg_list, format); \
NSString *formattedString = [[NSString alloc] initWithFormat:format arguments:arg_list]; \
asl_add_log_file(NULL, STDERR_FILENO); \
asl_log(NULL, NULL, (LEVEL), "Prog_ASL: %s", [formattedString UTF8String]); \
va_end(arg_list); \
}
__AF_MAKE_LOG_FUNCTION(ASL_LEVEL_DEBUG, AFLogDebug)
#undef __AF_MAKE_LOG_FUNCTION
您可以看到我将static bool gLoggingEnabled
用作开关。
在主项目文件中,我执行以下操作:
#import "AFLogger.h"
// ...
gLoggingEnabled = YES;
if (gLoggingEnabled) {
asl_add_log_file(NULL, STDERR_FILENO);
//set log level
asl_set_filter(NULL, ASL_FILTER_MASK_UPTO(ASL_LEVEL_DEBUG));
} else {
asl_remove_log_file(NULL, STDERR_FILENO);
}
AFLogDebug(@"flag is %@", gLoggingEnabled ? @"Yes" : @"No");
// -> flag is Yes
但是,它仅在一个文件中起作用。
我还有其他.m
文件:
#import "AFLogger.h"
//...
NSLog(@"flag is %@", gLoggingEnabled ? @"Yes" : @"No");
// -> flag is No
// AFLogDebug prints nothing
为什么static bool gLoggingEnabled
在其他文件中No
值
如何解决?
[编辑]
我想避免使用extern
这是static
因此导入MyLogger.h
每个.m文件都将获得其自己的gLoggingEnabled
变量副本。
如果您想要单个应用范围的变量,则需要更改2项内容。
在MyLogger.h
您需要将static
更改为extern
:
extern bool gLoggingEnabled;
在MyLogger.m
您需要添加:
bool gLoggingEnabled = NO;
该声明与extern
配对。 这是应用程序范围的全局变量。
然后,在任何文件中,您都可以更改其值:
gLoggingEnabled = YES; // or NO as needed
最后一行将更改整个应用程序(任何包含MyLogger.h
文件)的值。
您所拥有的是变量的定义。 您要的是声明。 不仅如此, static
修饰符还将其可见性限制在其定义的编译单元中。实质上,每个.c
或.m
文件都有其自己的gLoggingEnabled
副本,只有它可以看到。
您需要做的是在一个.c
或.m
文件中创建一个非静态文件作用域变量
bool gLoggingEnabled = false; // Note, using C11 bool definitions
然后,您在标题中添加一个外部声明。 这就像对编译器的承诺,即您可能尚未在当前编译单元中定义变量的存储,但是将在链接时完成。
extern bool gLoggingEnabled;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.