windows里的Qt和linux中的Qt有何异同

windows里的Qt和linux中的Qt有何异同,第1张

Linux是目前十分火爆的 *** 作系统。它是由芬兰赫尔辛基大学的一个大学生Linus B. Torvolds在1991年首次编写的。标志性图标是一个可爱的小企鹅。Linux是一种类Unix系统,Linus当时编写它的目的是为了替代一种名叫Minix的 *** 作系统。Minix是由一个名叫Andrew Tannebaum的计算机教授编写的,当时由于Unix是一个商业软件,其源代码是不能拿来进行教学的,Andrew教授就自己编写了一个系统用于教学。最初的Minix用一张软盘就能装下,麻雀虽小、五脏俱全,Minix具有一般 *** 作系统的特征,它同时兼容Unix系统一直以来,很多人对 *** 作系统的认识停留在windows的华丽的图形界面,认为只有鼠标 *** 作才能把一个 *** 作系统给很好的用起来。linux的出现改变了这点先看看linux的目录结构,linux以/作为一个总的挂载点,把所有系统文件安装在/下的不同目录下,linux下的通常目录有:/etc用来放linux启动脚本和系统配置信息/boot 放着linux内核和启动系统所需的文件/dev存放设备文件/home用户文件的主目录/proc放着存储进程和系统信息/root超级用户的主目录/bin常用必要的命令/sbin存放系统管理员命令/usr一般的应用程序文件/var包含系统产生的经常变化的文件,如邮件日志等等/lib系统必要的运行库/mnt存放临时的映射文件系统,如系统光驱软驱的挂载/tmp存放临时文件的目录。Linux命令通常放在/bin/sbin/usr/bin /usr/sbin等目录下,每一个安装的软件包,都会在这些目录下产生几个命令。下面就windows几个常用特征,对比着简单介绍linux,以redhat9.0为例。 1.windows在桌面上经常能看见各种图标,这些图标是相应程序中快捷方式,在linux下可以用ln n xxx, ln命令是建立文件符号链接的linux命令,可以在一个目录下建立起多个文件的链接,执行这些链接,就执行了文件本身,而删除链接,并不删除文件。所以通过建立各种链接文件,你也能拥有自己的命令桌面。 2.windows的任务管理器中能看到系统的进程,性能等一系列动态信息,也能关闭一些用户进程,在linux中,通过psaux ,top,kill命令可以实现这些 *** 作,ps是linux用来查看当前运行进程的命令,top动态显示目前正在系统中执行的程序,kill+文件Id可以删除相应进程,这些命令实际上调用的对/proc中,文件的 *** 作/proc是一个内存映射到文件的文件夹,里面存放的文件记录了系统进程信息、动态信息和系统基本信息。通过查看/proc,能得到系统的大部分信息。 3.windows 的添加删除程序相当的简单,在linux 也有类似简单的工具rpm redhat专门为程序编程人员提供了这一个软件制作工具,大量linux 软件已经做成rpm格式,只需要通过rpm ivh xxx的方式可以成功安装,通过rpmuvh xxx就可以成功卸载。同时 rpm工具带有很多其他功能,如通过rpmqa|more可以查询所有的已经安装在系统的rpm包的软件名rpmql xx能查找一个软件包即将拷贝何种文件在待安装的linux系统上,rpmqf /xxx能查找任何一个rpm格式的命令是属于哪个软件包,总之,rpm的功能很强大,给linux添加删除软件带来很多便捷。 4.windows的设备管理器提供了计算机软硬件很多信息,在linux下,这些系统信息通过dmesg|more的命令,dmesg实际上是/var/log下一个日志文件,系统在启动的时候记录相应的软硬件信息,存放在此,除了这个文件,/proc下也存放着许多相应系统的信息,如分区信息,cpu信息,内存信息交换分区信息,中断信息,系统总线信息。大多相应的系统信息命令就是通过查找这里的文件信息提供给大家的。 5.windows中有环境变量概念,linux也有,系统在启动的时候已经设置了很多环境变量,其中比较常见的有PATH SHELLHOME PS1等 。PATH就是我们常常说的路径,定义了它才能够直接使用命令,而不需要加上路径 ,SHELL选择系统启动后进入bash脚本 HOME是记录当前的用户的目录,PS1是当前提示符,显示一个环境变量用echo $PATH,显示本地所有环境变量用set,显示所有环境变量用env,清楚环境变量用unset xx设置一个环境变量用export xx=” ”。 6.windows的任务启动执行常见的有几种方式,一个是在系统启动文件中执行程序的启动,如编辑autoexec程序,一个是放在注册表的Run下,一个是放在开始菜单的启动项中。linux启动,通常需要加载一系列启动脚本, linux启动当内核完成加载需要找/etc/inittab这个文件,这个文件通常会执行/etc/rc.local脚本文件(当然也可以自己更改),再由它调用其他脚本文件进行各种后台程序的启动和系统环境信息的设置。需要启动时执行的程序可以放在这里用脚本语言启动。熟悉了脚本编程,还可以对系统本身启动的脚本进行修改,去掉不想要启动的设备程序和修改启动后的系统信息,打造属于自己的linux *** 作系统。 7.window下控制面板-管理工具-服务,记载着windows后台服务的启动情况,在linux下也有着类似的管理方式,它是通过脚本的方式来管理,所有的后台启动脚本都放在rc.d下,linux启动有六个模式,相应就有六个启动脚本文件夹,每一个文件夹对应着在linux启动的一种模式下应该启动或不启动的程序,在启动的时候通过改变相应模式文件夹中的程序脚本前缀S或K,就能在相应的模式下自启动或不启动程序,在 *** 作系统运行中,还可以通过service start | restart|stop来手动启动或重启或停止该程序。 8.windows对文件的 *** 作十分方便,用户很容易就能建立,查找,删除一个文件,Linux命令模式没有向windows那么直观的文件 *** 作界面,但它提供了一组强大的文件 *** 作命令来让用户能方便的对硬盘中的文件进行 *** 作,touch 建立一个新文件,find功能强大的查找文件 rm删除文件和目录,tar对多个文件打包同时进行压缩,ln建立文件快捷方式 chmod,chown修改文件的权限和所有者,vi类似与windows下记事本的编辑程序等等。这些命令能够很容易的对硬盘文件进行各种有用的 *** 作,不同于windows *** 作系统,linux的命令大都独立的程序,可以添加和裁减,这使得不同的系统可以拥有对文件不同的 *** 作,使linux能很灵活的应用各个方面。 linux系统是属于那种灵活的 *** 作系统,除了少数必须的命令,多数的命令都可以通过裁减的方式由用户自己定制。不像windows系统一口吃一个胖子,这样做的好处就使得linux能够用在比windows更广泛的领域,从服务器到桌面系统到嵌入式,甚至可以小到仅仅只由内核+文件系统构成大小不到一兆的嵌入式系统。而大多数的linux开发人员的热情,使得linux今后会成为一个重要的 *** 作系统。希望采纳

