Visual Basic编程规范

visual|编程|规范

Visual Basic编程规范

1.      Visual Basic IDE(集成开发环境)设置

       必须打开设置选项的“要求变量声明”,“对齐控件到网格”,“自动缩进”开关。        Tab的宽度统一为4个空格,网格单位一律设为:width 60 height 60。

2.     命名约定

       (注意:在任何时候,不能使用中文及全角字符,只允许使用英文字母、下划线和数字)

2.1          工程的命名

       ActiveX控件和DLL工程命名格式为(….Lib),EXE工程直接命名,如果是通用组件工程,直接命名,如果是项目或产品工程,则使用项目或产品缩写作为前缀。如:XWY….Lib。        工程命名不必缩写,为了表达意思和用途,可以尽可能地长,而且命名格式采用 (名词) 、 (形容词 + 名词) 或 (名词 + 动作的名词形式)。如: StockOperationLib或StockLib。

2.2          变量的命名

    程序中的变量遵循匈牙利表示法,即“前缀+变量含义”,变量的含义为一个或多个英文单词,每个单词的第一个字母大写。变量前缀为三个小写字母示意其类型,所需添加的前缀遵循微软在MSDN中的建议。列表如下:   对于一般的计数器变量定义,应该尽可能地简单,如:Dim i As IntegerFor i = 0 to 100Next i范围标识:
              全局变量加前缀:’g_’ 例如:g_strFdbm

              模块级变量加前缀:’m_’ 例如:m_strFdbm

              过程级变量不加前缀        全局变量和模块级变量应该尽量使用全名称,不推荐使用缩写,如:gEntityManager常见的变量类型和控件类型前缀如下表所示:变量类型前缀列表

数据类型

前缀

示例

Boolean

bln

blnLoggedIn

Currency

cur

curSalary

Control

ctl

ctlLastControl

Double

dbl

dblMiles

ErrObject

err

errLastError

Single

sng

sngYears

Handle

hwd

hwdPicture

Long

lng

lngOnHand

Object

obj

objUserTable

Integer

int

intAge

String

str

strName

User-defined type

udt

udtEmployee

Variant (including Dates)

vnt

vntDateHired

Array

arr

arrEmployees 数据库对象前缀示例Database

dbs

dbsAccounts Recordset

rec

recForecast command

cmd

cmdQuery connection

con

conSql

 

 

 

2.3          控件的命名

       控件命名一律使用控件类型缩写+控件用途的命名方式,缩写规则同变量命名,以下是常用控件的类型缩写,应该严格遵守。如果使用了新的控件(包括升级版本),必须向公司提出申请,经评审通过后,协同一致其类型名称缩写,再进行使用。 控件类型前缀列表

控件

前缀

举例

ADO Data

ado

adoBiblio

Animated button

ani

aniMailBox

Checkbox

chk

chkPrint

Combo box

cbo

cboTitle

Command button

cmd

cmdCancel

Communications

com

comFax

Data

dat

datBiblio

Data-bound combo box

dbcbo

dbcboLanguage

Data-bound grid

dbgrd

dbgrdQueryResult

Common dialog control

dlg

dlgCommon

Control

ctr

ctrCurrent

Directory list box

dir

dirSource

Drive list box

drv

drvTarget

DTPicker       DropDateControl

dt

 

EnumEditBox

enm

 

File list box

fil

filSource

Frame

fra

fraLanguage

Form

frm

frmMain

Vfgrid

grd

 

Graph

gra

 

Group push button

gpb

gpbChannel

Hierarchical flexgrid

flex

flexOrders

Horizontal scroll bar

hsb

hsbVolume

Image

img

imgIcon

Image ImageList

img

 

Label

lbl

lblHelpMessage

Line

lin

linVertical

List box

lst

lstResultCodes

ListView

lv

 

MCI

mci

mciVideo

MDI child form

mdi

mdiContact

Menu control

mnu

mnuFileOpen

