vb.net泛型委托 net常用的泛型委托

VB6與VB.NET的差異有哪些?

.Net平臺引入了很多先進的技術,導致了VB6和VB.Net之間產(chǎn)生了一個巨大的鴻溝

創(chuàng)新互聯(lián)公司堅持“要么做到,要么別承諾”的工作理念,服務領域包括:做網(wǎng)站、成都做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務,滿足客戶于互聯(lián)網(wǎng)時代的蘭陵網(wǎng)站設計、移動媒體設計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡建設合作伙伴!

就語言功能上來講,VB.net完全是為了.Net技術而生,具有更好的運行效率和更加強大的功能(某些方面甚至超過了C#)

從語法角度上來講,VB.net成為了真正的OOP(面向?qū)ο笳Z言),不但支持類的繼承、派生,還支持委托、泛型等等更加高級的編程技術

如果你是從VB6升級到.net的話,建議要將VB.net當作一門新的語言來學。以VB6的經(jīng)驗來應用到VB.net上是會犯很多錯誤的

關于從VB6升級到VB.net的代碼變換問題,注意以下幾個重要的要點即可:

1.不再支持Load、Shell、.LoadPicture等語句

請用相關的.net語句替換

2.String類為引用類,也就是說

Dim s1,s2 as String

s1="FFFFFFF"

s2=s1

此時修改s2的值s1也會跟著相應變化

3.不再支持Variant型和Currency型變量

分別用Object和Demical類型代替

4.變量長度的變化:

VB6的byte、Integer、long型分別被vb.net的byte、short、integer代替,而long型則成為64位大小的整數(shù)。新增了UInteger、ULong、SByte等無符號整數(shù)類型

vb.net 中在模塊(module)里如何實現(xiàn)委托

委托三個步驟

1、聲明委托 用Delegate 聲明一個委托 類型 參數(shù)要和 被委托的方法一樣 例如 Delegate Function a(byval x as string) as string

2、實例化委托 dim t as new a(AddressOf Function Name)

3.通過 t(參數(shù)) 或者 t.Invoke(參數(shù)調(diào)用委托)

示例:

Module module1

Delegate Function a(ByVal x As Integer, ByVal y As Integer) As Integer '聲明委托類型 委托可以使一個對象調(diào)用另一個對象的方法

Function sum(ByVal x As Integer, ByVal y As Integer) As Integer

Return (x + y)

End Function

Sub main()

Dim d As New a(AddressOf sum) '實例化委托

Dim s = 0

s = d.Invoke(1, 2) '執(zhí)行委托

Console.WriteLine(s.ToString())

s = d(1, 2) '執(zhí)行委托

Console.WriteLine(s.ToString())

MsgBox("")

End Sub

End Module

Asp.net包含哪些技術

主要的是:

委托,泛型,LINQ,ADO.NET,ASP.NET,WPF,WWF,WCF,GDI和聯(lián)網(wǎng)等技術。

關于vb.net中實現(xiàn)委托的一個問題

把UI對象當做參數(shù)傳入 比如 Sub a(Form As Form1)

之后再用Form.Invoke(你的委托,參數(shù)) 就可以即時修改Form中的內(nèi)容了

vb.net中如何用事件和委托,會C#中的事件和委托,但不知VB.net中的語法,望給個簡單的例子熟悉語法。

一委托:此示例演示如何將方法與委托關聯(lián)然后通過委托調(diào)用該方法。

創(chuàng)建委托和匹配過程

創(chuàng)建一個名為 MySubDelegate 的委托。

Delegate Sub MySubDelegate(ByVal x As Integer)

聲明一個類,該類包含與該委托具有相同簽名的方法。

Class class1

Sub Sub1(ByVal x As Integer)

MsgBox("The value of x is: " CStr(x))

End Sub

End Class

定義一個方法,該方法創(chuàng)建該委托的實例并通過調(diào)用內(nèi)置的 Invoke 方法調(diào)用與該委托關聯(lián)的方法。

