以洪荒之力打开linux德·摩根定律

德·摩根定律让学习liunx的小伙伴绕得头疼,现在我就用洪荒之力为大家理顺一下这个定律。


wKiom1etwHLSIrxXAAAskZ0cql4503.jpg

由图片可以看出,


A=4+3

B=3+2


非A=2+1

非B=4+1



A且B就是代表既是A又是B的地方,A和B都有色块3,所以色块3代表了A且B

同时,我们再看A=4+3 ,B=3+2,我们可以推断出,且运算的结果就是两个算数式中重复的数字。


A且B=3



A或B就是代表可以是A的部分,也可以是B的部分,所以色块2,3,4的和代表了A或B的范围。再看A=4+3,B=3+2,我们可以推断出,或运算的结果就是两个算术式中所有数字相加,重复的数字只加一次。


A或B=2+3+4


非一个色块,就是除了这个色块的其他所有色块之和。非n个色块,就是除了这n个色块的其他色块之和。


例:

   非3=1+2+4



由此,我们可以进行以下的运算


(非A)或(非B)=(2+1)或(4+1)=1+2+4

非(A且B)=非(4+3且3+2)=非(3)=1+2+4


(非A)且(非B)=(2+1)且(4+1)=1

非(A或B)=非(4+3或3+2)=非(4+3+2)=1


我们可以得出以下结论:


(非A)或(非B)=非(A且B)


(非A)且(非B)=非(A或B)




下面让我们来做下练习题:


  1. chmod -rw /tmp/file1,编写脚本/root/bin/per.sh,判断当前用户对/tmp/fiile1文件是否不可读且不可写

    方法一:


[root@localhost bin]# cat per.sh 

#!/bin/bash

[ ! -r /tmp/file1 -a ! -w /tmp/file1 ] && echo "you can't read and write /tmp/file1" || echo "you can read or write /tmp/file1 " 


    方法二:

    

[root@localhost bin]# cat per2.sh

#!/bin/bash

! [ -r /tmp/file1 -o -w /tmp/file1 ] && echo "you can't read and write /tmp/file1" || echo "you can read or write /tmp/file1 "


红色标记处为两条语句中不同的地方,但两者的功能是相同的。



有的小伙伴不理解 “所有用户都没有写权限”的反面=至少有一类用户有写权限

我们可以拿个空瓶子来说明:


“空瓶子”反面=“瓶子里有水”,注意跟水量多少无关,有一滴水的瓶子也不算空瓶子,我们也可以说,


“空瓶子”反面=瓶子里至少有一滴水


所以,“所有用户都没有写权限”的反面=至少有一类用户有写权限。

练习:

1、查找/var目录下属主为root,且属组为mail的所有文件

   find /var -user root -a -group -mail

2、查找/var目录下不属于root、lp、gdm的所有文件

   find /var -not \( -user root -o -user lp -o -user gdm \)

3、查找/var目录下最近一周内其内容修改过,同时属主不为root,也不是postfix的文件

   find /var -mtime -7 -a -not -user root -a -not -user plstfix

4、查找当前系统上没有属主或属组,且最近一个周内曾被访问过的文件

   find / -nouser -o -nogroup -atime -7

5、查找/etc目录下大于1M且类型为普通文件的所有文件

   find /etc/ -size +1M -type f

6、查找/etc目录下所有用户都没有写权限的文件

   find /etc -not -perm /222

7、查找/etc目录下至少有一类用户没有执行权限的文件

   find /etc -not -perm -111 

8、查找/etc/init.d目录下,所有用户都有执行权限,且其它用户有写权限的文件

   find /etc/init.d/ -perm -113

原创文章,作者:zebra930,如若转载,请注明出处:http://www.178linux.com/34405

(0)
zebra930zebra930
上一篇 2016-08-15
下一篇 2016-08-15

相关推荐

  • Nginx及其相关配置详解(二)

    与套接字相关的配置: 1、server { … }  #配置一个虚拟主机;         Default:—         Context:http server { # 配…

    2017-07-14
  • Linux常用文件管理命令

    常用文件管理命令 cat cat命令连接文件并打印到标准输出设备上,cat经常用来显示文件的内容 语法 cat(选项)(参数) 选项 -n或-number:有1开始对所有输出的行数编号; -b或–number-nonblank:和-n相似,只不过对于空白行不编号; -s或–squeeze-blank:当遇到有连续两行以上的空白行,就代换为一行的空白行; …

    2018-03-11
  • hbase安装配置(整合到hadoop)

    1.  快速单击安装 在单机安装Hbase的方法。会引导你通过shell创建一个表,插入一行,然后删除它,最后停止Hbase。只要10分钟就可以完成以下的操作。 1.1下载解压最新版本 选择一个 Apache 下载镜像:http://www.apache.org/dyn/closer.cgi/hbase/,下载 HBase Re…

    Linux干货 2015-04-13
  • lvm基本应用

    前言 一种技术要知其然,还要知其所以然 lvm简介 LVM是 Logical Volume Manager(逻辑卷管理)的简写,它是Linux环境下对磁盘分区进行管理的一种机制。普通的磁盘分区管理方式在逻辑分区划分好之后就无法改变其大小,当一个逻辑分区存放不下某个文件时,这个文件因为受上层文件系统的限制,也不能跨越多个分区来存放,所以也不能同时放到别的磁盘上…

    Linux干货 2016-05-21
  • btrfs 文件系统

    简介   Btrfs((B-tree,ButterFS ,Better FS通常念成Butter FS),由Oracle于2007年宣布并进行中的COW(copy-on-write式)文件系统。继ext3/4文件系统之后linux又有了比较强大的文件系统(btrfs文件系统),btrfs文件系统不仅可以将ex…

    Linux干货 2016-02-19
  • 用户及组概念和管理

    用户和组概念 /etc/passwd文件字段含义 root:x:0:0:root:/root:/bin/bash 用户名:登陆名,具有唯一性 密码存放加密用户的密码,看到的是一个x,其实已经映射到/etc/shadow文件中 UID:用户ID GID:组群ID 用户名全称:可以不设置 主目录:用户登陆系统中首先进入的目录 登陆Shell:用户使用shell类…

    Linux干货 2016-11-04