NumEditBox

nm

 

OLE container

ole

olePhoto

Option button

opt

optSpanish

Panel

pnl

pnlSettings

Picture box

pic

PicDiskSpace

Picture clip

clp

ClpToolbar

ProgressBar

prg

prgLoadFile

Report

rpt

 

Scroll bar

sbr

 

Shape

shp

ShpCircle

Slider

sld

sldScale

Spin

spn

 

StatusBar

st

 

ToolBar

tb

 

Text box

txt

TxtAddress

Timer

tmr

TmrAlarm

TreeView

tv

tvFlbm

Vertical scroll bar

vsb

vsbRate

 

 

 

 

2.4          函数和过程的命名

       此处函数包括sub和function,以下这两种过程统称为函数。        函数表示的是一个动作,所以它的结构应该是 动词+名词,动词必须小写,后面的名称首字母大写,如:getMaterialCodeupdateGridreadOrder       函数命名尽量不要使用缩写,而且它的名称应该使人一目了然,能够从名称就知道这个函数的功能,不要使用无意义的函数名称,如:getCode,update,readData。       当函数名称不足以表达其功能时,使用在函数头部加上让调用者足够明白的注释。       参数的命名:参数命名的原则是全部小写,如果参数包括两个或以上的单词时,首单词字母小写,其它单词首字母大写,如showCol、isUpdate。

2.5          常量的命名

       常量的命名应该全部大写,使用‘_’作为单词间的分隔符,单词尽量使用全名称,如:        Public Const MSG_EMPTY_ROW As String = “有空行存在!”       解释:(1)  对一些常用词应该使用简写,如MSG(2)  使用Public来声明常量(3)  对常量的声明必须带上类型,如上面的As String

2.6          属性的命名

       属性的命名采用首字母大写的原则,如ItemCount Item

2.7          类、窗体和模块的命名

       类的命名:Cls前缀+功能名词,并且单词首字母大写。如:ClsSystemConfig        窗体命名:使用Frm前缀+功能名词,并且单词首字母大写。如:FrmList。        模块命名:Mod前缀+功能名词,并且单词首字母大写。如ModList。以上三种命名在一个项目内必须保持唯一。

2.8          自定义控件的命名

       自定义控件的命名:名词 + Ctrl 如:EditGridCtrl

3.     书写格式约定

3.1          定义

       定义的代码块应该放在一起,不要在中间定义变量,变量的定义应该顶行进齐,不能缩进。
如下: Dim i As IntegerDim j As IntegerDim em As EntityManager       对象的定义应该尽可能地带上所属的库名称,防止以后引起名称冲突,如引用了两个Lib,每个中都包含一个stock类,如果不使用As ….Lib.Stock的定义方式,则无法编译通过,为了防止以后程序扩充和修改时引入新的库带来命名冲突,推荐在定义类对象时全部加上库标识,如:       Dim em As ObjectPersistenceLib.EntityManager

3.2          空行

       空行是区分代码块与块的间隔,在函数之间必须加上空行(两行左右),而函数内部,变量声明块和实现块(实现块指除变量声明外的其它代码)要使用空行来间隔(一行),实现块的内部,通过空行来标识一个功能段,如: Private Sub Check(Order As NYSaleBackLib.Order)

'减少库存 Dim objStockItem As NYStockLib.StockItemDim objStock As NYStockLib.StockDim i As Integer     Set objStock = CreateStock()     For i = 0 To Order.ItemCount - 1            Set objStockItem = Order.item(i) 

        '减少库存         Call objStock.ReduceItem(objStockItem, True)     Next i            Set objStock = Nothing    End Sub 

(注意:不要使用过多的空行,空行太多影响代码阅读!)

3.3          缩进

       缩进必须严格执行,变量声明块不缩进,实现块必须保证全部缩进(即不可能有实现块是行首对齐的)。       每个单位的代码缩进为一个TAB,非相关代码留一行空白的间隔。