Protected Sub DelegateTest()

Dim c1 As New class1

' Create an instance of the delegate.

Dim msd As MySubDelegate = AddressOf c1.Sub1

' Call the method.

msd.Invoke(10)

End Sub

二、事件

下面的示例程序闡釋如何在一個類中引發(fā)一個事件,然后在另一個類中處理該事件。AlarmClock 類定義公共事件 Alarm,并提供引發(fā)該事件的方法。AlarmEventArgs 類派生自 EventArgs,并定義 Alarm 事件特定的數(shù)據(jù)。WakeMeUp 類定義處理 Alarm 事件的 AlarmRang 方法。AlarmDriver 類一起使用類,將使用 WakeMeUp 的 AlarmRang 方法設置為處理 AlarmClock 的 Alarm 事件。

該示例程序使用事件和委托和引發(fā)事件中詳細說明的概念。

示例

' EventSample.vb.

'

Option Explicit

Option Strict

Imports System

Imports System.ComponentModel

Imports Microsoft.VisualBasic

Namespace EventSample

' Class that contains the data for

' the alarm event. Derives from System.EventArgs.

'

Public Class AlarmEventArgs

Inherits EventArgs

Private _snoozePressed As Boolean

Private nrings As Integer

'Constructor.

'

Public Sub New(snoozePressed As Boolean, nrings As Integer)

Me._snoozePressed = snoozePressed

Me.nrings = nrings

End Sub

' The NumRings property returns the number of rings

' that the alarm clock has sounded when the alarm event

' is generated.

'

Public ReadOnly Property NumRings() As Integer

Get

Return nrings

End Get

End Property

' The SnoozePressed property indicates whether the snooze

' button is pressed on the alarm when the alarm event is generated.

'

Public ReadOnly Property SnoozePressed() As Boolean

Get

Return _snoozePressed

End Get

End Property

' The AlarmText property that contains the wake-up message.

'

Public ReadOnly Property AlarmText() As String

Get

If _snoozePressed Then

Return "Wake Up!!! Snooze time is over."

Else

Return "Wake Up!"

End If

End Get

End Property

End Class

' Delegate declaration.

'

Public Delegate Sub AlarmEventHandler(sender As Object, _

e As AlarmEventArgs)

' The Alarm class that raises the alarm event.

'

Public Class AlarmClock

Private _snoozePressed As Boolean = False

Private nrings As Integer = 0

Private stopFlag As Boolean = False

' The Stop property indicates whether the

' alarm should be turned off.

'

Public Property [Stop]() As Boolean

Get

Return stopFlag

End Get

Set

stopFlag = value

End Set

End Property

' The SnoozePressed property indicates whether the snooze

' button is pressed on the alarm when the alarm event is generated.

'

Public Property SnoozePressed() As Boolean

Get

Return _snoozePressed

End Get

Set

_snoozePressed = value

End Set

End Property

' The event member that is of type AlarmEventHandler.

'

Public Event Alarm As AlarmEventHandler

' The protected OnAlarm method raises the event by invoking

' the delegates. The sender is always this, the current instance

' of the class.

'

Protected Overridable Sub OnAlarm(e As AlarmEventArgs)

RaiseEvent Alarm(Me, e)

End Sub

' This alarm clock does not have

' a user interface.

' To simulate the alarm mechanism it has a loop

' that raises the alarm event at every iteration

' with a time delay of 300 milliseconds,

' if snooze is not pressed. If snooze is pressed,

' the time delay is 1000 milliseconds.

'

Public Sub Start()

Do

nrings += 1

If stopFlag Then

Exit Do

Else

If _snoozePressed Then

System.Threading.Thread.Sleep(1000)

If (True) Then

Dim e As New AlarmEventArgs(_snoozePressed, nrings)

OnAlarm(e)

End If

Else

System.Threading.Thread.Sleep(300)

Dim e As New AlarmEventArgs(_snoozePressed, nrings)

