当前位置:首页>Linux>OS22.【Linux】环境变量

OS22.【Linux】环境变量

  • 2026-06-28 11:46:57
OS22.【Linux】环境变量

目录

1.与环境变量有关的实验

A.对比命令和自制程序的运行

为什么.像ls、pwd这样的命令运行是不需要加路径?

执行自制程序而不加路径的方法,看看PATH环境变量

方法1:将自制程序移动到系统的搜索路径下

方法2:临时修改PATH环境变量

B.查看系统中所有环境变量

解释几个常见的环境变量

C.获取环境变量的函数getenv()

2.环境变量

解释全局属性

命令行参数

a.out子进程是如何得到环境变量表的?

证明能被子进程继承,也就证明的全局属性

添加环境变量的命令:export

取消环境变量的命令:unset

使用第三方变量environ来访问环境变量

环境变量的配置文件存储的位置

用户级环境配置文件

系统级环境配置文件

3.系统变量的分类

环境变量

本地变量

set命令

证明本地变量不可被继承

4.系统命令的分类

常规命令和内建命令

man和help的区别

5.总结获取环境变量的几种方法

6.拓展阅读:自定义入口函数

7.附: C89标准文档对main函数的描述


1.与环境变量有关的实验

从与环境变量有关的实验来感受环境变量

A.对比命令和自制程序的运行

1.像ls、pwd这样的命令运行是不需要加路径的

2.如果不配置环境变量,那么运行开发者自制程序是需要加路径的

例如:当前目录下有一个a.out可执行文件,那么运行时需要加路径:

./a.out #.表示当前目录

a.out是由以下代码产生的: 

#include<stdio.h>intmain(){    printf("Hello World!");    return 0;}

为什么.像ls、pwd这样的命令运行是不需要加路径?

之前在OS4.【Linux】基本指令入门(3)文章讲过:系统的命令存储在特定的路径下,那么bash执行指令会到特定的路径中找

特定的路径存储在环境变量PATH中

 使用echo命令打印系统的环境变量:

echo $PATH #注意: $作用:说明PATH是变量名

那么在搜索命令时,会从左向右按顺序查找这些路径下的命令,如果找到了,之后的路径就不找了 

还可以打印其他环境变量:

echo PATH:/home/guest

(要使用冒号分割符,因为冒号分割符的作用就是分开各个路径)

这样就不用添加路径了:

可以看到环境变量设置之后,不需要重启shell,也不需要重新加载文件,只要设置环境变量就能直接生效

B.查看系统中所有环境变量

使用不带任何选项的env命令:

其中,=前面的大写单词指的是环境变量名, =后面的是该环境变量的值

环境变量名 = 对应的值

解释几个常见的环境变量

USER

指的是当前登录的用户(随su命令切换用户而变)

LOGNAME

和USER不同的是:在某些情况下,它的值可能会保持不变,即使通过su命令切换到其他用户

PWD

指当前处于的绝对路径,其值会在每次执行cd命令后时更新

*注:pwd命令不是使用了PWD环境变量,而是通过getcwd函数实现的

HOME

指当前用户的家目录

SHELL

指当前Shell,它的值通常是/bin/bash

C.获取环境变量的函数getenv()

看看手册:

getenv()的作用:获取指定的环境变量(environment variable),需要包含<stdlib.h>头文件

函数的声明: char* getenv(const char *name);

注意到有两个参数:

示例代码:

#include<stdlib.h>#include<stdio.h>intmain(){    printf("PATH=%s\n",getenv("PATH"));    return 0;}

运行结果:和不带任何选项的env命令打印的结果是一样的

2.环境变量

从上面的三个实验可以总结出环境变量的定义:

环境变量: 是操作系统中用来指定操作系统运行环境的一些参数,是系统提供的一组 name = value 形式的变量,不同的环境变量有不同的用途,通常具有全局属性

例如编写C/C++代码的时候,在链接的时候,有相关环境变量帮助编译器进行查找所链接的动态静态库

解释全局属性

命令行参数

回顾分析命令行参数的文章:

110.【C语言】编写命令行程序(1)

113.【C语言】编写命令行程序(2)