1. 在系统维护的过程中,随时可能有需要查看 CPU 使用率,并根据相应信息分析系统状况的需要。在 CentOS 中,可以通过 top 命令来查看 CPU 使用状况。运行 top 命令后,CPU 使用状态会以全屏的方式显示,并且会处在对话的模式 -- 用基于 top 的命令,可以控制显示方式等等。退出 top 的命令为 q (在 top 运行中敲 q 键一次)。

top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器

可以直接使用top命令后,查看%MEM的内容。可以选择按进程查看或者按用户查看,如想查看oracle用户的进程内存使用情况的话可以使用如下的命令:

$ top -u oracle

2. 释义:

PID:进程的ID

USER:进程所有者

PR:进程的优先级别,越小越优先被执行

NInice:值

VIRT:进程占用的虚拟内存

RES:进程占用的物理内存

SHR:进程使用的共享内存

S:进程的状态。S表示休眠,R表示正在运行,Z表示僵死状态,N表示该进程优先值为负数

%CPU:进程占用CPU的使用率

%MEM:进程使用的物理内存和总内存的百分比

TIME+:该进程启动后占用的总的CPU时间,即占用CPU使用时间的累加值。

COMMAND:进程启动命令名称

3. *** 作实例:

在命令行中输入 “top”

即可启动 top

top 的全屏对话模式可分为3部分:系统信息栏、命令输入栏、进程列表栏。

第一部分 -- 最上部的 系统信息栏 :

第一行(top):

“00:11:04”为系统当前时刻;

“3:35”为系统启动后到现在的运作时间;

