thinkphp源码无差别阅读(一)(thinkphp分布式数据库)
wptr33 2025-05-08 06:56 23 浏览
thinkphp源码无差别阅读(一)
thinkphp的framework源码大概165个文件,我们不按照逻辑分析阅读源码,我们一个文件一个文件阅读,阅读完以后有个大概了解,然后在运行逻辑下进行阅读
framework阅读
App.php阅读
- 常量:VERSION-定义框架版本号
- 属性:$appDebug、envName、beginTime、beginRem、namespace、rootPath、thinkPath、appPath、runtimePath、routePath、configExt、initializers、services、initialized、bind
- 构造方法:__construct
- 注册服务:register
- 执行服务:bootService
- 获取服务:getService
- 设置调试模式:debug
- 是否调试模式:isDebug
- 设置应用命名空间:setNamespace
- 获取应用命名空间:getNamespace
- 设置环境变量标识:setEnvName
- 获取框架版本:version
- 获取应用根目录:getRootPath
- 获取应用基础魔力:getBasePath
- 获取当前应用目录:getAppPath
- 设置应用目录:setAppPath
- 获取应用运行目录:getRuntimePath
- 设置应用运行目录:setRuntimePath
- 获取框架核心目录:getThinkPath
- 获取应用配置目录:getConfigPath
- 获取配置后缀:getConfigExt
- 获取用于开启时间:getBeginTime
- 获取应用初始内存占用:getBeginRem
- 加载环境变量:loadEnv
- 初始化应用:initialize
- 是否初始化:initialized
- 加载语言包:loadLangPack
- 引导引用:boot
- 加载应用文件和配置:load
- 调试模式设置:debugModeInit
- 注册应用事件:loadEvent
- 解析应用类名:parseClass
- 是否在命令行下运行:runningInConsole
- 获取应用根目录:getDefaultRootPath
Cache.php阅读
- 属性:namespace
- 获取默认驱动:getDefaultDriver
- 获取缓存配置:getConfig
- 获取驱动配置:getStoreConfirm
- 未知:resolveType
- 未知:resolveConfig
- 连接获取切换缓存:store
- 清空缓存池:clear
- 读取缓存:get
- 写入缓存:set
- 删除缓存:delete
- 读取缓存:getMultiple
- 写入缓存:setMultiple
- 删除缓存:deleteMultiple
- 判断缓存是否存在:has
- 缓存标签:tag
Config.php阅读
- 属性:config、path、ext
- 构造方法:__construct
- 未知:__make
- 加载配置文件:load
- 解析配置文件:parse
- 判断配置是否存在:has
- 获取一级配置:pull
- 获取配置:get
- 设置配置:set
Console.php阅读
- 属性:app、commands、wantHelps、catchExceptions、autoExit、definition、defaultCommand、defaultCommands、startCallbacks
- 构造方法:__construct
- 初始化:initialize
- 构造request:makeRequest
- 添加初始化器:starting
- 清空启动器:flushStartCallbacks
- 设置执行用户:setUser
- 启动:start
- 加载指令:loadCommands
- 未知:call
- 执行当前指令:run
- 执行指令:doRun
- 设置输入参数:setDefinition
- 获取输入参数:getDefinition
- 获取帮助:getHelp
- 是否捕获异常:setCatchException
- 是否自动退出:setAutoExit
- 获取完整版本号:getLongVersion
- 添加指令集:addCommands
- 添加指令:addCommand
- 获取指令:getCommand
- 判断指令是否存在:hasCommand
- 获取所有的命名空间:getNamespaces
- 查找命名空间的名称或缩写:findNamespace
- 查找指令:find
- 获取所有指令:all
- 配置输入输出:configurateIO
- 执行指令:doRunCommand
- 获取指令的基础名称:getCommandName
- 获取默认输入:getDefaultInputDefinition
- 获取建议:getAbbreviationSuggestions
- 返回命名空间部分:extractNamespace
- 查找可替代建议:findAlternatives
- 返回所有命名空间:extractAllNamesapces
Container.php
- 属性:instance、instances、bind、invokeCallback
- 获取当前容器实例:getInstance
- 设置当前容器实例:setInstance
- 注册一个容器对象回调:resolving
- 获取容器中的对象实例:pull
- 获取容器中的对象实例:get
- 绑定类、闭包、对象、接口到容器:bind
- 根据别名获取类真实的名字:getAlias
- 绑定一个类实例到容器:instance
- 判断容器中是否存在类和标识:bound
- 判断容器中是否存在类和标识:has
- 判断容器中是否存在类和标识:exists
- 创建类实例,单例:make
- 删除容器中的对象实例:delete
- 执行函数或者闭包:invokeFunction
- 执行反射类的方法:invokeMethod
- 执行反射类的方法:invokeReflectMethod
- 调用反射执行callable:invoke
- 调用反射,执行类的实例化:invokeClass
- 执行invokeClass回调:invokeAfter
- 绑定参数:bindParams
- 创建工厂对象实例:factory
- 获取对象类型的参数值:getObjectParam
- 魔术方法和数组是访问:__set、__get、__isset、__unset、offsetExists、offsetGet、offsetSet、offsetUnset、count、getIterator
计划阅读
[ ] framework源码
[ ] orm源码
[ ] helper源码
留言
点击「链接」
相关推荐
- 高性能并发队列Disruptor使用详解
-
基本概念Disruptor是一个高性能的异步处理框架,是一个轻量的Java消息服务JMS,能够在无锁的情况下实现队列的并发操作Disruptor使用环形数组实现了类似队列的功能,并且是一个有界队列....
- Disruptor一个高性能队列_java高性能队列
-
Disruptor一个高性能队列前言说到队列比较熟悉的可能是ArrayBlockingQueue、LinkedBlockingQueue这两个有界队列,大多应用在线程池中使用能保证线程安全,但其安全性...
- 谈谈防御性编程_防御性策略
-
防御性编程对于程序员来说是一种良好的代码习惯,是为了保护自己的程序在不可未知的异常下,避免带来更大的破坏性崩溃,使得程序在错误发生时,依然能够云淡风轻的处理,但很多程序员入行很多年,写出的代码依然都是...
- 有人敲门,开水开了,电话响了,孩子哭了,你先顾谁?
-
前言哎呀,这种情况你肯定遇到过吧!正在家里忙活着,突然——咚咚咚有人敲门,咕噜咕噜开水开了,铃铃铃电话响了,哇哇哇孩子又哭了...我去,四件事一起来,人都懵了!你说先搞哪个?其实这跟我们写Java多线...
- 面试官:线程池如何按照core、max、queue的执行顺序去执行?
-
前言这是一个真实的面试题。前几天一个朋友在群里分享了他刚刚面试候选者时问的问题:"线程池如何按照core、max、queue的执行循序去执行?"。我们都知道线程池中代码执行顺序是:co...
- 深入剖析 Java 中线程池的多种实现方式
-
在当今高度并发的互联网软件开发领域,高效地管理和利用线程资源是提升程序性能的关键。Java作为一种广泛应用于后端开发的编程语言,为我们提供了丰富的线程池实现方式。今天,就让我们深入探讨Java中...
- 并发编程之《彻底搞懂Java线程》_java多线程并发解决方案详解
-
目录引言一、核心概念:线程是什么?...
- Redis怎么实现延时消息_redis实现延时任务
-
一句话总结Redis可通过有序集合(ZSET)实现延时消息:将消息作为value,到期时间戳作为score存入ZSET。消费者轮询用ZRANGEBYSCORE获取到期消息,配合Lua脚本保证原子性获取...
- CompletableFuture真的用对了吗?盘点它最容易被误用的5个场景
-
在Java并发编程中,CompletableFuture是处理异步任务的利器,但不少开发者在使用时踩过这些坑——线上服务突然雪崩、异常悄无声息消失、接口响应时间翻倍……本文结合真实案例,拆解5个最容易...
- 接口性能优化技巧,有点硬_接口性能瓶颈
-
背景我负责的系统到2021年初完成了功能上的建设,开始进入到推广阶段。随着推广的逐步深入,收到了很多好评的同时也收到了很多对性能的吐槽。刚刚收到吐槽的时候,我们的心情是这样的:...
- 禁止使用这5个Java类,每一个背后都有一段"血泪史"
-
某电商平台的支付系统突然报警:大量订单状态异常。排查日志发现,同一笔订单被重复支付了三次。事后复盘显示,罪魁祸首竟是一行看似无害的SimpleDateFormat代码。在Java开发中,这类因使用不安...
- 无锁队列Disruptor原理解析_无锁队列实现原理
-
队列比较队列...
- Java并发队列与容器_java 并发队列
-
【前言:无论是大数据从业人员还是Java从业人员,掌握Java高并发和多线程是必备技能之一。本文主要阐述Java并发包下的阻塞队列和并发容器,其实研读过大数据相关技术如Spark、Storm等源码的,...
- 线程池工具及拒绝策略的使用_线程池处理策略
-
线程池的拒绝策略若线程池中的核心线程数被用完且阻塞队列已排满,则此时线程池的资源已耗尽,线程池将没有足够的线程资源执行新的任务。为了保证操作系统的安全,线程池将通过拒绝策略处理新添加的线程任务。...
- 【面试题精讲】ArrayBlockingQueue 和 LinkedBlockingQueue 区别?
-
有的时候博客内容会有变动,首发博客是最新的,其他博客地址可能会未同步,认准...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
程序员的开源月刊《HelloGitHub》第 71 期
-
详细介绍一下Redis的Watch机制,可以利用Watch机制来做什么?
-
假如有100W个用户抢一张票,除了负载均衡办法,怎么支持高并发?
-
如何将AI助手接入微信(打开ai手机助手)
-
Java面试必考问题:什么是乐观锁与悲观锁
-
SparkSQL——DataFrame的创建与使用
-
redission YYDS spring boot redission 使用
-
一文带你了解Redis与Memcached? redis与memcached的区别
-
如何利用Redis进行事务处理呢? 如何利用redis进行事务处理呢英文
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)