注:Goto标签不缩进        对于基本的控制结构,必须要有缩进,如:IF、DO、WITH、FOR、OPEN、SELECT块,缩进示例如下:Private Function GetMax(Byref lngArray() As Long) As Long  Dim lngMax As Long  Dim lngCount as long            GetMax=0         For lngCount =0 to Ubound(lngArray) 

         If lngArray (lngCount)>lngMax Then              lngMax=lngArray(lngCount)          End If      Next     End Function  对于过长的语句,必须使用续行,续行位置要有明显意义,示例:       sql = “SELECT [code],[name] FROM [Person] “ _              & “ WHERE [code] LIKE ‘001%’ “              & “ and [code] LIKE ‘002%’ “

        函数的参数如果过长,也应该续行,示例:

'

'增加库存

' ProductCode 产品编号

' Spec 长度规格

' Color 颜色

' Patch 是否拼圈

' Volumn 盘号

' Ordinal 子库存顺序号

' Length 长度

' IsCheck 是否审核入库增加(否则为弃审出库增加) Public Sub AddDetail(ProductCode As String, _                Spec As Double, _                Color As String, _                Patch As Boolean, _                Volumn As String, _                Ordinal As Integer, _                Length As Double, _                IsCheck As Boolean)

4.     注释约定

4.1        注释量

程序的注译越详尽,越仔细越好。程序中声明的每一个变量,能加上注译最好,至少用来运算或者保存关键数据的变量必须加上注译。  对于每一段逻辑上实现某个基本功能的几句代码,最好在其上一行加上简单注译。对于每一个自定义的函数,不管大小都必须加上注译。

4.2        格式

注译的格式如下:
'****************************************************** 

 

'函数所实现的功能 

'函数的参数1的含义:XXXXX 

'函数的参数2的含义:XXXXX 

'…… 

'函数返回值所代表的错误信息:XXXXX

'函数的返回值为0表示执行成功,为其它值表示执行失败

'****************************************************** Public(Private) Function ForExample(……………………) As Long  '…………………………………………  End Function

 在每个代码模块(窗体、类、模块、控件)的最上面,必须写上代码编写人、代码创建时间、代码修改时间和修改说明。示例:

'

'库存修改窗体

'作者             XXXXXX

'建立日期     2005-6-22

'修改日期      2005-6-23 修改人 XXXXXX

'增加对库存修改时同时影响最后入库日期的功能

5.     程序设计约定

1.      程序一律从Main()函数开始执行。

2.      同一个程序在一台机器同时只能运行一次,既不能同时运行同一个程序的多个副本。

即If App.PrevInstance = True Then End

3.      同一个登录用户同时只能登录同一个系统一次。

4.      建议使用Long型的变量来代替Integer类型。

这样做可以减少一些数据溢出的错误,而且,在Win32位平台上,CPU处理32位的数据比16位的数据速度更快。

5.      在连接字符串时使用 & 运算符,避免使用 + 运算符。

下面例子用 + 运算符来连接可能会导致问题。例如:vntVar1 = "10.01"vntVar2 = 11vntResult = vntVar1 + vntVar2 'vntResult = 21.01vntResult = vntVar1 & vntVar2 'vntResult = 10.0111

6.      当产生长字符串时,使用下划线连接字符产生多行代码,这样便于阅读或调试字符串。

当显示一个消息框 (MsgBox) 或输入框 (InputBox),或产生一个 SQL 字符串时,这一技术特别有用。例如:
 Dim Msg As StringMsg = "This is a paragraph that will be " _& "in a message box. The text is" _& " broken into several lines of code" _& " in the source code, making it easier" _& " for the programmer to read and debug."MsgBox Msg

 Dim QRY As StringQRY = "SELECT *" _& " FROM Titles" _& " WHERE [Year Published] > 1988"TitlesQry.SQL = QRY

7.      不要将类型转换的工作交给VB自动去做,而使用以下类型转换函数。 