“2 users”为当前登录到系统的用户,更确切的说是登录到用户的终端数 -- 同一个用户同一时间对系统多个终端的连接将被视为多个用户连接到系统,这里的用户数也将表现为终端的数目;

“load average”为当前系统负载的平均值,后面的三个值分别为1分钟前、5分钟前、15分钟前进程的平均数,一般的可以认为这个数值超过 CPU 数目时,CPU 将比较吃力的负载当前系统所包含的进程;

第二行(Tasks):

“59 total”为当前系统进程总数;

“1 running”为当前运行中的进程数;

“58 sleeping”为当前处于等待状态中的进程数;

“0 stoped”为被停止的系统进程数;

“0 zombie”为被复原的进程数;

第三行(Cpus):

分别表示了 CPU 当前的使用率;

第四行(Mem):

分别表示了内存总量、当前使用量、空闲内存量、以及缓冲使用中的内存量;

第五行(Swap):

表示类别同第四行(Mem),但此处反映着交换分区(Swap)的使用情况。通常,交换分区(Swap)被频繁使用的情况,将被视作物理内存不足而造成的。

第二部分 -- 中间部分的内部命令提示栏:

top 运行中可以通过 top 的内部命令对进程的显示方式进行控制。内部命令如下表:

s

- 改变画面更新频率

l - 关闭或开启第一部分第一行 top 信息的表示

t - 关闭或开启第一部分第二行 Tasks 和第三行 Cpus 信息的表示

m - 关闭或开启第一部分第四行 Mem 和 第五行 Swap 信息的表示

N - 以 PID 的大小的顺序排列表示进程列表(第三部分后述)

P - 以 CPU 占用率大小的顺序排列进程列表 (第三部分后述)

M - 以内存占用率大小的顺序排列进程列表 (第三部分后述)

h - 显示帮助

n - 设置在进程列表所显示进程的数量

q - 退出 top

s -

改变画面更新周期

第三部分 -- 最下部分的进程列表栏:

以 PID 区分的进程列表将根据所设定的画面更新时间定期的更新。通过 top 内部命令可以控制此处的显示方式

pmap

可以根据进程查看进程相关信息占用的内存情况,(进程号可以通过ps查看)如下所示:

$ pmap -d 5647

ps

如下例所示:

$ ps -e -o 'pid,comm,args,pcpu,rsz,vsz,stime,user,uid' 其中rsz是是实际内存

$ ps -e -o 'pid,comm,args,pcpu,rsz,vsz,stime,user,uid' | grep oracle | sort -nrk

其中rsz为实际内存,上例实现按内存排序,由大到小

在Linux下查看内存我们一般用free命令:

[root@scs-2 tmp]# free

total used free shared buffers cached

Mem: 3266180 3250004 16176 0 110652 2668236

-/+ buffers/cache: 471116 2795064

Swap: 2048276 80160 1968116

下面是对这些数值的解释:

total:总计物理内存的大小。

used:已使用多大。

free:可用有多少。

Shared:多个进程共享的内存总额。

Buffers/cached:磁盘缓存的大小。

第三行(-/+ buffers/cached):

used:已使用多大。

free:可用有多少。

第四行就不多解释了。

区别:第二行(mem)的used/free与第三行(-/+ buffers/cache) used/free的区别。 这两个的区别在于使用的角度来看,第一行是从OS的角度来看,因为对于OS,buffers/cached 都是属于被使用,所以他的可用内存是16176KB,已用内存是3250004KB,其中包括,内核(OS)使用+Application(X, oracle,etc)使用的+buffers+cached.

第三行所指的是从应用程序角度来看,对于应用程序来说,buffers/cached 是等于可用的,因为buffer/cached是为了提高文件读取的性能,当应用程序需在用到内存的时候,buffer/cached会很快地被回收。

所以从应用程序的角度来说,可用内存=系统free memory+buffers+cached。

如上例:

2795064=16176+110652+2668236

接下来解释什么时候内存会被交换,以及按什么方交换。 当可用内存少于额定值的时候,就会开会进行交换。

如何看额定值:

cat /proc/meminfo

[root@scs-2 tmp]# cat /proc/meminfo

MemTotal: 3266180 kB

MemFree: 17456 kB

Buffers: 111328 kB

Cached: 2664024 kB

SwapCached: 0 kB

Active: 467236 kB

Inactive: 2644928 kB

HighTotal: 0 kB

HighFree: 0 kB

