初识 Powershelgl 5.0 class

过去豆子在PowerShell 里面处理自定义的对象一般都是通过hash表转换来的。今天看了看PS 5里面的class功能,发现这个功能实在是太好使了,如果有其他面向对象的开发语言的基础,很容易就上手了。

直接来看看例子吧。

比如我创建一个people的类。

注意要点:

  1. 格式
  2. 我通过static指定了一个静态的属性 $sex
  3. Enum是PS5的另外一个很nb的功能,可以自己创建一个枚举类,然后这个类的实例只能在限定的范围里面出现;比如 nationality(国籍)只能是我指定的那几个国家名字
Class people
{
[string]$name
[int]$age
static [string]$sex=‘male‘
[string]$career
[nationality]$nationality
}

Enum nationality
{
 China = 1
 Japan = 2
 Australia = 3
 USA = 4
 Russia = 5
}

创建好类了,我们需要实例化。这里有2种方式实例化,第一种是和传统的方式一样,New-Object实现,然后挨个给每个实例的属性赋值

$obj=new-object people
$obj.name=‘alex‘
$obj.age=20
$obj.career=‘IT‘
$obj.nationality=‘china‘
$obj::sex
$obj

结果如下所示,注意他的类的静态成员只能通过::的方式显示出来,而不会显示在实例对象的属性里面

male
name age career nationality
---- --- ------ -----------
alex  20 IT           China

第二个实例化的方式是通过new()这个构造函数来实例化,他和第一种的区别主要在于第一种方式还可以在初始化的同时通过-property指定属性,但是new()默认的构造方法只能通过=来给属性赋值

$obj2=[people]::new()
$obj2.name=‘james‘
$obj2

$obj3=new-object people -Property @{‘name‘=‘kevin‘;‘age‘=30;‘career‘=‘Chef‘; ‘nationality‘=‘Japan‘}
$obj3

如果一定要在new()实例化的时候一起赋值,我们可以手动重写一个构造函数

比如

Class people
{
[string]$name
[int]$age
static [string]$sex=‘male‘
[string]$career
[nationality]$nationality
people($name,$age,$career,$nationalty){
$this.name=$name
$this.age=$age
$this.career=$career
$this.nationality=$nationalty
}
}
Enum nationality
{
 China = 1
 Japan = 2
 Australia = 3
 USA = 4
 Russia = 5
}
$user=[people]::new(‘zhangsan‘,22,‘receptionist‘,‘china‘)
$user
-------

name     age career       nationality
----     --- ------       -----------
zhangsan  22 receptionist       China

然后简单的看一下类的继承

继承关系通过:实现。

比如我创建一个子类 immigrant,继承people,子类里面可以定义新的属性

class immigrant : people
{
[nationality]$destination
}
$immi=New-Object immigrant -Property @{‘name‘=‘qq‘;‘age‘=30;‘career‘=‘dancer‘; ‘nationality‘=‘Japan‘;‘destination‘=‘USA‘}
$immi
------------
PS C:\Windows\system32> $immi
destination : USA
name        : qq
age         : 30
career      : dancer
nationality : Japan

最后把面向过程和面向对象做个简单的对比

首先是传统的方式,通过hash表转为自定义的对象,这种开发思路应该是面向过程的

Function Get-SystemInfo{
[cmdletbinding()]
param(
[string[]]$ComputerName
)
begin{}
process{
[email protected]()
foreach($computer in $ComputerName){
try{
write-verbose "Querying OS and Computer System"
$os=Get-WmiObject -Class win32_operatingsystem -ErrorAction Stop 
$cs=Get-WmiObject -Class win32_computersystem -ErrorAction Stop
}catch{
$computer |out-file c:\temp\error.txt -Append
}
[email protected]{ComputerName=$computer;LastBootTime=$os.ConvertToDateTime($os.LastBootUpTime);OSVersion=$os.Version;Manufacture=$cs.Manufacturer;Model=$cs.model}
$obj=New-Object -TypeName psobject -property $prop
$obj.psobject.typenames.insert(0,‘Yuan.systeminfo‘)
write-output $obj 
}
}
end {}
}
Get-SystemInfo -ComputerName sydav01

然后我用面向对象的思路也写了个同样的功能,创建类,类里面封装字段和方法,然后实例化

class sysinfo
{
[string] $model
[string] $computername
[string] $manufacture
[string] $lastboottime
[string] $osversion
getinfo($computername){
$os=Get-WmiObject -computername $computername -Class win32_operatingsystem -ErrorAction Stop 
$cs=Get-WmiObject -computername $computername -Class win32_computersystem -ErrorAction Stop
$this.LastBootTime=$os.ConvertToDateTime($os.LastBootUpTime);
$this.OSVersion=$os.Version;
$this.Manufacture=$cs.Manufacturer;
$this.Model=$cs.model
}
}
$obj=New-Object sysinfo 
$obj.computername=‘sydav01‘
$obj.getinfo($obj.computername)
$obj

他们的结果都是一样的