OnAlarm(e)

End If

End If

Loop

End Sub

End Class

' The WakeMeUp class has a method AlarmRang that handles the

' alarm event.

'

Public Class WakeMeUp

Public Sub AlarmRang(sender As Object, e As AlarmEventArgs)

Console.WriteLine((e.AlarmText + ControlChars.Cr))

If Not e.SnoozePressed Then

If e.NumRings Mod 10 = 0 Then

Console.WriteLine(" Let alarm ring? Enter Y")

Console.WriteLine(" Press Snooze? Enter N")

Console.WriteLine(" Stop Alarm? Enter Q")

Dim input As String = Console.ReadLine()

If input.Equals("Y") Or input.Equals("y") Then

Return

Else

If input.Equals("N") Or input.Equals("n") Then

CType(sender, AlarmClock).SnoozePressed = True

Return

Else

CType(sender, AlarmClock).Stop = True

Return

End If

End If

End If

Else

Console.WriteLine(" Let alarm ring? Enter Y")

Console.WriteLine(" Stop Alarm? Enter Q")

Dim input As String = Console.ReadLine()

If input.Equals("Y") Or input.Equals("y") Then

Return

Else

CType(sender, AlarmClock).Stop = True

Return

End If

End If

End Sub

End Class

' The driver class that hooks up the event handling method of

' WakeMeUp to the alarm event of an Alarm object using a delegate.

' In a forms-based application, the driver class is the

' form.

'

Public Class AlarmDriver

Public Shared Sub Main()

' Instantiates the event receiver.

Dim w As New WakeMeUp()

' Instantiates the event source.

Dim clock As New AlarmClock()

' Wires the AlarmRang method to the Alarm event.

AddHandler clock.Alarm, AddressOf w.AlarmRang

clock.Start()

End Sub

End Class

End Namespace

vb.net 中的異步委托機制,最好有相關的詳細資料講解,我是新手

所謂的委托(Delegate)實際上就是和C/C++里面的函數(shù)指針差不多,只是增強了類型檢查等其它健壯性方面的內(nèi)容。異步調(diào)用的回調(diào)函數(shù)有格式要求,所謂格式要求就是參數(shù)數(shù)量及類型順序的要求,具體是什么樣的你要看文檔了。一般.NET Framework里面都是AsyncCallBack。

所謂異步編程,就是說你要求做某樣事情,但是在完成這件事之前,我能接著做下一件事,而當這件事情完成之后,能夠有一種機制通知我完成了。相反,在完成之前一直等待,直到完成了才能進行下一步操作,叫做同步。一般來說,我們平常寫的程序都是“同步”,或者成為“順序執(zhí)行”更加貼切,而“異步”則可以說是“亂序執(zhí)行”的。