114.【C语言】实战分析命令行程序:srom转换工具源码分析

一般情况下,main函数用的比较多的两种写法:

int main()int main(int argc, char* argv[])

但Linux操作系统为main函数提供了第3个参数:char *envp[]

(来自GNU Program-Arguments网站) 

注:编译器会根据情况处理main函数的三种不同写法

envp的全称是environment variables pointer array,是环境变量指针数组,可以打印内容

#include<stdio.h>intmain(int argc,char* argv[],char* envp[]){	for (size_t i=0;envp[i];i++)	{		printf("%s\n",envp[i]);	}	return 0;}

提示: argv和env表的结构都一样,必须以NULL结尾

运行结果:

结论: 

1.程序运行需要两张核心向量表: char* argv[],char* envp[],指针数组的结尾元素的值为空指针 2.main函数之前还有一些函数,这些函数负责向main函数传递这两张表的指针和参数的个数argc

a.out子进程是如何得到环境变量表的?

上方运行了a.out子进程,子进程打印了操作系统的所有环境变量

bash在启动时,会从操作系统的配置文件中读取环境变量信息,bash产生的子进程会继承bash得到的环境变量!

证明能被子进程继承,也就证明的全局属性

添加环境变量的命令:export

例如添加临时环境变量:

export MY_ENV=1

注意: 不能写成MY_ENV=1,这样写是添加本地变量;变成环境变量需要加export前缀

 检查是否成功添加:

env | grep MY_ENV

再次执行a.out,会发现MY_ENV已经被bash的子进程a.out继承

取消环境变量的命令:unset

使用第三方变量environ来访问环境变量

查询environ的含义:

extern char **environ其实是存一些环境变量字符串指针的数组, 最后一个元素的值为空指针

libc中定义的全局变量environ指向环境变量表,environ没有包含在任何头文件中,所以在使用时要用extern声明

例如以下代码:

#include<stdio.h>#include<unistd.h>intmain(){    extern char** environ;    for ( int i = 0; environ[i]; i++)     {        printf("%d:%s\n", i, environ[i]);    }}

运行结果:

环境变量的配置文件存储的位置

用户级环境配置文件

Ubuntu是~/.profile,

Centos是~/.bash_profile 或 ~/.bashrc,

.profile存储用户环境定义和启动时运行的程序

.bashrc存储用户定义的命令别名和环境变量  

每个用户目录下都会有自己的用户级环境配置文件,在用户每次登录系统时被读取,里面所有命令都会被shell执行,包括环境变量的配置命令

系统级环境配置文件

/etc/progile.d目录下包含了系统级环境配置文件,任意用户登录时都会执行这个目录下的环境配置文件完成环境配置

/etc/bashrc 系统定义的命令别名和环境变量  

/etc/profile 系统环境定义和启动时运行的程序  

/etc/inputrc 键盘设定和键位配置信息  

3.系统变量的分类

系统变量主要分为本地变量和环境变量

环境变量

见上方内容

本地变量

创建本地变量的命令

本地变量名 = 本地变量值 #前面不要加export

 本地变量和环境变量不同,本地变量主要作用范围是当前shell进程,不会被子进程继承,但环境变量可以被子进程继承

例如添加2个本地变量:

 (\是续行符,可以帮助开发者写多行命令)

环境变量中是查不到的:

set命令

作用: 查系统中所有的变量(本地变量+环境变量)

例如查之前添加的本地变量:

证明本地变量不可被继承

证明bash的子进程无法获取上面提到的VAL1和VAL2的值即可

#include<stdio.h>#include<stdlib.h>intmain(){    printf("VAL1=%s",getenv("VAL1"));    printf("VAL2=%s",getenv("VAL2"));    return 0;}

运行结果:值为空 

将VAL1和VAL2用export导出,再打印:

4.系统命令的分类

常规命令和内建命令

问题:执行echo命令让bash产生了子进程,那为什么能获取本地变量?

显然echo不是常规命令

Linux下有两种命令:

1.常规命令: 通过创建子进程;来执行常规命令 2.内建命令(也称内置命令,英文名为builtin): bash 不创建子进程,而是由自己亲自执行,类似于 bash 调用了自己写的或者系统提供的函数

