using System.Runtime.CompilerServices;
using System.Text;
public static class ca2
{
public static void Main()
{
var d = new Dictionary<long, string>();
var s = "";
var sb = new StringBuilder();
var rnd = new Random();
var cnt = rnd.Next(8, 12);
for (int i = 0; i < cnt; i++) d.Add(rnd.Next(), $"Name {i}");
foreach (var v in d) sb.Append($"{v.Value} = {v.Key}, ");
s = sb.ToString();
s = s.Substring(0, s.Length - 2);
s.print();
}
public static void print(this string s) => Console.WriteLine(s);
}
... если интересует производительность StringBuilder
впереди планеты всей... Проблема в том, что для LinkedList операция чтения O(n), вставки - O(1). Для List - операция чтения O(1), вставки - O(n). Получается, что скорость равна?если n=1, умозрительно да...
if((ArrayNumber[i][k] === ArrayNumber[i][k+1]) ||
ArrayNumber[i][k] === ArrayNumber[i+1][k]))
{...}
if((ArrayNumber[i][k] === ArrayNumber[i][k+1]) ||
ArrayNumber[i][k] === ArrayNumber[i+1][k]) ||
ArrayNumber[i][k] === ArrayNumber[i+1][k+1]))
{...}
CancellationToken token = cancelTokenSource.Token;
///...
Task task2 = new Task(() =>
{
for (int i = 1; i < 10; i++)
{
if (token.IsCancellationRequested)
{
Console.WriteLine("Операция прервана");
return;
}
Console.WriteLine($"2. Квадрат числа {i} равен {i * i}");
Thread.Sleep(200);
}
});
.. они у тебя в одной области видимости, и ты бодро проверяешь статус завершения.. зачем? ;)))using System.Threading.Tasks;
using System.Threading;
using System;
class cancelTokenTest
{
static void Main(string[] args)
{
var cancelTokenSource = new CancellationTokenSource();
var token = cancelTokenSource.Token;
var cancelTokenSource2 = new CancellationTokenSource();
var token2 = cancelTokenSource2.Token;
var task = new Task(() =>
{
for (int i = 1; i < 100000; i++)
{
if (token.IsCancellationRequested)
{
Console.WriteLine("Операция 1 прервана");
return;
}
Console.WriteLine($"1. Квадрат числа {i} равен {i * i}");
Thread.Sleep(200);
}
}, token);
var task2 = new Task(() =>
{
for (int i = 10; i < 1000000; i++)
{
if (token2.IsCancellationRequested)
{
Console.WriteLine("Операция 2 прервана");
return;
}
Console.WriteLine($"2. Квадрат числа {i} равен {i * i}");
Thread.Sleep(200);
}
}, token2);
task.Start();
task2.Start();
Thread.Sleep(1000);
cancelTokenSource.Cancel();
Thread.Sleep(50); // без этого не успевает обновиться статус у меня..
Console.WriteLine($"Task Status 1: {task.Status}");
Thread.Sleep(1000);
cancelTokenSource2.Cancel();
Thread.Sleep(200); // можете закаментить для сравнения, и поиграть со значениями..
Console.WriteLine($"Task Status 2: {task2.Status}");
cancelTokenSource.Dispose();
cancelTokenSource2.Dispose();
}
}
using System.Runtime.CompilerServices;
public static class cancelTokenTest8and2task
{
public static void print(this string s) => Console.WriteLine(s);
public static void Main()
{
var ts1 = new CancellationTokenSource();
var tk1 = ts1.Token;
var ts2 = new CancellationTokenSource();
var tk2 = ts2.Token;
var t1 = new Task(() => {
for (int i = 1; i < 100000; i++)
{
if (tk1.IsCancellationRequested)
{
"Операция t1 прервана".print();
return;
}
$"t1. Квадрат числа {i} равен {i * i}".print();
Thread.Sleep(200);
}
});
var t2 = new Task(() => {
for (int i = 1; i < 100000; i++)
{
if (tk2.IsCancellationRequested)
{
"Операция t2 прервана".print();
return;
}
$"t2. Корень числа {i} равен {Math.Sqrt(i)}".print();
Thread.Sleep(200);
}
});
t1.Start();
t2.Start();
Thread.Sleep(1000);
ts1.Cancel();
Thread.Sleep(50);
$"\nTask1 status: {t1.Status}".print();
Thread.Sleep(1000);
ts2.Cancel();
Thread.Sleep(200);
$"\nTask2 status: {t2.Status}".print();
ts1.Dispose();
ts2.Dispose();
}
}
работает в дот нет 8 ... кроме using System.Runtime.CompilerServices;
я разницы пока не вижу (имена не в счет!)...