CBool(expression)  CByte(expression)  CCur(expression)  CDate(expression)  CDbl(expression)  CDec(expression)  CInt(expression)  CLng(expression)  CSng(expression)  CStr(expression)  CVar(expression)Val(expression)

8.      错误处理(编一个函数处理所有已知错误)

在Main()函数或主窗体Load过程中添加如下代码: 
'****************************************************** 

'打开错误日志文件,在Form_Unload()中关闭 

'******************************************************     Dim strExePath As String 

     If Right(App.Path, 1) = "\" Then          strExePath = App.Path      Else          strExePath = App.Path & "\"  End If 

 intErrLogFileHandle = FreeFile() 

 Open strExePath + "Err.log" For Append Shared As intErrLogFileHandle     在主窗体退出函数中添加如下代码:  '****************************************************** 

'关闭错误日志文件 

'******************************************************         Close #intErrLogFileHandle     在某个Module中添加: 

'****************************************************** 

'写入错误日志 

'****************************************************** 

 Public Sub WriteErrLogFile(ByVal strSub As String, ByVal strErr As String)      Print #intErrLogFileHandle, Date, Time, strSub, strErr  End Sub     在每个过程或自定义的函数中,使用如下的系统错误捕获机制:  Public Function ForExample(…………) As Long         On Error Goto FuncError         ForExample=True         ………………………      ………………………         Exit Function  FuncError:      ForExample=False      WriteErrLogFile " ForExample ", "错误号:" & Err.Number & ",错误源:" & Err.Source & ",错误描述:" & Err.Description      MsgBox  "……… ", vbCritical 

    '在此作内存资源回收工作  End Function 

9.      窗体布局 

    窗体内各个控件的布局,建议如下:      1、所有与窗体上、下、左、右四条边界相邻的控件与窗体的边缘相距120缇      2、各个控件之间的间距为:相关控件60缇,非相关控件120缇      3、按钮控件大小为高300缇,长〉=1200缇,这也是操作系统默认按钮的大小      4、各个控件的字体建议为宋体五号字

时间: 2024-11-03 21:40:38

Visual Basic编程规范的相关文章

安装Visual Basic

运行安装程序时将会为 Visual Basic 创建目录,从而可选择要安装的 VisualBasic 部件. 除了 \Os 目录下的操作系统文件,CD 上的其它文件是没有被压缩的,所以可从盘上直接使用.例如,在 \Tools 目录下有许多的工具和部件,可以直接从 CD-ROM 运行或安装. 要从 CD 盘上安装,请按照以下步骤执行: 1. 在 CD-ROM 驱动器中插入 CD 盘. 2. 安装程序在Disk 1的根目录下,可用操作系统中的适当命令来运行.如果您的计算机能够在系统中运行 AutoP

visual basic 6.0-Visual Basic 6.0中TextBox的行距的控制

问题描述 Visual Basic 6.0中TextBox的行距的控制 TextBox的行距太小了,我希望能拉大行距,请问在Visual Basic编程文本框,应该改什么属性呢? 解决方案 TextBox的行距的控制需要重绘才能实现了.不过VB本身重绘比较麻烦,你可以用C++编写一个给VB调用. 解决方案二: 用richtextbox吧 解决方案三: http://bbs.csdn.net/topics/80135493 解决方案四: 设置控制的字符属性来实现

Visual Basic.NET 新编程模型和语言改进(转)