可以看到,同步的代碼非常好寫,因為我們可以預測執(zhí)行的順序和情況。而異步就不是很好寫了,因為無法得知完成的時候我正在做什么、做到什么程度。過去寫這些代碼是比較麻煩的,實現(xiàn)的辦法就是自己建立一個處理異步事物的線程,然后在這個線程和主線程之間建立聯(lián)系。而現(xiàn)在這個過程大部分已經(jīng)被系統(tǒng)封裝起來了,你只要調(diào)用BeginXXX,系統(tǒng)就會為你自動建立一個新的線程處理這個事情,當前線程不阻塞,可以馬上進行下一項操作,于是就實現(xiàn)了“異步”了。但是從前面我講道的你就應該知道,開始異步操作并沒有完事,還需要能夠得知操作完成,并能夠進行相應的處理。于是你在調(diào)用BeginXXX的時候就需要傳遞一個回調(diào)函數(shù),在.NET里是以委托的方式傳遞的?;卣{(diào)函數(shù)的意思就是“回過頭來調(diào)用你”,或者說A調(diào)用B并且傳遞函數(shù)C的地址,于是B在指定的情況下調(diào)用A指定的函數(shù)C?,F(xiàn)在就應該明白這個回調(diào)函數(shù)在BeginXXX中的作用就是,當你指定的事情做完之后將會調(diào)用這個回調(diào)函數(shù)。

在這個回調(diào)函數(shù)里面,我們就可以進行一些后續(xù)的工作,例如接著進行性質(zhì)相同的工作,或者相應的處理。在這里,我們也許向知道剛才那件事情執(zhí)行的情況和結果,這個時候我們就可以通過EndXXX來獲得這些東西。說到這里,結合上面說到的AsyncCallBack以及隨便哪個BeginXXX,我們可能會對下列兩個東西感到困惑:

IAsyncResult

stateObject

首先說IAsyncResult,這個是一個接口,你在回調(diào)函數(shù)中通過參數(shù)獲得的對象具體是什么類型的一般我們不需要關心,我們只需要依照這個接口的定義進行訪問就可以了。簡單點說,這個接口規(guī)定了順利完成異步操作所需信息的最小集合。一般來說,我們需要通過這個參數(shù)(ar)來識別異步操作。比如說,你在一瞬間發(fā)起一百個“從不同的網(wǎng)絡連接獲取數(shù)據(jù)”的異步請求,當某一個請求被完成的時候,如何判斷是那個請求被完成呢?就是依靠回調(diào)函數(shù)的參數(shù)ar。實際上你一般是不需要參與判斷的,你只要將這個ar傳遞給EndXXX就可以了,EndXXX會根據(jù)這個ar自行判斷的。需要注意的是,這個ar就是你調(diào)用BeginXXX的時候的返回值,可以說是一個存根,如果你需要在完成操作前終止他,也可以通過將這個存根傳遞給EndXXX,EndXXX就會根據(jù)情況終止操作。(IAsyncResult里面的IsCompleted提供了是否已經(jīng)完成的判斷,EndXXX就是根據(jù)這個值決定是否有必要終止。當然,你不需要關心他。)

接下來我們看看stateObject,這個東西被稱為狀態(tài)對象。于是大家就可能奇怪了:那個ar不也是狀態(tài)嗎?實際上stateObject是一個留給用戶使用的東西,BeginXXX/EndXXX根本就不使用。這個stateObject會被裝到ar的AsyncState里面,也就是說這個stateObject可以隨時通過訪問存根(BeginXXX的返回值)或者回調(diào)函數(shù)里的ar得到,你完全沒必要額外的保存到什么地方,更不需要費神的去考慮如何和你的某個異步操作對應起來。說了半天,這個東西有什么用呢?你想怎么用就怎么用唄,發(fā)揮一下你的想象力。比如說,你可以保存這是第幾次操作,或者在多個異步操作之間要同步的時候可以作為信號旗,再或者直接是操作這個異步操作的對象(x.BeginXXX的時候?qū)傳遞到stateObject參數(shù)上)。

第一種用法有點多余,第二種用法有點復雜,第三種我用得最多。因為你很可能在協(xié)一個服務端,而服務段必須能夠響應多個客戶端,這決定了必須用異步。同時,對于多個客戶端必然有多個對象,例如網(wǎng)絡連接的時候可能是Socket。而實際上處理的方法或者協(xié)議是和具體哪個客戶端沒有關聯(lián)的,因此我們只需要一套處理程序就夠了。這個時候第三種用法就很有用處,我們完全可以把代碼寫成這樣:

Sub DataReceived(ByVal ar As IAsyncResult)

ar.AsyncState.EndReceive(ar)

ar.AsyncState.BeginReceive(... , ar.AsyncState)

End Sub

這樣就不需要額外的數(shù)據(jù)結構去記錄有那些正在活動的對象了。

網(wǎng)站題目:vb.net泛型委托 net常用的泛型委托
文章起源:http://muchs.cn/article26/hhidjg.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供企業(yè)網(wǎng)站制作、服務器托管、、搜索引擎優(yōu)化、Google商城網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

h5響應式網(wǎng)站建設