LowTotal: 3266180 kB

LowFree: 17456 kB

SwapTotal: 2048276 kB

SwapFree: 1968116 kB

Dirty: 8 kB

Writeback: 0 kB

Mapped: 345360 kB

Slab: 112344 kB

Committed_AS: 535292 kB

PageTables: 2340 kB

VmallocTotal: 536870911 kB

VmallocUsed: 272696 kB

VmallocChunk: 536598175 kB

HugePages_Total: 0

HugePages_Free: 0

Hugepagesize: 2048 kB

用free -m查看的结果:

[root@scs-2 tmp]# free -m

total used free shared buffers cached

Mem: 3189 3173 16 0 107 2605

-/+ buffers/cache: 460 2729

Swap: 2000 78 1921

查看/proc/kcore文件的大小(内存镜像):

[root@scs-2 tmp]# ll -h /proc/kcore

-r-------- 1 root root 4.1G Jun 12 12:04 /proc/kcore

备注:

占用内存的测量

测量一个进程占用了多少内存,linux为我们提供了一个很方便的方法,/proc目录为我们提供了所有的信息,实际上top等工具也通过这里来获取相应的信息。

/proc/meminfo 机器的内存使用信息

/proc/pid/maps pid为进程号,显示当前进程所占用的虚拟地址。

/proc/pid/statm 进程所占用的内存

[root@localhost ~]# cat /proc/self/statm

654 57 44 0 0 334 0

输出解释

CPU 以及CPU0。。。的每行的每个参数意思(以第一行为例)为:

参数 解释 /proc//status

Size (pages) 任务虚拟地址空间的大小 VmSize/4

Resident(pages) 应用程序正在使用的物理内存的大小 VmRSS/4

Shared(pages) 共享页数 0

Trs(pages) 程序所拥有的可执行虚拟内存的大小 VmExe/4

Lrs(pages) 被映像到任务的虚拟内存空间的库的大小 VmLib/4

Drs(pages) 程序数据段和用户态的栈的大小 (VmData+ VmStk )4

dt(pages) 04

查看机器可用内存

/proc/28248/>free

total used free shared buffers cached

Mem: 1023788 926400 97388 0 134668 503688

-/+ buffers/cache: 288044 735744

Swap: 1959920 89608 1870312

我们通过free命令查看机器空闲内存时,会发现free的值很小。这主要是因为,在linux中有这么一种思想,内存不用白不用,因此它尽可能的cache和buffer一些数据,以方便下次使用。但实际上这些内存也是可以立刻拿来使用的。

所以 空闲内存=free+buffers+cached=total-used

top命令 是Linux下常用的性能 分析工具 ,能够实时显示系统 中各个进程的资源占用状况,类似于Windows的任务管理 器。下面详细介绍它的使用方法。

top - 02:53:32 up 16 days, 6:34, 17 users, load average: 0.24, 0.21, 0.24

Tasks: 481 total, 3 running, 474 sleeping, 0 stopped, 4 zombie

Cpu(s): 10.3%us, 1.8%sy, 0.0%ni, 86.6%id, 0.5%wa, 0.2%hi, 0.6%si, 0.0%st

Mem: 4042764k total, 4001096k used, 41668k free, 383536k buffers

Swap: 2104472k total, 7900k used, 2096572k free, 1557040k cached

PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND

32497 jacky 20 0 669m 222m 31m R 10 5.6 29:27.62 firefox

4788 yiuwing 20 0 257m 18m 13m S 5 0.5 5:42.44 konsole

5657 Liuxiaof 20 0 585m 159m 30m S 4 4.0 5:25.06 firefox

4455 xiefc 20 0 542m 124m 30m R 4 3.1 7:23.03 firefox

6188 Liuxiaof 20 0 191m 17m 13m S 4 0.5 0:01.16 konsole

统计信息区前五行是系统整体的统计信息。第一行是任务队列信息,同 uptime 命令的执行结果。其内容如下:

01:06:48 当前时间

up 1:22 系统运行 时间,格式为时:分

1 user 当前登录用户 数

load average: 0.06, 0.60, 0.48 系统负载 ,即任务队列的平均长度。

三个数值分别为 1分钟、5分钟、15分钟前到现在的平均值。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/8905963.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-22
下一篇 2023-04-22

发表评论

登录后才能评论

评论列表(0条)

保存