visual|编程 摘要:Visual Basic.NET是针对微软的.NET框架,对Visual Basic进行重塑之后的结果   .在里面有许多修改,使Visual Basic.NET比Visual Basic 6.0更易使用.更强大,而且给它赋予了过去需要使用C++这样的语言才具有的访问某些系统资源的能力.最重要的是增加了对象的继承性.在Visual Basic.NET里,所有受控类型都派生自System.Object. 一个重要的新语言特性是垃圾搜集,它由公共语言运行时(Common L

Visual Basic中的界面设计原则和编程技巧

在vb里,mdi(multiple document interface,多窗口程序)窗体是这样定义的:"mdi窗体作为一个程序的后台窗口,包含着mdichild属性为true的窗体".在一个vb程序中,至多只能存在一个mdi父窗体,可以有多个mdi子窗体:建立一个mdi父窗体的方法是在vb的file菜单里选择"new mdi form". 在mdi程序运行时,如果子窗口具有菜单,那么当子窗口被激活时,子窗口的菜单就会自动替换父窗口菜单:当子窗口被最小化时,在mdi

使用Visual Basic 9.0进行XML编程

到目前为止,您可能已听说过LINQ(语言集成查询),它是Visual Studio 2008中附带的新查询技术.启用LINQ的语言(如Visual Basic)为您提供了一组丰富的查询运算符,您可以将这些运算符应用到各种数据源,如内存中的集合.数据库.数据集和XML.仅这一项技术就已经非常优秀了,但Visual Basic 9.0实际上提供的技术远不止此,它使XML成为直接集成到语言中的一流数据类型. 现在您可能想知道为什么需要将 XML 数据类型直接集成到Visual Basic中.当今,许多

《Visual Basic 2012入门经典》----第1章 全身心投入:Visual Basic 2012编程之旅 1.1 开始使用Visual Basic 2012

第1章 全身心投入:Visual Basic 2012编程之旅 Visual Basic 2012入门经典在本章中,读者将学习: 创建一个简单但有一定功能的Visual Basic应用程序:让用户浏览硬盘:显示硬盘中的图片:熟悉一些编程术语:学习Visual Studio 2012 IDE.学习一门新的编程语言因其难度可能使人望而却步.如果您从来没有编写过程序,那么输入有些神秘的文本就可以产生精美的.功能强大的应用程序,这种行为对您来说可能就像一种魔法,您可能会想知道如何才能学会需要掌握的东西.

《Visual Basic 2012入门经典》---- 2.7 快速而简单的编程入门指南

2.7 快速而简单的编程入门指南 Visual Basic 2012入门经典编程很复杂.所有东西都互相关联,因此很难将每个编程概念分开然后用线性方式加以说明.相反,在学习一个主题的过程中,通常在学到另一个主题前就需要接触它.正如第1章指出的,我尽量避免这种前向参考,但有些概念需要你首先熟悉一下.这些主题在对应的章节中都将介绍,但阅读本书之前你必须至少听说过. 2.7.1 用变量存储值 变量是代码中用于保存值的元素.例如,可以创建一个保存用户名或用户年龄的变量.每个变量(存储实体)都必须在使用前创

利用Visual Basic操作XML数据

visual|xml|数据 什么是XML 扩展标记语言XML是一种简单的数据存储语言,使用一系列简单的标记描述数据,而这些标记可以用方便的方式建立,虽然XML占用的空间比二进制数据要占用更多的空间,但XML极其简单易于掌握和使用. XML与Access,Oracle和SQL Server等数据库不同,数据库提供了更强有力的数据存储和分析能力,例如:数据索引.排序.查找.相关一致性等,XML仅仅是展示数据.事实上XML与其他数据表现形式最大的不同是:他极其简单.这是一个看上去有点琐细的优点,但正是

Visual Basic迎来第20个生日

导语:Christiaan Baes是一名技术专家,同是也是一名VB.NET的粉丝.在他的博文中写到:当我在看VBTeam时得知5月20日是Visual Basic的20岁生日.在这二十年来,Visual Basic一度是世界上开发者人数最多的一种语言之一,并持久不衰. 这一切还要追溯到1991年比尔·盖茨推出了Visual Basic 1.0版.这在当时引起了很大的轰动,许多专家都把VB的出现当做是软件开发史上的一个具有划时代意义的事件.事实上,它最初在1988年以名为Ruby的代码项目开始,