Back to Top

プログラムの覚書

Author Archives: miyunsarna

VB.NET Threadクラスによるマルチスレッド

Threadクラスでマルチスレッドをする

・同時に実行できるスレッドの数に制限がある

Threadのマルチスレッド

Start()         スレッドの開始
Suspend()       スレッドの一時停止
Resume()        スレッドの再開
Join()          スレッドの処理が終了するまで待つ
Abort()         スレッドの強制終了
ThreadState     スレッドのステータスの取得

スレッド使用例

Private thisLock As New Object
Private s As String = ""

「呼ぶ出されるスレッドプログラム」
Private Sub ThreadMain1()
    Dim i As Integer
    For i = 0 To 9999
        SyncLock thisLock
            s = s + "A"
        End SyncLock
    Next
    System.Diagnostics.Debug.WriteLine(" Thread2:" & s.Length.ToString())
End Sub


------------------------------------------------------------------------------

「呼び出し側のプログラム」
Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
    Dim thread1 As System.Threading.Thread = New System.Threading.Thread(AddressOf ThreadMain1)
    thread1.Start()
    thread1.Join()
End Sub

 

スレッド側でメインのコントロールを更新する

別スレッドからコントロールを操作する場合にはInvokeメソッドを使用します。Invokeメソッドを使うと、コントロールに対する操作をメイン・スレッドで実行させることができる。

Invokeメソッドを使う必要があるかどうかをチェックするためのInvokeRequiredプロパティがあります。このプロパティは、それを呼び出したスレッドがメイン・スレッドかどうかを調べ、trueあるいはfalseを返します。

Private thisLock As New Object
Private s As String = ""

'コントロールを扱うためのデリゲート宣言
Delegate Sub delegate_ProgressBarValue(ByVal value As Integer)

'デリゲート宣言をデータ型とした変数を作成
Private ProgressBarValue As New delegate_ProgressBarValue(AddressOf ProgressBar1Value)

'プログレスバー更新処理
Sub UpdateProgressBar1(val As Integer)
    If InvokeRequired Then
        Dim callback As New delegate_ProgressBarValue(AddressOf UpdateProgressBar1)
        Invoke(callback, val)
        Return
    End If
    ProgressBar1.Value = val
End Sub

Private Sub ThreadMain1()
Dim i As Integer
    For i = 0 To 999
        UpdateProgressBar1(i)
        SyncLock thisLock
            s = s + "A"
        End SyncLock
    Next
    System.Diagnostics.Debug.WriteLine(" Thread1:" & s.Length.ToString())
End Sub

--------------------------------------------------------------------------------------

[呼び出し側プログラム]

Dim Thread1 As System.Threading.Thread = Nothing

Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
    If Not Thread1 Is Nothing Then
        ' スレッドが停止状態でない場合は終了
        If Thread1.ThreadState <> System.Threading.ThreadState.Stopped Then
            Exit Sub
        End If
    End If

    ' スレッド開始
    Thread1 = New Threading.Thread(AddressOf ThreadMain1)
    Thread1.IsBackground = True
    Thread1.Start()
    '    Thread1.Join()
End Sub

'Joinでスレッド終了を待たせると、メインコントロール更新で死にますので注意

Private Sub Form1_FormClosed(sender As Object, e As FormClosedEventArgs) Handles MyBase.FormClosed
    If Not Thread1 Is Nothing Then
        ' スレッドを強制終了させる
        Thread1.Abort()

        ' メインスレッドに結合する
        Thread1.Join()
    End If
End Sub

 

VB.NETのDataTable列(Columns)

DataTableで使用する列(Columnsプロパティ)の操作を説明します。

列(フィールド)の追加および主キーの設定をする

Dim tbl As DataTable = New DataTable("Table1")
Dim PrimaryColumn As DataColumn

PrimaryColumn = tbl.Columns.Add("ID", Type.GetType("System.Int32"))

tbl.Columns.Add("Item1", Type.GetType("System.String"))
tbl.Columns.Add("Item2", Type.GetType("System.String"))
tbl.Columns.Add("Item3", Type.GetType("System.Double"))

'フィールドに主キーを設定(IDを主キーにします)
tbl.PrimaryKey = New DataColumn() {PrimaryColumn}

 

フィールド名の存在チェックおよびフィールド名の削除をする

フィールド名が主キーに設定されている時は、削除することはできません。

Dim ItemName = "Item1"
Dim columns As DataColumnCollection = tbl.Columns

'フィールドの存在チェック
If columns.Contains(ItemName) Then
    '削除できるかチェック 
    If columns.CanRemove(columns(ItemName)) Then 
        'フィールド削除        
        columns.Remove(ItemName)
    End If
End If

 

フィールド数を取得する

MessageBox.Show(Tbl.Columns.Count)

 

フィールドでループ

Dim s As String = ""
For Each Col As DataColumn In tbl.Columns
    s &= Col.ColumnName & System.Environment.NewLine
Next
MessageBox.Show(s)

 

主キーの大文字と小文字を区別する

主キーが文字列の場合、主キーの大文字と小文字を区別する場合はCaseSensitiveをTrueに設定します。

Dim tbl As DataTable = New DataTable("Table1")
Dim PrimaryColumn As DataColumn
Dim row As DataRow

PrimaryColumn = tbl.Columns.Add("ID", Type.GetType("System.String"))
tbl.Columns.Add("Item1", Type.GetType("System.String"))
tbl.Columns.Add("Item2", Type.GetType("System.String"))

tbl.PrimaryKey = New DataColumn() {PrimaryColumn}

'主キーの大文字小文字を区別する
tbl.CaseSensitive = True

'1列目
row = tbl.NewRow
row("ID") = "AAA1"
row("Item1") = "A1"
row("Item2") = "A2"
tbl.Rows.Add(row)

'2列目
row = tbl.NewRow
row("ID") = "aaa1"
row("Item1") = "B1"
row("Item2") = "B2"
tbl.Rows.Add(row)

上のコードでCaseSensitiveがFalseの場合2列目の追加でエラーになります。