(연관된 글이 1개 있습니다.)
선생님 안녕하세요!
오랜만에 사이트 방문했는데 약간 구조가 변경되었네요.
하지만 저는 질문 전에 공지사항을 먼저 읽기 때문에 길을 잃지 않고 여기로 올 수 있었네요^^
// 윈폼에 Button을 하나 추가
namespace WindowsFormsApplication1
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e)
{
Task.Run(() => DisplayPrimeCounts());
}
void DisplayPrimeCounts()
{
for (int i = 0; i < 10; i++)
{
var awaiter = GetPrimesCountAsync(i * 1000000 + 2, 1000000).GetAwaiter();
awaiter.OnCompleted(() =>
Debug.WriteLine(awaiter.GetResult() + " primes between " + (i * 1000000) + " and " + ((i + 1) * 1000000 - 1)));
}
Debug.WriteLine("Done");
}
// 특정 범위 안에 있는 소수 개수를 찾아서 반환하는 함수
Task<int> GetPrimesCountAsync(int start, int count)
{
return Task.Run(() => Enumerable.Range(start, count).Count(
n => Enumerable.Range(2, (int)Math.Sqrt(n) - 1).All(i => n % i > 0)));
}
}
}
F5를 누르면 아래와 같은 출력을 볼 수 있습니다.
[출력 ①] 중단점이 걸리지 않은 경우
Done
78498 primes between 10000000 and 10999999
70435 primes between 10000000 and 10999999
67883 primes between 10000000 and 10999999
65367 primes between 10000000 and 10999999
66330 primes between 10000000 and 10999999
62090 primes between 10000000 and 10999999
63799 primes between 10000000 and 10999999
64336 primes between 10000000 and 10999999
62712 primes between 10000000 and 10999999
63129 primes between 10000000 and 10999999
[출력 ②] for 문에 중단점이 걸린 경우
78498 primes between 3000000 and 3999999
70435 primes between 5000000 and 5999999
67883 primes between 5000000 and 5999999
66330 primes between 6000000 and 6999999
65367 primes between 7000000 and 7999999
64336 primes between 9000000 and 9999999
Done
63799 primes between 10000000 and 10999999
[질문 ①] 중단점이 걸리면 for 문의 변수 i가 먹히는 것 같지만 중간에 1, 2, 4, 8이 빠지고 5는 중복되었습니다.
중단점을 걸지 않고 실행하면 for 문의 변수 i가 먹히지 않습니다.
저는 for 문의 변수 i가 제대로 동작하기를 원했는데 이런 결과의 원인이 궁금합니다.
[질문 ②]
UI가 멈추는 현상을 길게 하기 위해서 고의로 GetPrimesCountAsync() 안에
ParallelEnumerable.Range(start, count) 대신에
Enumerable.Range(start, count)을 사용했는데 확실히 속도가 느리더라고요.
ParallelEnumerable를 한글로 설명한 책이 없어서 어려운 MSDN을 읽어봤는데
(이해되지는 않지만...) ParallelEnumerable는 컴퓨터의 CPU 코어 수를 모두 활용하기 때문에 Enumerable보다 빠르다고 이해했는데 정확히 이해했을까요?
[연관 글]
[최초 등록일: ]
[최종 수정일: 8/30/2023]