Вот мои идеи:
object[] primitiveData = new object[byteData.Lenght];
for (int i = 0; i < bytesData.Lenght; i++)
{
primitiveData[i] = Converter.ChangeType(bytesData[i], types[i]);
}
object[] primitiveData = new object[bytDate.Lenght];
for (int i = 0; i < bytesDate.Lenght; i++)
{
Type t = types[i];
if (t == typeof(int))
{
primitiveData[i] = Convert.ToInt32(bytesDate[i]);
}
else if (t == typeof(short))
{
primitiveData[i] = Convert.ToInt16(bytesDate[i]);
}
..
}
var dic = new Dictionary<Type, Func<byte, object>>
{
{ typeof(int), b => Convert.ToInt32(b) },
{ typeof(short), b => Convert.ToInt16(b) },
...
};
byte[] byteData = new byte[] { 0xa0, 0x14, 0x72, 0xbf, 0x72, 0x3c, 0x21 };
Type[] types = new Type[] { typeof(int), typeof(short), typeof(sbyte) };
List<object> list = new List<object>(primitiveData.Length);
for (int i = 0; i < primitiveData.Length; i++)
{
Byte b = byteData[i];
Type t = types[i];
Func<byte, object> func = dic[t];
list.Add(func(b));
}
object[] primitiveData = list.ToArray();
byte[] byteData = new byte[] { 0xa0, 0x14, 0x72, 0xbf, 0x72, 0x3c, 0x21 };
// delegates to converters instead of just appropriate types
Func<byte, object>[] funcs = new Func<byte, object>[]
{
b => Convert.ToInt32(b),
b => Convert.ToInt16(b),
b => Convert.ToSByte(b)
};
List<object> list = new List<object>(primitiveData.Length);
for (int i = 0; i < primitiveData.Length; i++)
{
Byte b = byteData[i];
Func<byte, object> func = funcs[i];
list.Add(func(b));
}
object[] primitiveData = list.ToArray();
Обратите внимание, что все мои решения, приведенные выше, предполагают симметрию между byteData
и types
.
В противном случае вы должны подготовить симметричный массив, который будет содержать индекс асимметричного массива:
byte[] byteData = new byte[] { 0xa0, 0x14, 0x72, 0xbf, 0x72, 0x3c, 0x21 };
Type[] types = new Type[] { typeof(int), typeof(short), typeof(sbyte) }; // asymmetric
int[] indexes = new int[] { 0, 0, 0, 0, 1, 2 }; // symmetric