9.1.2 Sub 过程的调用[共2页]
VB过程及其调用
VB过程及其调用VB(Visual Basic,简称VB)是一种基于事件驱动编程的程序设计语言,是Microsoft公司开发的一种高级程序设计语言,常被用于Windows操作系统的应用程序开发。
VB中的过程指的是一系列语句的集合,用于完成特定的任务。
本文将介绍VB中的过程及其调用。
1.过程的定义在VB中,过程可以分为两种类型:Sub过程和Function过程。
Sub过程用于执行一系列操作,没有返回值;而Function过程则返回一个值。
Sub过程的定义格式如下:Sub 过程名(参数列表)'过程主体End SubFunction过程的定义格式如下:Function 过程名(参数列表) As 返回值类型'过程主体End Function其中,参数列表可以包含零个或多个参数,每个参数包含两部分:参数名和参数类型。
返回值类型指的是Function过程的返回值类型,可以是任意VB数据类型。
2.过程的调用在VB中,可以通过过程的名称和参数列表来调用过程。
调用过程时,可以传递参数给过程,如果过程需要返回值,可以将结果保存到一个变量中。
调用Sub过程的语法格式如下:过程名参数列表调用Function过程的语法格式如下:变量名=过程名(参数列表)以下是一个使用Sub过程和Function过程的示例:Sub SayHello(name As String)MsgBox("Hello, " & name & "!")End SubFunction Multiply(a As Integer, b As Integer) As IntegerMultiply = a * bEnd Function调用上述过程的示例代码如下:SayHello("John") '调用Sub过程,显示对话框,输出"Hello,John!"result = Multiply(5, 6) '调用Function过程,将结果保存到变量result中,result的值为303.过程的参数传递在调用过程时,可以传递参数给过程。
计算机组成原理sub指令
计算机组成原理sub指令一、引言计算机指令是计算机执行各种操作的核心,而sub指令是计算机指令系统中的一种基本指令,用于执行减法运算。
sub指令在计算机组成原理中占据着重要的地位,它不仅在数据传送、算数运算、逻辑运算等方面有着广泛的应用,而且在控制流程、地址计算等方面也发挥着重要的作用。
二、sub指令的功能与实现sub指令的功能是将两个操作数相减,并将结果存储在一个寄存器中。
在实现上,sub指令通常采用加法器来实现减法运算,即将第一个操作数加负第二个操作数来实现减法。
如果两个操作数相减的结果为正数,则表示被减数大于减数,结果存储在寄存器中;如果结果为负数,则表示被减数小于减数,需要继续执行减法操作,直到结果为正数为止。
三、sub指令的应用sub指令在计算机组成原理中有着广泛的应用。
首先,它可以用于算术运算中,例如加减法运算、比较大小等。
其次,它可以用于逻辑运算中,例如判断两个数值之间的关系等。
此外,sub指令还可以用于控制流程中,例如跳转、循环等操作。
最后,sub指令还可以用于地址计算中,例如计算内存地址等。
四、sub指令的执行过程sub指令的执行过程可以分为以下几个步骤:1.取指阶段:从内存中读取指令和操作数数据;2.译码阶段:对指令进行译码,确定指令的操作和操作数;3.执行阶段:根据译码结果执行sub指令,将两个操作数相减并将结果存储在寄存器中;4.送回阶段:将结果返回给程序计数器或寄存器等。
五、sub指令的优化为了提高计算机的性能和效率,可以对sub指令进行优化。
例如,可以采用流水线技术来减少指令之间的等待时间;可以采用乱序执行技术来提高指令执行的顺序性;可以采用分支预测技术来减少分支跳转的时间和次数等。
六、总结sub指令是计算机组成原理中的基本指令之一,它在数据传送、算数运算、逻辑运算、控制流程、地址计算等方面有着广泛的应用。
通过对sub指令的学习和理解,可以更好地了解计算机的工作原理和性能优化方法。
第九章 Access的编程语言VBA
… [Else
<语句组n+1>] End If
例9_5输入文本框中三个数,单击“排序” 按钮后,三个数按由大到小的顺序排列。 单击“重新输入”按钮后,清空文本框, 以便于重新输入。
Select Case语句(情况语句)
Select Case <表达式> Case 值1 语句组1 Case 值2 语句组2
If…Then…If…Then…Else…Else… 在VBA中规定,每一个Else与在它前面的、距
离最近的且没有被匹配过的If…Then配对。
块if语句 格式一:
If <条件> Then <语句组1>
Else <语句组2>
End If
格式二: If <条件1> Then
<语句组1> Elseif <条件2> Then
– 随机文件:每一条记录的长度是固定的,随 机文件中每一条记录都具有一个记录号。在 读取文件时,就可以直接访问文件中的某一 条记录。
VBA中对文件操作的语句
– 打开文件 Open “文件名” [For 模式] As [#]文件号
[Len=记录长度] – 格式:
OUTPUT:写操作
INPUT:读操作 APPEND:追加到文件未尾 Random:指定随机存取方式,也是默认方式 Binary:指定二进制方式
– 运算符是表示实现某种运算的符号。VB中的 运算符可分为:算术运算符、关系运算符、 逻辑运算符、字符串连接运算符和对象运算 符。
– 通过运算符和操作数组合成表达式,实现程 序编制中所需的大量操作。
算术运算符
关系运算符
逻辑运算符
sub口的用法
sub口的用法一、sub口的定义和作用sub口是计算机网络中的一个术语,指的是子接口(subinterface)或子网接口(subnet interface)。
它是在物理接口上划分的逻辑接口,用于在一个物理接口上划分多个逻辑网络。
sub口的作用是将一个物理接口划分为多个虚拟接口,每个虚拟接口可以与不同的子网进行通信,实现网络的分段管理。
二、sub口的配置方法1. 配置子接口在路由器或交换机上配置子接口,需要使用命令行界面(CLI)或者网络管理软件进行配置。
下面以Cisco设备为例,介绍子接口的配置方法。
首先,进入全局配置模式,输入命令:configure terminal然后,选择要配置的物理接口,输入命令:interface GigabitEthernet 0/0接着,创建子接口,并指定子接口的编号和虚拟局域网(VLAN)标识,输入命令:interface GigabitEthernet 0/0.1encapsulation dot1q 10以上命令中,“GigabitEthernet 0/0.1”表示物理接口GigabitEthernet 0/0的子接口1,“encapsulation dot1q 10”表示子接口使用802.1q协议进行封装,VLAN标识为10。
2. 配置子网配置子接口后,需要为每个子接口配置IP地址和子网掩码,以及其他必要的网络参数。
下面是配置子网的示例命令:interface GigabitEthernet 0/0.1ip address 192.168.1.1 255.255.255.0以上命令中,“ip address 192.168.1.1 255.255.255.0”表示为子接口GigabitEthernet 0/0.1配置IP地址为192.168.1.1,子网掩码为255.255.255.0。
3. 配置路由配置完子接口和子网后,还需要配置路由,使得不同的子网可以相互通信。
过程调用详解
过程调用详解过程调用是计算机中常见的一种操作,它通常用于调用函数或子程序。
在程序执行过程中,当需要调用某个函数或子程序时,程序会通过过程调用的方式将控制权转移到被调用的函数或子程序中,等待其执行完毕后再返回结果。
过程调用的实现涉及到许多细节,包括参数传递、栈操作、返回值获取等,本文将对这些细节进行详解。
一、参数传递在过程调用中,参数传递是必不可少的一环。
按照不同的编程语言和编译器,参数传递的方式也有所不同。
常见的有以下几种:1. 值传递:将实参的值复制到形参中,函数内部对形参的操作不会影响实参。
2. 引用传递:传递的是实参的地址,函数内部对形参的操作会影响实参。
3. 指针传递:传递的是指向实参内存地址的指针,函数内部通过指针访问实参的值。
4. 寄存器传递:将实参的值存放在寄存器中,通过寄存器传递参数。
这种方式通常用于参数数量较少的情况下。
二、栈操作在过程调用中,栈是一个重要的数据结构。
在调用过程中,栈用于存储函数的返回地址、参数和局部变量等信息。
常见的栈操作包括以下几种:1. 压栈:将数据压入栈中,通常用于保存函数的返回地址、参数和局部变量等信息。
2. 弹栈:将栈顶的数据弹出栈,通常用于恢复函数的返回地址、参数和局部变量等信息。
3. 栈平衡:在函数调用结束后,需要将函数调用过程中压入栈中的数据全部弹出,以保证栈的平衡。
三、返回值获取在函数执行完毕后,需要将返回值传回到调用者处。
常见的返回值获取方式包括以下几种:1. 寄存器返回:将返回值存放在寄存器中,调用者通过寄存器获取返回值。
2. 栈返回:将返回值压入栈中,调用者通过弹栈获取返回值。
3. 寄存器+栈返回:将返回值同时存放在寄存器和栈中,调用者可以通过寄存器或弹栈获取返回值。
总之,过程调用涉及到众多细节,包括参数传递、栈操作、返回值获取等,只有了解这些细节,才能编写出高效、稳定的代码。
vb过程
9.3.4
数组参数的传送
Visual Basic允许把数组作为实参传送到过程中。如定义: Sub S(a(),b()) …… End Sub 可以用下面的语句调用该过程: Call S(a(),b())
数组参数一般通过传地址方式传送。在传送数组时,除遵 守参数传送的一般规则外,还应注意以下几点: (1)为了把一个数组的全部元素传送给一个过程,应将 数组名分别放入实参表和形参表中,并略去数组的上下界, 但括号不能省略。 (2)如果不需要把整个数组传给通用过程,可以只传送 指定的单个元素,这需要在数组名后面的括号中写上指定 元素的下标。例如:
全国计算机等级考试二级教程
主讲教师
潘大胜
结构化程序设计思想的要点之一就是对一个 复杂的问题采用模块化,把一个较大的程序划 分为若干个模块,每个模块只完成一个或若干 个功能。这些模块通过执行一系列的语句来完 成一个特定的操作过程,因此被称为“过程”。
9.1 9.3 9.4 9.5 9.7
Sub过程 参数传送
9.2.1
建立Function过程
1.定义Sub过程
Static|Private|Public Function <过程名>[ (参数列表) ] [As 类型]
[<语句组>]
[过程名=表达式] [Exit Function] [<语句组>] End Function
说明: (1)Function过程以Function开头,以End Function结束, 在两者之间是描述过程操作的语句块,即“过程体”或 “函数体”。格式中的“过程名”、“参数表列”、 “Static”、“Private”、“Public”、“Exit Function”的 含义与Sub过程相同。“As 类型”是Function过程返回 值的数据类型,可以是Integer、Long、Single、Double、 Currency或String,如果省略,则为Variant。
Sub过程的编写示例
Sub过程的编写示例
【例1】编写计算n! 的Sub过程。
分析:在使用函数过程求n!的示例中,阶乘值由函数名返回,因此只需设置一个参数n,如果改成用Sub过程实现,由于Sub过程名不能返回值,所以需要在形参表中引入另一个参数来返回阶乘值。
Sub Fact(N As Integer, F As Long) ' 参数F用于返回阶乘值
Dim I As Integer
F = 1
For I = 1 To N
F = F * I
Next I
End Sub
【例2】编写Sub过程,打印以下图形。
*
***
*****
*******
*********
分析:打印以上图形,不需要返回值,因此可以用Sub过程实现,该过程也无需引入参数。
Sub a()
For I = 1 To 5
Print Tab(6 - I);
For J = 1 To 2 * I - 1
Print "*";
Next J
Print
Next I
End Sub
【例3】编写Sub过程,求三个数中的最大数和最小数。
分析:首先要设置三个参数,如x、y、z,用于接收三个原始数据,另外引入两个参数max和min,用于返回最大和最小数。
Sub s(x, y, z, max, min)
max = x
min = x
If y > max Then max = y If y < min Then min = y If z > max Then max = z If z < min Then min = z End Sub。
第9章 w过程
Visual Basic 程 序 设 计
t=x : x=y : y=t
End Sub
主调过程定义如下: Private Sub Form_click()
Visual Basic 程 序 设 计
Dim a%,b% A=10:B=20 Call Swap(a,b) „ 第一种调用方法
Swap a,b
„ 第二种调用方法
例9.3求C106。
分析: C106=10!/(6!*4!)
Visual Basic 程 序 设 计
Private SUB FAC(N As Single, P As Single )
P=1 FOR I=1 TO N P=P*I NEXT I END sub Private Sub Form_Click() Call FAC (10,P1) Call FAC (4,P2) Call FAC (6,P3) 传递参数 C=P1/P2/P3 调用过程 PRINT “C106 =”;C End Sub 形参、实参。虚实结合
9.2.2. 函数过程的调用 函数过程的调用方法同前面大量使用的标准函数调用方法 相同,调用形式如下: <变量名>=函数过程名([参数列表])
Visual Basic
由于函数过程名返回一个值,故函数过程不能作为单独的 语句加以调用,必须作为表达式或表达式中的一部分。再 程 配以其他的语法成份构成语句。 序 设 调用函数时需要注意的地方可参考子程序过程调用的有关 计 说明。 例9.3 定义一个函数过程,用碾转相除法求两个整数m和n 的最大公约数。 函数过程定义如下:
End Function
主调过程定义如下: Private Sub Form_Click()
Visห้องสมุดไป่ตู้al Basic 程 序 设 计
vba编程里面的sub的用法(一)
vba编程里面的sub的用法(一)VBA编程里面的Sub1. 什么是Sub在VBA编程中,Sub是一种用于定义子程序的关键字。
它可以理解为一个独立的代码块,可以在程序中被调用执行。
Sub是Visual Basic for Applications(VBA)中用于创建宏和自定义函数的主要组件之一。
2. Sub的基本语法Sub语句的基本语法为:Sub SubName()' 执行的代码块End Sub其中,SubName代表子程序的名称,可以根据需要自定义。
代码块部分是Sub子程序要执行的具体操作。
3. Sub的调用方式在编写一个Sub子程序后,可以通过不同的方式进行调用。
下面是几种常见的调用方式:直接调用在主程序中,可以直接使用子程序名称调用Sub:Sub MainProgram()' 主程序的代码块SubName ' 直接调用Sub' 其他逻辑代码End Sub使用参数进行调用可以在Sub子程序中定义参数,以便在调用时传递参数值。
Sub MainProgram()' 主程序的代码块Dim var1, var2 As Integervar1 = 10var2 = 20SubName var1, var2 ' 使用参数调用Sub' 其他逻辑代码End SubSub SubName(num1 As Integer, num2 As Integer)' 执行的代码块Dim result As Integerresult = num1 + num2MsgBox "结果为:" & resultEnd Sub在上述例子中,使用var1和var2作为参数传递给Sub子程序,在子程序中执行操作后,通过MsgBox显示结果。
使用返回值进行调用Sub子程序本身不具有返回值。
如果需要得到子程序的执行结果,可以使用ByRef进行参数传递。
过程和子过程的定义和调用方法
过程和子过程的定义和调用方法在计算机科学中,过程(procedure)指的是一系列指令的集合,他们按照指定的顺序来执行特定的任务。
而子过程(subprocedure)则是一种更为复杂的过程,通过将任务划分为更小的组件来提高代码的可读性和可维护性。
本文将详细介绍过程和子过程的定义和调用方法。
首先,让我们来了解过程的概念。
过程是一段可重用的代码块,用于执行特定的任务。
它可以接受输入参数并返回输出结果。
过程的定义通常包括以下几个要素:1.过程名称:过程的名字用来唯一标识它,在调用过程时需要使用该名称。
2.输入参数列表:代表过程接受的输入数据。
参数可以有多个,并且可以有不同的数据类型。
3.输出参数列表:代表过程返回的输出数据。
过程可以返回多个输出参数,并且可以有不同的数据类型。
4.过程体:具体的指令集合,用于实现特定的任务逻辑。
下面是一个示例过程的定义:```procedure add(x, y)return x + yend```这个过程名为"add",接受两个参数x和y,并返回它们的和。
在调用过程时,可以像下面这样传递参数并接收返回值:```result = add(3, 4)print(result) // 输出结果为7```接下来,我们来了解子过程的概念。
子过程是一种更为复杂的过程,它将任务划分为更小的组件,从而提供重用性和模块化的优势。
子过程通常用于解决复杂的问题,其中每个子过程负责解决一个相对简单的子问题。
子过程可以嵌套调用,从而形成更复杂的函数组合。
子过程的定义和调用方法与过程相似,只是在过程体中可以调用其他子过程。
下面是一个示例子过程的定义:```subprocedure gcd(a, b)if b == 0 thenreturn aelsereturn gcd(b, a % b)endend```这个子过程名为"gcd",用于计算两个数的最大公约数。
Sub过程
End Sub
Private Sub Form_Load()
End Sub
Private Static Sub mySub2() '模块级过程 Dim x As Integer 'x为静态变量
Sub subA(y As Integer) X = 0 '本过程级变量,未经显式声明 Print y 'y的值来自父过程中的实参
End Sub
Visual Basic 程序设
计
Sub过程
Sub mySub1(m As Integer, n As Integer) Print m, n
End Sub Private Sub Form_Load()
Call mySub1(1, 3) '过程中的形参m=1,n=3 mySub1 1, 3 Call mySub2 'VB将后面的空括号自动去掉 mySub2 End Sub Private Static Sub mySub2() Call Form_Load '调用窗体的Load事件过程 Form_Load End Sub
Sub过程
Sub过程也称子过程,是指以规定语法结构组织的、 可以被重复调用的、具有特定功能的相对独立的语句 块。 一、声明Sub过程
[Private|Public][Static] Sub 过程名([形式参数]) 过程体
End Sub 其中,Public声明全局过程,Private声明模块级过 程,默认为Public。 Static表明本过程中所有过程级变量均为静态。 使用Exit Sub语句可以使程序从Sub过程中退出。
plc的sub指令用法
plc的sub指令用法PLC(可编程逻辑控制器)是一种广泛应用于工业自动化领域的计算机设备,它通过执行一系列的指令来控制各种机械设备和生产过程。
在PLC编程中,Sub指令是一种常用的子程序指令,它允许将常用的程序段封装成一个独立的子程序,以便在需要时重复调用。
本文将介绍Sub指令的用法、优点、注意事项以及应用案例。
一、Sub指令的用法Sub指令用于创建一个子程序,也称为子程序块或函数/过程块。
子程序可以包含一系列的指令,用于完成特定的任务。
当调用子程序时,PLC会执行子程序中的指令,并返回一个结果。
如果子程序中有需要返回结果的指令,则需要在子程序末尾添加Return指令。
Sub指令的使用步骤如下:1. 编写子程序:首先,需要编写子程序的代码,包括指令、逻辑和变量等。
2. 保存子程序:将子程序保存到PLC中,以便后续调用。
3. 调用子程序:在主程序中需要使用子程序的地方,使用Call Sub指令来调用子程序。
4. 等待子程序执行结果:在调用子程序后,需要等待子程序执行完毕,并获取其返回结果。
二、Sub指令的优点Sub指令具有以下优点:1. 提高了编程效率:将常用的程序段封装成子程序,可以减少重复编写代码的工作量,提高编程效率。
2. 提高了可读性和可维护性:将复杂的程序分解成多个子程序,可以使程序结构更加清晰,便于维护和调试。
3. 增强了可扩展性:通过使用Sub指令,可以将一些常用的功能封装成独立的子程序,方便后续扩展和修改。
三、Sub指令的注意事项在使用Sub指令时,需要注意以下几点:1. 参数传递:在调用子程序时,需要传递参数。
需要注意参数的类型和数量,以确保子程序的正确执行。
2. 错误处理:在子程序中需要添加适当的错误处理机制,以避免出现异常情况。
3. 避免死循环:在子程序中需要合理控制循环次数,以避免出现死循环或资源占用过多的问题。
4. 避免重复操作:在子程序中需要避免对同一变量或设备进行重复操作,以避免对系统造成不必要的负担。
selection change 调用sub 过程
主题:selection change 调用sub 过程随着技术的不断发展,各种编程语言也在不断更新和完善。
在各种编程语言中,VBA(Visual Basic for Applications)作为一种宏语言,被广泛应用于Microsoft Office软件的自动化操作中。
在VBA中,常常会需要根据文档或表格中的选定内容的变化来触发一些特定的操作。
在这种情况下,可以通过selection change 事件来调用sub 过程,实现对选定内容变化的响应。
一、selection change 事件的概念和作用1.1 selection change 事件的定义selection change 事件是VBA中一个重要的事件,它的作用是在用户更改所选内容时触发相应的操作。
在Microsoft Office软件中,用户可以通过鼠标或键盘来选择文档或表格中的内容,当所选内容发生变化时,selection change 事件会被自动触发。
1.2 selection change 事件的作用selection change 事件可以用于实现对选定内容变化的监控和响应。
通过捕捉selection change 事件,可以及时发现用户对文档或表格中的所选内容进行了何种操作,并进行相应的处理。
二、调用sub 过程实现对selection change 事件的响应2.1 sub 过程的定义sub 过程是VBA中的一种子过程,它用于执行特定的操作。
在处理selection change 事件时,可以编写相应的sub 过程来实现对选定内容变化的响应。
2.2 调用sub 过程实现对selection change 事件的响应在VBA中,可以通过在文档或工作表的代码模块中编写相应的sub 过程,并将其与selection change 事件进行关联,以实现对选定内容变化的响应。
当用户更改选定内容时,selection change 事件会被触发,从而调用相应的sub 过程来执行特定的操作。
第9章 Sub过程
第9章Sub过程第9章Sub过程VBA应用程序是由过程组成的,使用Excel VBA开发应用程序就是在编写过程。
前面各章中已经多次使用到过程。
9.1 过程的分类过程是指由一组完成指定任务的VBA语句组成的代码集合。
在VBA中,可执行的代码都必须放置在过程中。
VBA中的过程可分为事件过程、属性过程和通用过程。
1. 事件过程事件过程是当发生某个事件(如单击、双击)时,对该事件做出响应的程序段。
事件过程位于对象所在模块中,例如有关工作簿的事件代码放置在ThisWorkbook对象的代码模块中。
在打开工作簿时将调用的程序代码可放置在Workbook对象的Open事件中,如图9-1所示。
2. 属性过程在“类模块”中设置类的属性值时,可通过“属性过程”来完成。
3. 通用过程有时在不同的事件过程中需要执行一段相同的代码,可以把这段代码独立出来,作为一个过程,这样的过程称为“通用过程”。
在VBA中,通用过程又分为两类:Sub(子程序)过程和Function(函数)过程。
●Sub过程:这类过程完成指定任务,执行结束后不返回值。
●Function过程:这类过程完成指定的任务,并返回一个值供调用程序使用。
一般通用过程保存在VBA的“模块”中,一个模块可以包含任意数量的过程,同时,一个VBA工程可以包括任意多个模块。
9.2 定义Sub过程在使用之前,需要先在模块中定义过程。
VBA中有两种定义过程的方法:一种方法是使用窗体创建过程的结构,再在过程中编写相应的代码;另一种方法是在模块中直接输入代码来定义过程。
】9.2.1 添加过程通用过程一般保存在模块中,在创建过程前可先通过选择“插入”ㄧ“模块”命令向工程中添加一个模块。
VBA开发环境中提供了一个“添加过程”对话框,通过该对话框可方便地向当前模块中添加过程。
具体操作步骤如下。
步骤1 在VBE环境中选择“插入”ㄧ“过程”命令,打开如图9-2所示的“添加过程”对话框。
使用图9-2所示对话框除了可以插入一个新的Sub过程、Function过程或属性过程,还可以设置Public或Private有效范围,并使得过程中所有的局部变量成为静态变量。
VB过程及其调用
事件过程
事件过程:事件过程为响应由用
户操作或程序中的引发的事件而 执行的SUB 过程,它附加在窗体 和事件上!
1:事件过程
事件过程的格式: private|public sub 控件名_事件名(参数列表) <语句组> End Sub
eg:private sub command_click()(点击事件) print "hello" End Sub
过程
过程
VB程序是由过程组成的,每个过程是为了完成一定
的任务,由一组独立的程序代码组成。
VB分为两类过程
1:事件过程
2:通用过程
过
通用过程
程 事件过程
拓展:
Val函数
变量的作用域 自定义sub
过程和function过程,能
够根据需要自由调用两个 过程!
2:自定义sub过程
说明: (1)public和private表明SUB过程的有效范围, public的有效范围是整个工程,private的有效范围是 当前模块,默认为private
(2)过程必须以End SUB 结束
(3)exit sub可以强制退出过程
(4)VB 中所有过程都是并列关系,不允许在一个 过程内部定义 另外一个过程,即不能嵌套定义
• 1:过程变量 • 2:模块级变量 • 3:全局变量
变量的作用域
1:过程变量
•过程变量也称为局部变量,过程变量在过程内部用 dim或者static关键字申明,只能在过程内部使用!
public sub song()
dim liang as double '过程变量 (相当于方法体内部定义的变量)
end sub
2:模块级变量
Excelprivatesub私有过程使用介绍
Excelprivatesub私有过程使用介绍第一,认识private sub和sub过程 Excel VBA里,我们会接触到private sub私有过程和sub过程。
前者private sub是私有过程,sub是公共过程。
过程也有私有和公共之分。
想把一个过程声明为公共过程,使用:Public Sub 过程名;其中的Public就是公共过程的标识牌。
如果想声明为私有过程,则:Private Sub 过程名;其中的Private就是私有过程的标识牌。
如果省略前面的Public,只写sub 过程名,就是公共过程。
第二,private sub和sub过程的区别 private sub和sub过程有什么区别呢?VBA的过程主要包括sub过程和function过程两种。
sub过程不可以返回值,function过程可以返回值。
比如我们经常录制的宏就是一个简单的sub 过程,使用录制宏功能只能生成sub过程的代码。
private sub 和sub过程都是在模块中使用。
下面我们具体看看private sub私有过程和sub过程的使用和区别。
Private Sub与Sub的区别是什么?完整地说,应该是Private Sub与Public Sub的区别是什么。
(Sub 实际上是省略了Public关键字)。
Sub过程:在一程序内执行特殊任务的过程,不返回显式值。
Sub 过程以Sub 语句开头,以End Sub 语句结尾。
Sub 语句主要是声明子过程的名称、参数、以及构成其主体的代码。
其语法如下:[Private | Public | Friend] [Static] Sub name [(arglist)][statements][Exit Sub][statements]End Sub注:[]中间的参数表示可选。
可以不输入,则按默认设置进行。
Sub 语句的各部分详述如下: Private:可选的。
表示只有在包含其声明的模块中的其它过程可以访问该 Sub 过程。
第9章ADAMS用户子程序-(陈立平)机械系统动力学分析及ADAMS应用
第9章ADAMS用户子程序本章对ADAMS用户子程序做了简要介绍,着重介绍了CONSUB、GFOSUB和REQSUB的使用方法,以及在用户子程序中两个最常用的功能子程序SYSARY和SYSFNC的使用情况。
通过本章的学习,读者将具备基本的开发用户子程序的能力。
9.1 ADAMS用户子程序简介一般情况下,ADAMS的大部分功能可以通过函数表达式完成,函数表达式很容易操作,因为不必编译或连接程序,而且ADAMS/Solver还会实时地提供函数表达式。
但函数表达式提供的只是有限的编程结构,因此有些复杂的情况,特别是涉及到一些逻辑表达,用函数表达式则很难表达出来。
因此在需要采用一些ADAMS没有提供的特殊函数时,可以采用用户子程序。
用户子程序更具有通用性,可以利用编程语言来定义模型元素或者特定的输出。
用户可以将函数表达式写成子程序的形式并将其与ADAMS/Vi ew连接,它具有函数表达式所没有的通用性和灵活性。
子程序利用通用程序设计语言(FORTRAN或C)的功能来定义ADAMS/View不能提供的函数,并使之按照需要而量身设计。
通过连接用户子程序,不会失去ADAMS/View的任何功效,也不会降低仿真速度。
当出现下列情况时,通常会使用到用户子程序:(1)数学函数很难表达。
(2)需要定义多用户使用的函数。
(3)GSE和UCON声明时,需要用户子程序。
(4)需要控制复杂仿真运行时,以及需要作决策逻辑时。
使用用户子程序时要小心,因为不正确的用户子程序会很难调试。
9.1.1用户子程序的种类根据用户子程序的功能,可以将它们分为三类:(1)DriverSubroutine——驱动子程序(2)Evaluation Subroutines——计算子程序(3)Restart subroutines——重启子程序1.驱动子程序(Driver Subroutine)驱动子程序(DriverSubroutine)--CONSUB--用来驱动ADAMS/Solver。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
159 例如:Sub Sum(x%, y%, s%)
s = x + y
Print "两个数的和为:"; s
End Sub
该过程中有3个形参,调用该过程可以实现两数之和的计算和输出。
子过程可以带参数,也可以不带参数。
没有参数的过程称为无参过程。
例如:Sub Mysub ( )
Print "Visual Basic! "
End Sub
(3)[Exit Sub]为可选项,表示中途退出子过程。
(4)[Private|Public|Static]的含义将在9.4节介绍。
9.1.2 Sub 过程的调用
要执行过程中的代码,必须通过正确的方式调用过程。
调用Sub 过程有以下两种方式。
1.利用Call 语句
格式:Call 过程名([参数列表])
例如:Call Sum(a,b,c)
Call Mysub( )
(1)参数列表中包含的实参,代表在调用时要传递给Sub 过程的参数值,它必须与
形参在个数、顺序、数据类型上保持一致。
(2)调用时把实参的值传递给形参称为参数传递。
传递方式分为两种。
① 当形参前有Byval 说明时,进行的是值传递,实参值不随形参值的改变而改变。
② 当形参前没有Byval 说明时,进行的是地址传递,实参值随形参值的改变而改变,
参数传递部分将在9.3节详细介绍。
(3)当参数是数组时,形参数组在参数声明时应省略其维数,但括号不能省。
2.把过程名作为一个语句来使用
格式:过程名[参数列表]
例如:Sum a,b,c
Mysub
与第一种调用方式相比,省略了关键字Call,去掉了“参数列表”的括号。
子过程可以被多次调用,图9-3是一个过程调用的示例。
调用过程(主调过程)在执行过程中,首先遇到Call Sum(a,b,c)语句,于是转到子过程Sum (被调过程)的入口处去执行。
执行完子过程Sum 后,返回到调用过程的调用语句处继续执行后面的语句。
执行过程中遇到Sum a,b,c 语句,于是再次转到子过程Sum 去执行,执行完返回调用处继续执行其后的语句。
同样,遇到Call Mysub( )语句时,转到子过程Mysub (被调过程)去执。