首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

iOS启动优化~~~二进制重排

正好看到抖音的启动优化文案----二进制重排,顺便就做个记录。 1 项目配置 1.1 开启 Write Liink Map File ?...那么我们怎么处理来达到项目启动优化呢?...2 理论原理 2.1 缺页中断 App启动时会将对应的符号加载如内存,iOS中默认一次按照4k空间加载符号文件,假如一次无法加载完成启动需要的资源符号,那么就会出现缺失,需要加载更多page,这个重新寻址加载是相对耗时的...假如将分散的符号按照App的启动顺序需要按需排列,那么就可减少启动耗时。 ? 未分配前 ?...项目编译后的符号文件 对比我们的收集到的首屏启动完成后的符号与编译项目符号一致,从而通过减少缺页中断达到优化启动的目的

64450
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    启动优化(二)——二进制重排

    今天要研究的,就是通过一项技术来减少启动时的pageFault,进而缩减启动时间,这个技术就是二进制重排。...二进制重排步骤初体验 上面我们了解了如何去测量启动阶段pageFault的次数,接下来就来初步体验一下二进制重排。...这就是二进制重排的基本步骤,是不是很简单! 实际上,二进制重排并不难,一个Order文件外加一个配置就搞定,真正的难点在于去找到启动时刻的符号,也就是说,你需要知道要将哪些符号排列到前面去。...Hook一切的终极武器——Clang插桩 上面说到,二进制重排最难最核心的一点就是如何去拿到启动阶段的各个符号。 现在大家考虑一个问题,如何去HookOC中所有方法的调用呢?...如果你的项目代码已经十分优雅了,很难再在代码层面优化启动时间了,那么通过二进制重排,你大概还能优化10%左右。

    1.8K51

    iOS 启动优化--二进制重排

    1、二进制重排原理 当进程在访问虚拟内存时,如果对应的物理内存不存在,会触发缺页异常(pagefault),由于在启动的时候需要调用的方法存在不同类中,而每个page的大小是固定的,这就导致启动时需要加载的...page会更多,我们可以通过手动排列符号,将启动时刻需要的方法排列在一起,减少缺页异常 二进制重排原理 查看没有优化前的方法编译顺序 自定义demo @implementation ViewController...Link Map LinkMap是iOS编译过程的中间产物,记录了二进制文件的布局,通过在Xcode的Build Setting中设置Write Link Map File = YES开启,主要包含下面三个部分...Setting --> Order File中设置自定义的.order后缀的文件路径,将需要重排的符号按顺序写在里面,当Xcode编译时会按照.order文件中的符号顺序加载,我们可以通过下面几种方法获得APP启动时的运行函数...,在项目中新增一个方法、block、c++时stop对应会加0x4,属性则会多0x12 __sanitizer_cov_trace_pc_guard (uint32_t *guard)方法,捕获所有启动时刻的符号

    1.3K60

    MySQL 使用mysql二进制方式连接

    使用mysql二进制方式连接 您可以使用MySQL二进制方式进入到mysql命令提示符下来连接MySQL数据库。...实例 以下是从命令行中连接mysql服务器的简单实例: [root@host]# mysql -u root -p Enter password:****** 在登录成功后会出现 mysql> 命令提示窗口...在以上实例中,我们使用了root用户登录到mysql服务器,当然你也可以使用其他mysql用户登录。 如果用户权限足够,任何用户都可以在mysql的命令提示窗口中进行SQL操作。...规定 MySQL 用户名。 password 可选。规定 MySQL 密码。 dbname 可选。规定默认使用的数据库。 port 可选。规定尝试连接到 MySQL 服务器的端口号。...实例 你可以尝试以下实例来连接到你的 MySQL 服务器: 连接 MySQL <?

    1.5K00

    linux命令mysql启动,linux下启动mysql的命令

    linux下启动mysql的命令 一、总结一下: 1.linux下启动mysql的命令: mysqladmin start /ect/init.d/mysql start (前面为mysql的安装路径)...mysqladmin shutdown /ect/init.d/mysql shutdown (前面为mysql的安装路径) 4.连接本机上的mysql: 进入目录mysql\bin,再键入命令mysql...的编码格式: 启动mysql的时候,mysqld_safe命令行加入 –default-character-set=gbk 如果要改变某个库的编码格式:在mysql提示符后输入命令 alter database...这样才有机会自己填充Command Code,Identi …… 摘要 我们在这里讨论的是对嵌入式linux系统的启动过程的输出信息的注释,通过我们的讨论,大家会对嵌入式linux启动过程中出现的、以前感觉熟悉的...嵌入式linux的启动信息是一个很值得我们去好好研究的东西,它能将一幅缩影图呈现在我� …… Linux内核源码分析-链表代码分析 分析人:余旭 分析时间:2005年11月17日星期四 11:40:10

    20.8K10

    mysql启动命令 linux命令,linux下mysql 启动命令

    命令去找/etc/init.d下的相关的mysql脚本去执行启动、关闭动作。...’t connect to local MySQL server through socket ‘/tmp/my … Linux下mysql启动失败 原因:强制重启服务器之后,发现mysql启动 失败...解决方法:强制清空 报错路径下的tmp文件,清空之后在tmp下面新建一个文件夹,文件夹的名字在你清空tmp之后启动mysql系统会给你提示 欧克,完 … linux下mysql启动出错 1.刚安装完就启动出错...… linux 下mysql启动 、调试、排错 Linux 下 MySQL 启动与关闭 说明 一.启动 1.1 MySQL 进程 可以用ps 命令查看进程: [root@rac2 ~]# ps -...ef|grep mysql root 21 … linux下如何启动/停止/重启mysql: 一.启动方式1.使用linux命令service 启动:service mysqld

    18.2K20

    关于mysql binlog二进制

    binlog 在mysql中,当发生数据变更时,都会将变更数据的语句,通过二进制形式,存储到binlog日志文件中. 通过binlog文件,你可以查看mysql一段时间内,对数据库的所有改动....binlog常用配置参数 [binlog] log_bin = mysql-bin # {on | off | base_name}指定是否启用记录二进制日志或者指定一个日志路径 sql_log_bin... = on # { on | off }    指定是否启用记录二进制日志 expire_logs_days=7  #  指定自动删除二进制日志的时间,即日志过期时间 log_bin_index= /usr... }    指定二进制日志基于什么模式记录 max_binlog_size = 100M #   指定二进制日志文件最大值 binlog_cache_size = 4M #   指定事务日志缓存区大小...binlog模式 在上面我们讲到了,mysql发生数据变更后,才会将变更的语句,通过二进制形式存储,而通过存储语句的方式,mysql将其分为了3种方式.

    1.1K20

    MySQL 压缩二进制日志

    通常,二进制日志压缩效果很好,所以人们一直希望有一个功能可以在MySQL使用二进制日志时对其进行压缩。从MySQL8.0.20开始,现在可以了。我将在这篇博文中看看这个新功能。...这个例子中,MySQL花费了6.21秒来压缩二进制日志,每个事务平均不到400微秒。相比,二进制日志文件执行I/O花费了4.8分钟。...为了进行比较,我还手工压缩系列测试的中未压缩的二进制日志,以查看最佳压缩率(与MySQL使用的每次事务压缩不同)。除了给定测试所需的设置外,测试都是使用默认配置执行的。...当比较MySQL压缩的二进制日志和使用zstd手工压缩的二进制日志时,批量负载的文件大小大致相同,这也反映出对于大事务,按每个事务进行压缩等同于压缩整个文件。...二进制日志大小与压缩级别的关系 可以看出,无论MySQL中使用的压缩级别如何,文件大小基本上没有差异,而对于zstd,随着压缩级别的增加,文件大小如预期一样减小。

    1.5K81
    领券