例如cd命令调用了chdir()系统调用接口,是由bash自己执行的函数,cd命令的作用是让进程改变自己的路径

成功切换返回0,否则返回-1 

可以写一个简单的切换路径的程序:

#include<stdio.h>#include<unistd.h>intmain(int argc, char* argv[]){    if (argc == 1)    {        printf("Usage:cd path");        return -1;    }    if (chdir(argv[1]))        printf("%s: No such directory\n", argv[1]);    else        printf("Change path successfully\n");    while (1)    {        scanf("%s", argv[1]);        if (chdir(argv[1]))            printf("%s: No such directory\n", argv[1]);        else            printf("Change path successfully\n");    }    return 0;}

注意:这个程序和cd命令还不太一样, 是让进程改变自己的路径,不是更改bash的路径,因此使用上方代码切换路径后,pwd命令打印的值是不变的

可以在cwd文件中看到: 

当然可以继续切换看看cwd的值的变化

man和help的区别

man主要查看的是外部命令和一些系统调用和函数,例如ls、printf…… help主要查看的就是内置命令了。

提示:使用type命令可以查看命令的类型,例如

5.总结获取环境变量的几种方法

1.使用命令env

2.使用getenv()函数

3.直接打印char* envp[]

4.第三方变量environ获取

6.拓展阅读:自定义入口函数

Linux下可以通过自定义入口函数的方法来达到不从main函数(cppreference main_function)开始执行的目的

在https://www.geeksforgeeks.org/c/write-running-c-code-without-main/提到一种方法;

#include<stdio.h>#include<stdlib.h>// entry point function intnomain()void _start(){     // calling entry point     nomain();     exit(0); intnomain()    puts("Geeksforgeeks");     return 0}

编译命令:

gcc -o nomain.out nomain.c -nostartfiles

 运行结果:

摘自stackoverflow what-is-the-use-of-start-in-c的回答:

The symbol _start is the entry point of your program. That is, the address of that symbol is the address jumped to on program start. Normally, the function with the name _start is supplied by a file called crt0.o which contains the startup code for the C runtime environment. It sets up some stuff, populates the argument array argv, counts how many arguments are there, and then calls main. After main returns, exit is called.

If a program does not want to use the C runtime environment, it needs to supply its own code for _start. For instance, the reference implementation of the Go programming language does so because they need a non-standard threading model which requires some magic with the stack. It's also useful to supply your own _start when you want to write really tiny programs or programs that do unconventional things.

翻译: _start符号是Linux下规定的函数的入口点,程序启动时会跳转到该符号所表示的地址

正常情况下, 由_start标识的的函数由crt0.o文件提供,它包含了 C 运行时环境的启动代码. 该代码会完成一些初始化工作: 填充参数数组 argv ,统计参数个数argc,然后调用main函数. main 返回后,再调用exit函数

如果某个程序不想使用C运行时环境,就必须自行提供 _start 的实现 当你想编写体积极小的程序,或者做一些非常规操作时,自己写 _start 也很有用

7.附: C89标准文档对main函数的描述

