- Android显示系统(09)- SurfaceFlinger的使用
红米饭配南瓜汤
Android显示系统Androidandroid媒体音视频
Android显示系统(01)-架构分析Android显示系统(02)-OpenGLES-概述Android显示系统(03)-OpenGLES-GLSurfaceView的使用Android显示系统(04)-OpenGLES-Shader绘制三角形Android显示系统(05)-OpenGLES-Shader绘制三角形(使用glsl文件)Android显示系统(06)-OpenGLES-VBO和E
- android display 笔记(八)WMS与SurfaceFlinger交互
那天的烟花雨
android笔记交互
在Android系统中由WindowManagerService也就是WMS承担窗口位置的管理。WMSWMS是一个系统服务,运行在systemserver进程,系统启动便开始启动该服务/frameworks/base/services/java/com/android/server/SystemServer.java//Startservices.938try{939t.traceBegin("S
- Android-Fk:BufferQueue学习整理
马小藤
一.BufferQueue概述BufferQueue可以理解为一个生产者-消费者”模型,对GraphicBuffer管理的一种机制。需注意的是,可以将BufferQueue当作是一个算法结构,并不是只有Surfaceflinger会使用到,其他进程只要有GraphicBuffer的消费地方都会使用到。二.BufferQueue结构在这里插入图片描述一般是在消费者进程调用BufferQueue的cr
- Android下SF合成流程重学习之GPU合成
IT先森
Androidgraphic深入分析androidGPU合成SurfaceFlinger纹理
Android下SF合成流程重学习之GPU合成引言SurfaceFlinger中的图层选择GPU合成(CLIENT合成方式)时,会把待合成的图层Layers通过renderengine(SkiaGLRenderEngine)绘制到一块GraphicBuffer中,然后把这块GraphicBuffer图形缓存通过调用setClientTarget传递给HWC模块,HWC进一步处理后把这个Gr
- Android下SF合成流程重学习之Refresh流程
IT先森
Androidgraphic深入分析androidSurfaceFlingerRefresh合成
Android下SF合成流程重学习之Refresh流程引言在前面初步分析完成了Android下SF合成流程重学习之Invalidate流程,我们接下来继续下面的分析。当有事务的更新或者有Buffer的更新便会触发后面刷新的流程,即Refresh流程!一.onMessageRefresh文件:frameworks/native/services/surfaceflinger/Surf
- Android画面显示流程分析(4)
长安想胖
Android显示框架androidjava开发语言
7.画面更新流程在我们前面几个章节的讨论中,我们从最底层的显示硬件,SOC和DDIC的接口,linux和Userspace的图形接口以及APP与SurfaceFlinger,HWCservice三者的关系,了解了帧数据流动所经过的关键节点,并重点讨论了帧buffer是如何管理的,以及在流动过程中是如何做到同步的。接下来我们将从应用侧角度来从上到下看一下应用所绘制的画面是如何使用到我们上面所设计的流
- SurfaceFlinger中Layer的合成 - 安卓R
SSSxCCC
安卓Frameworkandroid安卓
1等待任意Layer的buffer准备好当BufferQueueLayer有新的buffer到来时,会调用之前在SurfaceFlinger中Layer的创建时注册的ContentsChangedListener的onFrameAvailable方法(frameworks/native/services/surfaceflinger/BufferQueueLayer.cpp):voidBuffer
- Android 12 图形显示系统 -- 系列好文
向晚流年
Android学习android
请关注公众号:Android元宇宙获得最新的状态,阅读最新文章!图形显示系列Android12(S)图像显示系统-开篇Android12(S)图像显示系统-基本概念(一)Android12(S)图像显示系统-示例应用(二)Android12(S)图像显示系统-应用建立和SurfaceFlinger的沟通桥梁(三)Android12(S)图像显示系统-SurfaceFlinger的启动和消息队列处理
- Binder之获取服务
lbtrace
以获取SurfaceFlinger服务为例说明客户端向ServiceManager查询SurfaceFlinger服务的过程大部分流程在服务注册的过程中已经分析过,下面从ServiceManager收到请求后开始看。intbinder_parse(structbinder_state*bs,structbinder_io*bio,uintptr_tptr,size_tsize,binder_han
- SF相关1111
写完就会了
android
AndroidQ图形系统(11)UI刷新,SurfaceFlinger,Vsync机制总结_androidviewrootimplsurfaceflingerhw-CSDN博客
- Android Display ID 对应关系
april_12345
androidandroiddisplay
目录四个基本ID模块、类和id之间对应关系图Android中对display操作时,从APP,DisplayManagerService,SurfaceFlinger到HWC通信都需要用到displayid,但是,实际上,每个模块的displayid并不一致,他们之间有一定的对应关系。本文梳理各模块间displayid对应关系。四个基本IDDisplayID:DisplayManagerServi
- Android14 SurfaceFlinger的启动
jinyanmei_335
开发语言android
由init进程启动,从main函数开始主要是初始化了Surflinger,并启动了线程79intmain(int,char**){80signal(SIGPIPE,SIG_IGN);8182hardware::configureRpcThreadpool(1/*maxThreads*/,83false/*callerWillJoin*/);//启动图形服务8485startGraphicsAllo
- Android14 SurfaceFlinger的合成
jinyanmei_335
java前端javascript
frameworks/native/libs/gui/BufferQueueProducer.cpp831status_tBufferQueueProducer::queueBuffer(intslot,832constQueueBufferInput&input,QueueBufferOutput*output){1061addAndGetFrameTimestamps(&newFrameEve
- Android14 SurfaceFlinger-BLASTBufferQueue的创建
jinyanmei_335
java开发语言
如果mWindowSession.relayout之后,mSurfaceControl将会变成有效的,此时会判断blast是否开启(blast特性时12新推出的,它默认开启的),所以进入到getOrCreateBLASTSurface,在这里将会生成一个BLASTBufferQueue,而原来的mSurface.copyFrom(mSurfaceControl)privateintrelayout
- 2020-10-09 SurfaceFlinger 卡死问题分析:
胡一股
1:使用高的地图进行CarPlay投屏时候,出现整个系统卡死.2:log"Binder:880_C"prio=5tid=103Native|group="main"sCount=1dsCount=0flags=1obj=0x139c2cc0self=0x7ce0ec5800|sysTid=2996nice=-8cgrp=defaultsched=0/0handle=0x7cbc06d4f0|sta
- SurfaceFlinger学习2
小白好了
LayerclassLayer:publicvirtualRefBase,compositionengine::LayerFE{mutableboolcontentDirty{false};RegionsurfaceDamageRegion;//Layerserialnumber.Thisgiveslayersanexplicitordering,sowe//haveastablesortorde
- android cpu调度策略_android进程、线程调度简介
weixin_39640417
androidcpu调度策略
引言1、Audio、SurfaceFlinger等相关实时任务是如何调度的?2、怎样保证app的mainthread、renderthread等高优先级线程不会被其他低优先级的线程打断?3、app退到后台时,怎么限制其对cpu资源的占用?4、android是怎样支持ARM的big.LITTLE架构的?本文接下来将回答这几个问题。linux的调度策略android基于linux内核,android系
- Android 9.0 系统禁用截屏和录屏功能
安卓兼职framework应用工程师
android9.0Rom定制化系统开发讲解系列androidframework禁止截屏截屏系统禁止app截屏
1.前言在9.0的系统rom产品开发中,在对于一些产品开发需求中,对系统截屏和录屏功能要求去掉这些功能,不让用户截屏和录屏保护一个app的资源,所以就需要在系统中做限制不让截屏录屏,接下来具体实现相关功能2.系统禁用截屏和录屏功能的核心类frameworks\native\services\surfaceflinger\Layer.cppframeworks\base\core\java\andr
- HAL/SurfaceFlinger专题之HWC和GPU合成部分更新通知
千里马学框架
surfaceflinger车载系统安卓framework开发halperfettosurfaceflingerhwcGPU合成
背景hi,粉丝朋友们:hal/surfaceflinger/perfetto专题,马哥经过若干天的努力,终于把sf最重要合成部分搞定,上传平台审核完成。课程部分的截图花絮:目前完整课表list1-start-intruduct.mkv课程介绍hal/hal-1-s.mp4-hal发展总体介绍1hal/hal-2.mkv-hal发展总体介绍2hal/hal-3.mkv--经典hal深入讲解1hal/
- Android S: SurfaceFlinger指Surface.java的用途
月山知了
AndroidFrameworkAndroidandroidjavaandroid
Handleontoarawbufferthatisbeingmanagedbythescreencompositor.Surface是一个句柄,该句柄是指向由屏幕合成器管理的原始缓冲。ASurfaceisgenerallycreatedbyorfromaconsumerofimagebuffers(suchasaSurface通常被图像缓冲区的消费者创建或来自于其。{@linkandroid.g
- SurfaceFlinger的commit/handleTransaction分析
千里马学框架
surfaceflingerandroid系统车载系统自由窗口surfaceflingerhalvsyncSurfaceControl
整体背景介绍hi,粉丝朋友们:大家好!本节我们来讲解一下SurfaceFlinger主要合成工作的第一个阶段任务commit一般SurfaceFlinger端的合成工作主要有两个1.commit主要就是处理app端发起的一系列transaction的事务请求,需要对这些请求进行识别是否当前帧处理,处理过程就是把事务中的属性取出,然后更新到Layer中,偶buffer更新的还需要进行相关的latch
- android系统中查看内存信息
辉色投像
adbshellcatproc/meminfo:看下大致内存使用情况(free+buffers+cached)proc/meminfo机器的内存使用信息/proc/pid/mapspid为进程号,显示当前进程所占用的虚拟地址。/proc/pid/statm进程所占用的内存df查看存储空间使用情况ps-t|grepsystem_server(或surfaceflinger,servicemanage
- android p图形显示系统,Android图形显示系统——下层显示3:窗口系统
weixin_39597318
androidp图形显示系统
Android之窗口系统要点1.Android窗口系统通过C-S架构和一套Buffer循环机制实现,在保证安全稳定的前提下基本上做到了极致性能(无大块内存拷贝,IPC通信内容最少)。2.SurfaceFlinger创建Layer,将其中的BufferQueueProducer作为IGraphicBufferProducer传给应用侧的Surface,因而构成窗口。3.Surface是皮,Buffe
- 千里马2023年终总结-android framework实战
千里马学框架
Frameworkandroidframework车机车载hal安卓程序员手机年终总结
背景:hi粉丝朋友们:2023年马上就过去了,很多学员朋友也都希望马哥这边写个年终总结,因为这几个月时间都忙于新课程hal+systrace+surfaceflinger专题的开发,差点都忘记了这个事情了,今天特别花时间来写个blog总结记录一下这不平凡的一年。1、2023是疫情结束后第一年,也是各行各业艰难的一年2023年里无论是哪个行业,不仅仅是程序员这个行业,都是非常艰难,基本上就是经济危机
- SurfaceFlinger服务启动与初始化
泡面先生_Jack
SufaceFlinger启动与初始化SurfaceFlinger是一个Native系统服务,开机的时候在init.rc脚本中被启动servicesurfaceflinger/system/bin/surfaceflingerclasscoreusersystemgroupgraphicsdrmrpconrestartrestartzygotewritepid/dev/cpuset/system-
- SurfaceFlinger模块-VSYNC研究
努比亚技术团队
Vsync信号是SurfaceFlinger进程中核心的一块逻辑,我们主要从以下几个方面着手讲解。软件Vsync是怎么实现的,它是如何保持有效性的?systrace中看到的VSYNC信号如何解读,这些脉冲信号是在哪里打印的?为什么VSYNC-sf/VSYNC-app时断时续?SF请求VSYNC-SF信号进行合成的流程是怎样的?“dumpsysSurfaceFlinger--dispsync"命令输
- SurfaceFlinger
Wi1ls努力努力再努力
Android中,在HAL层抽象了Gralloc模块,封装了对帧缓冲区的访问操作。加载Gralloc模块后,获得一个gralloc设备和fb设备。通过gralloc,用户空间申请分配一块图形缓冲区,并且映射到应用程序的地址空间,以便写入想要绘制的内容。随后用户空间程序通过fb设备将绘制好的图形缓冲区渲染到帧缓冲区,即显示屏中。当不需要这一块图形缓冲区时,通过gralloc设备释放,同时解除映射。在
- Android Framework一些问题思考
丶随心
android
一,zygote通信为什么用socket,而不是binder?1,binder通信依赖Servicemanager,socket通信不依赖用户空间进程。zygote与servicemanager,surfaceflinger等都是通过各自init.rc被init创建,时序上无法保证zygote启动时候servicemanager一定加载好了。2,Linux推荐fork一个多线程的进程的。因为如果存
- Hal深入实战/perfetto-systrace实战/SurfaceFlinger合集-安卓framework开发实战开发
千里马学框架
surfaceflingerandroid车载系统安卓framework开发halperfettosystracesurfaceflinger
背景hi,粉丝朋友们:大家好!下面来介绍一下新的framework专题hal+perfetto+surafceflinger,这个专题主要就是分为3大块,但是彼此直接又是相互关联的。比如surfaceflingre模块深入分析需要用到hal相关的模块,比如mapper,hwc等,所以说去分析surfaceflinger就必须要有一定hal基础比较好,还有就是perfetto,大家可能会以为他只是个
- android
梦里花落知多少_9ce8
Androidview的一些认识requestLayout和invalidate的区别为什么ViewGroup的onDraw()方法不执行View的绘制-draw流程详解Android渲染机制——SurfaceFlingerAndroid回炉系列之SurfaceflingerSurfaceView与view区别详解SharePreference原理及跨进程数据共享的问题我Android匿名共享内存
- 关于旗正规则引擎规则中的上传和下载问题
何必如此
文件下载压缩jsp文件上传
文件的上传下载都是数据流的输入输出,大致流程都是一样的。
一、文件打包下载
1.文件写入压缩包
string mainPath="D:\upload\"; 下载路径
string tmpfileName=jar.zip; &n
- 【Spark九十九】Spark Streaming的batch interval时间内的数据流转源码分析
bit1129
Stream
以如下代码为例(SocketInputDStream):
Spark Streaming从Socket读取数据的代码是在SocketReceiver的receive方法中,撇开异常情况不谈(Receiver有重连机制,restart方法,默认情况下在Receiver挂了之后,间隔两秒钟重新建立Socket连接),读取到的数据通过调用store(textRead)方法进行存储。数据
- spark master web ui 端口8080被占用解决方法
daizj
8080端口占用sparkmaster web ui
spark master web ui 默认端口为8080,当系统有其它程序也在使用该接口时,启动master时也不会报错,spark自己会改用其它端口,自动端口号加1,但为了可以控制到指定的端口,我们可以自行设置,修改方法:
1、cd SPARK_HOME/sbin
2、vi start-master.sh
3、定位到下面部分
- oracle_执行计划_谓词信息和数据获取
周凡杨
oracle执行计划
oracle_执行计划_谓词信息和数据获取(上)
一:简要说明
在查看执行计划的信息中,经常会看到两个谓词filter和access,它们的区别是什么,理解了这两个词对我们解读Oracle的执行计划信息会有所帮助。
简单说,执行计划如果显示是access,就表示这个谓词条件的值将会影响数据的访问路径(表还是索引),而filter表示谓词条件的值并不会影响数据访问路径,只起到
- spring中datasource配置
g21121
dataSource
datasource配置有很多种,我介绍的一种是采用c3p0的,它的百科地址是:
http://baike.baidu.com/view/920062.htm
<!-- spring加载资源文件 -->
<bean name="propertiesConfig"
class="org.springframework.b
- web报表工具FineReport使用中遇到的常见报错及解决办法(三)
老A不折腾
finereportFAQ报表软件
这里写点抛砖引玉,希望大家能把自己整理的问题及解决方法晾出来,Mark一下,利人利己。
出现问题先搜一下文档上有没有,再看看度娘有没有,再看看论坛有没有。有报错要看日志。下面简单罗列下常见的问题,大多文档上都有提到的。
1、repeated column width is largerthan paper width:
这个看这段话应该是很好理解的。比如做的模板页面宽度只能放
- mysql 用户管理
墙头上一根草
linuxmysqluser
1.新建用户 //登录MYSQL@>mysql -u root -p@>密码//创建用户mysql> insert into mysql.user(Host,User,Password) values(‘localhost’,'jeecn’,password(‘jeecn’));//刷新系统权限表mysql>flush privileges;这样就创建了一个名为:
- 关于使用Spring导致c3p0数据库死锁问题
aijuans
springSpring 入门Spring 实例Spring3Spring 教程
这个问题我实在是为整个 springsource 的员工蒙羞
如果大家使用 spring 控制事务,使用 Open Session In View 模式,
com.mchange.v2.resourcepool.TimeoutException: A client timed out while waiting to acquire a resource from com.mchange.
- 百度词库联想
annan211
百度
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>RunJS</title&g
- int数据与byte之间的相互转换实现代码
百合不是茶
位移int转bytebyte转int基本数据类型的实现
在BMP文件和文件压缩时需要用到的int与byte转换,现将理解的贴出来;
主要是要理解;位移等概念 http://baihe747.iteye.com/blog/2078029
int转byte;
byte转int;
/**
* 字节转成int,int转成字节
* @author Administrator
*
- 简单模拟实现数据库连接池
bijian1013
javathreadjava多线程简单模拟实现数据库连接池
简单模拟实现数据库连接池
实例1:
package com.bijian.thread;
public class DB {
//private static final int MAX_COUNT = 10;
private static final DB instance = new DB();
private int count = 0;
private i
- 一种基于Weblogic容器的鉴权设计
bijian1013
javaweblogic
服务器对请求的鉴权可以在请求头中加Authorization之类的key,将用户名、密码保存到此key对应的value中,当然对于用户名、密码这种高机密的信息,应该对其进行加砂加密等,最简单的方法如下:
String vuser_id = "weblogic";
String vuse
- 【RPC框架Hessian二】Hessian 对象序列化和反序列化
bit1129
hessian
任何一个对象从一个JVM传输到另一个JVM,都要经过序列化为二进制数据(或者字符串等其他格式,比如JSON),然后在反序列化为Java对象,这最后都是通过二进制的数据在不同的JVM之间传输(一般是通过Socket和二进制的数据传输),本文定义一个比较符合工作中。
1. 定义三个POJO
Person类
package com.tom.hes
- 【Hadoop十四】Hadoop提供的脚本的功能
bit1129
hadoop
1. hadoop-daemon.sh
1.1 启动HDFS
./hadoop-daemon.sh start namenode
./hadoop-daemon.sh start datanode
通过这种逐步启动的方式,比start-all.sh方式少了一个SecondaryNameNode进程,这不影响Hadoop的使用,其实在 Hadoop2.0中,SecondaryNa
- 中国互联网走在“灰度”上
ronin47
管理 灰度
中国互联网走在“灰度”上(转)
文/孕峰
第一次听说灰度这个词,是任正非说新型管理者所需要的素质。第二次听说是来自马化腾。似乎其他人包括马云也用不同的语言说过类似的意思。
灰度这个词所包含的意义和视野是广远的。要理解这个词,可能同样要用“灰度”的心态。灰度的反面,是规规矩矩,清清楚楚,泾渭分明,严谨条理,是决不妥协,不转弯,认死理。黑白分明不是灰度,像彩虹那样
- java-51-输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字。
bylijinnan
java
public class PrintMatrixClockwisely {
/**
* Q51.输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字。
例如:如果输入如下矩阵:
1 2 3 4
5 6 7 8
9
- mongoDB 用户管理
开窍的石头
mongoDB用户管理
1:添加用户
第一次设置用户需要进入admin数据库下设置超级用户(use admin)
db.addUsr({user:'useName',pwd:'111111',roles:[readWrite,dbAdmin]});
第一个参数用户的名字
第二个参数
- [游戏与生活]玩暗黑破坏神3的一些问题
comsci
生活
暗黑破坏神3是有史以来最让人激动的游戏。。。。但是有几个问题需要我们注意
玩这个游戏的时间,每天不要超过一个小时,且每次玩游戏最好在白天
结束游戏之后,最好在太阳下面来晒一下身上的暗黑气息,让自己恢复人的生气
&nb
- java 二维数组如何存入数据库
cuiyadll
java
using System;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Xml;
using System.Xml.Serialization;
using System.IO;
namespace WindowsFormsApplication1
{
- 本地事务和全局事务Local Transaction and Global Transaction(JTA)
darrenzhu
javaspringlocalglobaltransaction
Configuring Spring and JTA without full Java EE
http://spring.io/blog/2011/08/15/configuring-spring-and-jta-without-full-java-ee/
Spring doc -Transaction Management
http://docs.spring.io/spri
- Linux命令之alias - 设置命令的别名,让 Linux 命令更简练
dcj3sjt126com
linuxalias
用途说明
设置命令的别名。在linux系统中如果命令太长又不符合用户的习惯,那么我们可以为它指定一个别名。虽然可以为命令建立“链接”解决长文件名的问 题,但对于带命令行参数的命令,链接就无能为力了。而指定别名则可以解决此类所有问题【1】。常用别名来简化ssh登录【见示例三】,使长命令变短,使常 用的长命令行变短,强制执行命令时询问等。
常用参数
格式:alias
格式:ali
- yii2 restful web服务[格式响应]
dcj3sjt126com
PHPyii2
响应格式
当处理一个 RESTful API 请求时, 一个应用程序通常需要如下步骤 来处理响应格式:
确定可能影响响应格式的各种因素, 例如媒介类型, 语言, 版本, 等等。 这个过程也被称为 content negotiation。
资源对象转换为数组, 如在 Resources 部分中所描述的。 通过 [[yii\rest\Serializer]]
- MongoDB索引调优(2)——[十]
eksliang
mongodbMongoDB索引优化
转载请出自出处:http://eksliang.iteye.com/blog/2178555 一、概述
上一篇文档中也说明了,MongoDB的索引几乎与关系型数据库的索引一模一样,优化关系型数据库的技巧通用适合MongoDB,所有这里只讲MongoDB需要注意的地方 二、索引内嵌文档
可以在嵌套文档的键上建立索引,方式与正常
- 当滑动到顶部和底部时,实现Item的分离效果的ListView
gundumw100
android
拉动ListView,Item之间的间距会变大,释放后恢复原样;
package cn.tangdada.tangbang.widget;
import android.annotation.TargetApi;
import android.content.Context;
import android.content.res.TypedArray;
import andr
- 程序员用HTML5制作的爱心树表白动画
ini
JavaScriptjqueryWebhtml5css
体验效果:http://keleyi.com/keleyi/phtml/html5/31.htmHTML代码如下:
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml"><head><meta charset="UTF-8" >
<ti
- 预装windows 8 系统GPT模式的ThinkPad T440改装64位 windows 7旗舰版
kakajw
ThinkPad预装改装windows 7windows 8
该教程具有普遍参考性,特别适用于联想的机器,其他品牌机器的处理过程也大同小异。
该教程是个人多次尝试和总结的结果,实用性强,推荐给需要的人!
缘由
小弟最近入手笔记本ThinkPad T440,但是特别不能习惯笔记本出厂预装的Windows 8系统,而且厂商自作聪明地预装了一堆没用的应用软件,消耗不少的系统资源(本本的内存为4G,系统启动完成时,物理内存占用比
- Nginx学习笔记
mcj8089
nginx
一、安装nginx 1、在nginx官方网站下载一个包,下载地址是:
http://nginx.org/download/nginx-1.4.2.tar.gz
2、WinSCP(ftp上传工
- mongodb 聚合查询每天论坛链接点击次数
qiaolevip
每天进步一点点学习永无止境mongodb纵观千象
/* 18 */
{
"_id" : ObjectId("5596414cbe4d73a327e50274"),
"msgType" : "text",
"sendTime" : ISODate("2015-07-03T08:01:16.000Z"
- java术语(PO/POJO/VO/BO/DAO/DTO)
Luob.
DAOPOJODTOpoVO BO
PO(persistant object) 持久对象
在o/r 映射的时候出现的概念,如果没有o/r映射,就没有这个概念存在了.通常对应数据模型(数据库),本身还有部分业务逻辑的处理.可以看成是与数据库中的表相映射的java对象.最简单的PO就是对应数据库中某个表中的一条记录,多个记录可以用PO的集合.PO中应该不包含任何对数据库的操作.
VO(value object) 值对象
通
- 算法复杂度
Wuaner
Algorithm
Time Complexity & Big-O:
http://stackoverflow.com/questions/487258/plain-english-explanation-of-big-o
http://bigocheatsheet.com/
http://www.sitepoint.com/time-complexity-algorithms/