Это не элемент управления, находящийся в отдельном потоке, а запрос, запущенный через элемент управления.
Допустим, у вас есть две вкладки, открытые по разным адресам. Вы нажимаете на ссылку, которая направляет вас на другой сайт на первой вкладке. Тем временем вы нажимаете другую ссылку на второй вкладке.
Во-первых, вам нужно знать, что поток может быть запущен при нажатии на ссылку на первой вкладке, что делает его отзывчивым для графического интерфейса. То же самое относится и ко второй вкладке, когда вы нажимаете на ссылку в ней.
Во-вторых, теперь у нас есть один поток (основной поток, также называемый GUI-потоком), задача которого заключается в обработке взаимодействия с пользователем. Другой поток обрабатывает запрос по ссылке на первой вкладке, а другой поток - по ссылке на второй вкладке.
В-третьих, пока обрабатываются ваши запросы на ссылки для обеих вкладок, вы можете, скажем, открыть новую вкладку и выполнить поиск в Google! Затем для этого требуется, чтобы ваш графический интерфейс реагировал, даже когда приложение, браузер, занято вашими запросами.
В-четвертых, по возвращении фоновых потоков они возвращаются в основной поток, сообщая о результате своей работы, то есть полученный ими веб-ответ с запросом на решение DNS связывал ссылки, по которым щелкнули.
Интересный способ сделать это возможным в C # и сделать его максимально простым - это класс BackgroundWorker
.
Каждый экземпляр BackgroundWorker
представляет поток. Таким образом, вам нужно создать столько экземпляров BackgroundWorker
, сколько требуется приложению при захвате щелчка мыши, когда пользователь нажимает на ссылку. Затем запрос отправляется на событие DoWork()
, которое вызывается при вызове метода RunWorkerAsync()
.
Вот интересный урок о том, как использовать BackgroundWorker