SortedSet adiciona confusão
-
08-09-2020 - |
Pergunta
Quando executo o código abaixo, apenas 8 dos 50 arquivos no diretório são adicionados.
Os arquivos são nomeados como 0001, 0002, 0003, 0004, etc.
Os arquivos adicionados estão nesta ordem:7,0,1,2,3,4,5,6 quando os itens não são mais adicionados.
Observando os valores mínimo e máximo do meu SortedSet são 6 e 7, respectivamente.
Suponho que minha pergunta seja: existe uma maneira melhor de fazer isso ou uma maneira de fazer com que o código abaixo faça o que desejo.Para ser mais específico, quero que as strings do caminho do arquivo sejam classificadas em uma coleção com base nos valores analisados no arquivo.
string[] files = System.IO.Directory.GetFiles(textBox1.Text);
SortedSet<string> ascending = new SortedSet<string>(new MyComparer());
foreach (string f in files)
{
bool added = ascending.Add(f);
}
//Compares values in file format
//MyComparer.Compare:
using (FileStream fsx = new FileStream(x, FileMode.Open, FileAccess.Read, FileShare.Read))
using (FileStream fsy = new FileStream(y, FileMode.Open, FileAccess.Read, FileShare.Read))
using (StreamReader rx = new StreamReader(fsx))
using (StreamReader ry = new StreamReader(fsy))
{
//the first 6 bytes represent a number
char[] buffx = new char[6], buffy = new char[6];
rx.Read(buffx, 0, 6);
ry.Read(buffy, 0, 6);
int nx, ny;
if (!int.TryParse(new String(buffx), out nx))
throw new Exception("Wtf?");
if (!int.TryParse(new String(buffy), out ny))
throw new Exception("Wtf?");
return Comparer<int>.Default.Compare(nx, ny);
}
Solução
Eu escreveria seu código semelhante a este:
int GetFileContentNumber(string filename)
{
using(var reader=new StreamReader(filename)
{
char[] chars=new char[6];
reader.Read(buf, 0, 6);
return int.Parse(new String(chars));
}
}
IEnumerable<string> files = System.IO.Directory.GetFiles(textBox1.Text)
.Select(filename=>new KeyValuePair<string,int>(filename, GetFileContentNumber(filename)))
.OrderBy(pair=>pair.Value)
.Select(pair=>pair.Key);
Mas eu não testei.Portanto, ainda pode haver bugs.
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow