How to insert values into VB.NET Dictionary on instantiation?

旧街凉风 提交于 2020-06-22 07:40:30

问题


Is there a way that I can insert values into a VB.NET Dictionary when I create it? I can, but don't want to, do dict.Add(int, "string") for each item.

Basically, I want to do "How to insert values into C# Dictionary on instantiation?" with VB.NET.

var dictionary = new Dictionary<int, string>
    {
        {0, "string"},
        {1, "string2"},
        {2, "string3"}
    };

回答1:


If using Visual Studio 2010 or later you should use the FROM keyword like this:

Dim days = New Dictionary(Of Integer, String) From {{0, "string"}, {1, "string2"}}

See: http://msdn.microsoft.com/en-us/library/dd293617(VS.100).aspx

If you need to use a prior version of Visual Studio and you need to do this frequently you could just inherit from the Dictionary class and implement it yourself.

It might look something like this:

Public Class InitializableDictionary
    Inherits Dictionary(Of Int32, String)

    Public Sub New(ByVal args() As KeyValuePair(Of Int32, String))
        MyBase.New()
        For Each kvp As KeyValuePair(Of Int32, String) In args
            Me.Add(kvp.Key, kvp.Value)
        Next
    End Sub

End Class



回答2:


This is not possible versions of Visual Basic prior to 2010.

In VB2010 and later, you can use the FROM keyword.

Dim days = New Dictionary(Of Integer, String) From {{0, "Sunday"}, {1, "Monday"}}

Reference

http://msdn.microsoft.com/en-us/library/dd293617(VS.100).aspx




回答3:


What you're looking at is a feature of C# called "collection initializers". The feature existed for VB as well, but was cut prior to the release of Visual Studio 2008. It doesn't help you right now, but this is expected to be available in Visual Studio 2010. In the meantime, you'll have to do it the old fashioned way — call the .Add() method of your new instance.



来源:https://stackoverflow.com/questions/1664514/how-to-insert-values-into-vb-net-dictionary-on-instantiation

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!