Model        : VMware7,1
ComputerName : sydav01
Manufacture  : VMware, Inc.
LastBootTime : 7/11/2016 10:03:56 AM
OSVersion    : 6.3.9600

豆子只是简单简简单单地了解了一下powershell 5 class的基本使用。类的三大特性,封装,继承和多态,Powershell 5具体实现了哪些特性还需要慢慢尝试。

时间: 2024-10-06 20:42:54

初识 Powershelgl 5.0 class的相关文章

初识vue 2.0(4):vuex组件通信

0,本来想只用vue就可以做项目了,后来发现不行:一个网页被切分成若干个组件,组件之间是需要数据传递的,因此引入了vuex这个集中式存储.管理的状态管理模式. 1,安装vuex: npm install --save vuex 在main.js中引入: import Vuex from 'vuex' Vue.use(Vuex) 2,创建数据源文件vuex/store.js import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) co

初识vue 2.0(3):Ajax请求

0,模拟ajax请求,需要构建web程序,使用express 方便快捷. 1,安装express 构建web server: npm install -g express npm install -g express-generator 2,创建 express 项目: express myserver cd myserver npm install 3,启动项目,一般情况下可以使用: npm start 但开发环境需要监控代码变动并自动重启进程,因此需要安装 supervisor. npm i

初识vue 2.0(12):使用$nextTick获取更新后的DOM

Vue 异步执行 DOM 更新. 只要观察到数据变化,Vue 将开启一个队列,并缓冲在同一事件循环中发生的所有数据改变. 如果同一个 watcher 被多次触发,只会被推入到队列中一次.这种在缓冲时去除重复数据对于避免不必要的计算和 DOM 操作上非常重要. 然后,在下一个的事件循环"tick"中,Vue 刷新队列并执行实际 (已去重的) 工作. Vue 在内部尝试对异步队列使用原生的 Promise.then 和 MessageChannel,如果执行环境不支持,会采用 setTim

初识QuartusII 9.0(破解,半加器的仿真,综合:下)

完成波形的随机设置(A,B任意给定高低电平即可,只是当作测试信号),选择任务栏Assignments[Setings],设置Simulation mode为functional,其余保持不变点击ok.点击进行编译,点击进行功能仿真,波形如下所示. 选择波形,查看Task栏目里RTL级,点击可以生成基于该波形的电路结构,通过查看该电路,验证verilog程序是否满足要求,若不满足,在打开.v文件修改保存再进行一系列的仿真,而不需要重新建立工程.若满足,选择任务栏Assignments[Seting

初识vue 2.0(2):路由与组件

1,在上一篇的创建工程中,使用的的模版 webpack-simple 只是创建了一个简单的demo,并没有组件和路由功能,此次采用了webpack模版,自动生成组件和路由.^_^ 在模版初始化时,因为ESLint语法检查过于严格,可以暂时不要开启. vue init webpack myapp ? Install vue-router? Yes ? Use ESLint to lint your code? No ? Setup unit tests with Karma + Mocha? Ye

初识vue 2.0(13):子组件使用watch监听父组件变化

子组件使用created或者mounted通常只能在组件初始化的时候,获取父组件传过来的props数据. 父组件props数据发生变化,子组件默认无法感知,因此需要手动实现子组件监听父组件变化的功能. 一般的值类型数据,可以直接使用watch监听: watch: { msg(newVal, oldVal){//对引用类型的值无效 console.info('value changed ', newVal) } } 引用类型,普通watch方法,无法监听到引用类型内部的变化. 解决此问题,可以在父

-----差分------

https://blog.csdn.net/qq_39670434/article/details/78454033 差分可以用来解决区间加问题.比如q次操作,每次操作输入两个数x,y;表示对区间[x,y]加上数k. 具体做法:维护一个数组tt[N]..tt[x]+=k,tt[y+1]-=k; 然后对tt数组求一下前缀和.tt[x]+=k表示的是从x(包括x)之后到y均加上k,而tt[y+1]-=k,表示的是加法到y+1处截止. 比如有10个数,初识值为0 0 0 0 0 0 0 0 0 0.对

鬃嘴释怀说太多就成真不了。

子阻撞砖奏尊仔籽着 释怀说太多就成真不了. http://passport.baidu.com/?business&un=vip&un=%E5%A4%A9%E6%B0%B4%E4%B8%8A%E9%97%A8%E8%BF%99%E5%B0%8F%E5%A7%90#0 http://passport.baidu.com/?business&un=vip&un=%E7%99%BD%E9%93%B6%E4%B8%8A%E9%97%A8%E8%BF%99%E5%B0%8F%E5%A

澜星粘鼐贩逊耐盼系甭妊倏纪傲傲sdfghjk

http://passport.baidu.com/?business&un=R&un=%E5%A4%A7%E5%AE%81%E6%A1%91%E6%8B%BF%E9%80%9A%E5%B0%8F%E5%A7%90#0 http://passport.baidu.com/?business&un=R&un=%E4%B9%A1%E5%AE%81%E6%A1%91%E6%8B%BF%E9%80%9A%E5%B0%8F%E5%A7%90#0 http://passport.bai