服务器之家

服务器之家 > 正文

iOS中解决Xcode 8控制台乱码的方式

时间:2021-02-05 15:30     来源/作者:强哥来简述

下面是之前大家会用的解决控制台log输出的方式

xcode8里边 edit scheme-> run -> arguments, 在environment variables里边添加 os_activity_mode = disable 环境变量 ,这个相信大家都会.

iOS中解决Xcode 8控制台乱码的方式

使用改变xcode系统模板的方式

先介绍几个c函数

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/**
 *getenv(取得环境变量内容)
 *定义函数 char * getenv(const char *name);
 *函数说明 getenv()用来取得参数name环境变量的内容。
 *参数说明
 *name为环境变量的名称,如果该变量存在则会返回指向该内容的指针。
 *环境变量的格式为name=value。
 *返回值:执行成功则返回指向该内容的指针,找不到符合的环境变量名称则返回null。
 */
- (void)getenv_test:(char *)env_name
{
  if(getenv(env_name))
  {
    printf("%s's value = %s",env_name,getenv(env_name));
  }
}
 
/**
 *putenv(改变或增加环境变量)
 *定义函数 int putenv(const char * string);
 *函数说明:putenv()用来改变或增加环境变量的内容。
 *参数
 *string的格式为name = value,
 *如果该环境变量原先存在,则变量内 容会依参数string改变,否则此参数内容会成为新的环境变量。
 *返回值:执行成功则返回0,有错误发生则返回-1。
 */
- (void)putenv_test
{
  char *env_name = "test_two";
  if(putenv(env_name) == 0)
  {
    printf("%s = %d",env_name,putenv("test_two = two"));
  }
 
}
 
/**
 *unsetenv(移除环境变量)
 *定义函数 unsetenv(const char *string);
 *函数说明:unsetenv()用来改变或增加环境变量的内容。
 *参数
 *string为环境变量的名称,
 *如果该环境变量原先存在,则移除该环境变量。
 *返回值:执行成功则返回0,有错误发生则返回-1。
 */
- (void)unsetenv_test
{
  char *env_name = "test_one";
  if(unsetenv(env_name) == 0)
  {
    printf("%s is unseted = %s",env_name,unsetenv(env_name) == 0 ? "yes" : "no");
  }
}
/**
setenv(改变或增加环境变量)
 *定义函数 int setenv(const char *name,const char * value,int overwrite);
 *函数说明 setenv()用来改变或增加环境变量的内容。
 *参数 name为环境变量名称字符串。
 *参数 value则为变量内容。
 *参数 overwrite用来决定是否要改变已存在的环境变量。
 如果overwrite不为0,则改变环境变量原有内容,原有内容会被改为参数value所指的变量内容。
 如果overwrite为0,且该环境变量已有内容,则参数value会被忽略。
 *返回值 执行成功则返回0,有错误发生时返回-1
*/
- (void)setenv_test
{
  char *env_name = "test_one";
  char *env_value = "ooops";
  if(setenv(env_name,env_value,1) == 0)
  {
    printf("%s is seted = %s",env_name,setenv(env_name,env_value,1) == 0 ? "success" : "failed");
  }
}

我们要修改的模板如下的路径中
/applications/xcode.app/contents/developer/platforms/iphoneos.platform/developer/
library/xcode/templates/project\ templates/ios/application/cocoa\ touch\ application\ base.xctemplate

iOS中解决Xcode 8控制台乱码的方式

打开文件,在文件中搜索如下代码

?
1
2
3
4
5
<key>main.m:main:uiapplicationmain</key>
            <string>@autoreleasepool {
  return uiapplicationmain(argc, argv, nil, nsstringfromclass([appdelegate class]));
}
</string>

将其改为

?
1
2
3
4
5
6
7
8
<key>main.m:main:uiapplicationmain</key>
            <string>@autoreleasepool {
  /*
   * 此行代码是增加的代码
   */
  setenv("os_activity_mode", "disable", 1);
  return uiapplicationmain(argc, argv, nil, nsstringfromclass([appdelegate class]));
}

其目的是为了,在创建的xcode项目的入口文件中增加添加环境变量的操作

效果如下

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
//
// main.m
// environment_variable
//
#import <uikit/uikit.h>
#import "appdelegate.h"
 
int main(int argc, char * argv[])
{
  @autoreleasepool
{
    setenv("os_activity_mode", "disable", 1);
    return uiapplicationmain(argc, argv, nil, nsstringfromclass([appdelegate class]));
  }
}

总结

以上就是这篇文章的全部内容了,至此解决xcode8创建新项目,控制台会出现奇葩log的小缺陷!希望能对各位遇到这个问题的朋友们能有所帮助,如果有问题大家可以留言交流。

标签:

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
Intellij idea2020永久破解,亲测可用!!!
Intellij idea2020永久破解,亲测可用!!! 2020-07-29
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
返回顶部