原文首发于CSDN,点击阅读全文即可查看

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-07-03 00:59:23 HTTP/2.0 GET : https://f.mffb.com.cn/a/500105.html
  2. 运行时间 : 0.287829s [ 吞吐率:3.47req/s ] 内存消耗:4,884.27kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=5a59c64dfdeaf44189d56c41f513db45
  1. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/public/index.php ( 0.79 KB )
  2. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/autoload.php ( 0.17 KB )
  3. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/autoload_real.php ( 2.49 KB )
  4. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/platform_check.php ( 0.90 KB )
  5. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/ClassLoader.php ( 14.03 KB )
  6. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/autoload_static.php ( 4.90 KB )
  7. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper.php ( 8.34 KB )
  8. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-validate/src/helper.php ( 2.19 KB )
  9. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/helper.php ( 1.47 KB )
  10. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/stubs/load_stubs.php ( 0.16 KB )
  11. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Exception.php ( 1.69 KB )
  12. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-container/src/Facade.php ( 2.71 KB )
  13. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/deprecation-contracts/function.php ( 0.99 KB )
  14. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/polyfill-mbstring/bootstrap.php ( 8.26 KB )
  15. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/polyfill-mbstring/bootstrap80.php ( 9.78 KB )
  16. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/var-dumper/Resources/functions/dump.php ( 1.49 KB )
  17. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-dumper/src/helper.php ( 0.18 KB )
  18. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/var-dumper/VarDumper.php ( 4.30 KB )
  19. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/App.php ( 15.30 KB )
  20. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-container/src/Container.php ( 15.76 KB )
  21. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/container/src/ContainerInterface.php ( 1.02 KB )
  22. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/provider.php ( 0.19 KB )
  23. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Http.php ( 6.04 KB )
  24. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper/Str.php ( 7.29 KB )
  25. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Env.php ( 4.68 KB )
  26. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/common.php ( 0.03 KB )
  27. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/helper.php ( 18.78 KB )
  28. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Config.php ( 5.54 KB )
  29. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/app.php ( 0.95 KB )
  30. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/cache.php ( 0.78 KB )
  31. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/console.php ( 0.23 KB )
  32. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/cookie.php ( 0.56 KB )
  33. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/database.php ( 2.48 KB )
  34. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/Env.php ( 1.67 KB )
  35. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/filesystem.php ( 0.61 KB )
  36. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/lang.php ( 0.91 KB )
  37. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/log.php ( 1.35 KB )
  38. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/middleware.php ( 0.19 KB )
  39. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/route.php ( 1.89 KB )
  40. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/session.php ( 0.57 KB )
  41. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/trace.php ( 0.34 KB )
  42. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/view.php ( 0.82 KB )
  43. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/event.php ( 0.25 KB )
  44. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Event.php ( 7.67 KB )
  45. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/service.php ( 0.13 KB )
  46. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/AppService.php ( 0.26 KB )
  47. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Service.php ( 1.64 KB )
  48. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Lang.php ( 7.35 KB )
  49. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/lang/zh-cn.php ( 13.70 KB )
  50. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/Error.php ( 3.31 KB )
  51. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/RegisterService.php ( 1.33 KB )
  52. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/services.php ( 0.14 KB )
  53. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/PaginatorService.php ( 1.52 KB )
  54. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/ValidateService.php ( 0.99 KB )
  55. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/ModelService.php ( 2.04 KB )
  56. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/Service.php ( 0.77 KB )
  57. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Middleware.php ( 6.72 KB )
  58. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/BootService.php ( 0.77 KB )
  59. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/Paginator.php ( 11.86 KB )
  60. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-validate/src/Validate.php ( 63.20 KB )
  61. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/Model.php ( 23.55 KB )
  62. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/Attribute.php ( 21.05 KB )
  63. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/AutoWriteData.php ( 4.21 KB )
  64. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/Conversion.php ( 6.44 KB )
  65. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/DbConnect.php ( 5.16 KB )
  66. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/ModelEvent.php ( 2.33 KB )
  67. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/RelationShip.php ( 28.29 KB )
  68. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/contract/Arrayable.php ( 0.09 KB )
  69. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/contract/Jsonable.php ( 0.13 KB )
  70. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/contract/Modelable.php ( 0.09 KB )
  71. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Db.php ( 2.88 KB )
  72. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/DbManager.php ( 8.52 KB )
  73. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Log.php ( 6.28 KB )
  74. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Manager.php ( 3.92 KB )
  75. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/log/src/LoggerTrait.php ( 2.69 KB )
  76. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/log/src/LoggerInterface.php ( 2.71 KB )
  77. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Cache.php ( 4.92 KB )
  78. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/simple-cache/src/CacheInterface.php ( 4.71 KB )
  79. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper/Arr.php ( 16.63 KB )
  80. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/cache/driver/File.php ( 7.84 KB )
  81. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/cache/Driver.php ( 9.03 KB )
  82. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/CacheHandlerInterface.php ( 1.99 KB )
  83. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/Request.php ( 0.09 KB )
  84. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Request.php ( 55.78 KB )
  85. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/middleware.php ( 0.25 KB )
  86. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Pipeline.php ( 2.61 KB )
  87. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/TraceDebug.php ( 3.40 KB )
  88. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/middleware/SessionInit.php ( 1.94 KB )
  89. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Session.php ( 1.80 KB )
  90. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/session/driver/File.php ( 6.27 KB )
  91. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/SessionHandlerInterface.php ( 0.87 KB )
  92. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/session/Store.php ( 7.12 KB )
  93. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Route.php ( 23.73 KB )
  94. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleName.php ( 5.75 KB )
  95. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Domain.php ( 2.53 KB )
  96. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleGroup.php ( 22.43 KB )
  97. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Rule.php ( 26.95 KB )
  98. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleItem.php ( 9.78 KB )
  99. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/route/app.php ( 1.72 KB )
  100. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/Route.php ( 4.70 KB )
  101. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/dispatch/Controller.php ( 4.74 KB )
  102. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Dispatch.php ( 10.44 KB )
  103. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/controller/Index.php ( 4.81 KB )
  104. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/BaseController.php ( 2.05 KB )
  105. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/facade/Db.php ( 0.93 KB )
  106. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/connector/Mysql.php ( 5.44 KB )
  107. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/PDOConnection.php ( 52.47 KB )
  108. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Connection.php ( 8.39 KB )
  109. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/ConnectionInterface.php ( 4.57 KB )
  110. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/builder/Mysql.php ( 16.58 KB )
  111. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Builder.php ( 24.06 KB )
  112. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/BaseBuilder.php ( 27.50 KB )
  113. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Query.php ( 15.71 KB )
  114. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/BaseQuery.php ( 45.13 KB )
  115. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/TimeFieldQuery.php ( 7.43 KB )
  116. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/AggregateQuery.php ( 3.26 KB )
  117. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ModelRelationQuery.php ( 20.07 KB )
  118. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ParamsBind.php ( 3.66 KB )
  119. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ResultOperation.php ( 7.01 KB )
  120. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/WhereQuery.php ( 19.37 KB )
  121. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/JoinAndViewQuery.php ( 7.11 KB )
  122. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/TableFieldInfo.php ( 2.63 KB )
  123. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/Transaction.php ( 2.77 KB )
  124. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/log/driver/File.php ( 5.96 KB )
  125. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/LogHandlerInterface.php ( 0.86 KB )
  126. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/log/Channel.php ( 3.89 KB )
  127. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/event/LogRecord.php ( 1.02 KB )
  128. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/Collection.php ( 16.47 KB )
  129. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/View.php ( 1.70 KB )
  130. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/View.php ( 4.39 KB )
  131. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Response.php ( 8.81 KB )
  132. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/response/View.php ( 3.29 KB )
  133. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Cookie.php ( 6.06 KB )
  134. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-view/src/Think.php ( 8.38 KB )
  135. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/TemplateHandlerInterface.php ( 1.60 KB )
  136. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/Template.php ( 46.61 KB )
  137. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/template/driver/File.php ( 2.41 KB )
  138. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/template/contract/DriverInterface.php ( 0.86 KB )
  139. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/runtime/temp/067d451b9a0c665040f3f1bdd3293d68.php ( 11.98 KB )
  140. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/Html.php ( 4.42 KB )
  1. CONNECT:[ UseTime:0.000715s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000576s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.010039s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000433s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000705s ]
  6. SELECT * FROM `set` [ RunTime:0.001908s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000683s ]
  8. SELECT * FROM `article` WHERE `id` = 500105 LIMIT 1 [ RunTime:0.011392s ]
  9. UPDATE `article` SET `lasttime` = 1783011563 WHERE `id` = 500105 [ RunTime:0.011197s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 67 LIMIT 1 [ RunTime:0.000331s ]
  11. SELECT * FROM `article` WHERE `id` < 500105 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.013864s ]
  12. SELECT * FROM `article` WHERE `id` > 500105 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.009995s ]
  13. SELECT * FROM `article` WHERE `id` < 500105 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.069726s ]
  14. SELECT * FROM `article` WHERE `id` < 500105 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.067953s ]
  15. SELECT * FROM `article` WHERE `id` < 500105 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.018201s ]
0.289578s