0

我是线程新手,需要很多帮助。我有基于启动线程的事件的代码。问题是我失去了对线程和 thread.abort(); 的引用。不会停止它,因此我的应用程序不会停止。谢谢

using System;
using Gtk;
using NAudio;
using NAudio.Wave;
using System.Threading;

public class Trackbox {
public static Thread thread;
public static void Main() {
    Application.Init();

    //Create the Window
    Window myWin = new Window("Trackbox");
    myWin.SetIconFromFile("Assets//logo.png");
    myWin.Resize(200, 100);


    Button playButton = new Button("Play Sound");
    playButton.Clicked += new EventHandler(playWav);
    myWin.Add(playButton);

    myWin.DeleteEvent += delegate { exitTrackbox(); };
    //Show Everything     
    myWin.ShowAll();


    Application.Run();


}

private static void exitTrackbox() {
    //Doesn't kill the application
    thread.Abort();
    Application.Quit();
}

private static void playWav(object sender, EventArgs e) {
    //Reference to Thread
    thread = new Thread(playWavThread);
    thread.Start();
}

private static void playWavThread()
{
    var soundFile = @"C:\sound.wav";
    using (var wfr = new WaveFileReader(soundFile))
    using (WaveChannel32 wc = new WaveChannel32(wfr) { PadWithZeroes = false })
    using (var audioOutput = new WaveOut())
    {
        audioOutput.Init(wc);
        audioOutput.Play();
        while (audioOutput.PlaybackState != PlaybackState.Stopped)
        {
            Thread.Sleep(20);
        }
        audioOutput.Stop();
    }

}
}

请提供您对这种情况的任何建议。谢谢

4

2 回答 2

0

好吧,不用太深入探讨线程以及如何使用线程和诸如此类的东西(我建议阅读更多关于 C# 中的线程,然后再次尝试 - 通过 C# 的 CLR 这本书有很多关于线程的内容,当然互联网上有很多网站),为了让你的应用程序在这种情况下死掉,你应该将你的线程设置为后台线程:

private static void playWav(object sender, EventArgs e) {
    //Reference to Thread
    thread = new Thread(playWavThread);
    thread.IsBackground = true;
    thread.Start();
}

非后台线程可防止您的应用程序终止,但后台线程会在进程关闭时愉快地死掉。对于任何对正在运行的应用程序不重要的线程,您应该将其设置为后台线程。

于 2013-05-11T22:27:30.513 回答
0

此外,根据最终目标,您可能会考虑使用BackgroundWorker。它似乎提供了您需要的功能以及实现线程取消的能力。此外,这样做的好处是使用 BackgroundWorker 会更快,因为它们使用线程池中的线程。缺点是可用的数量有限,因此如果您使用它们很多,它们可以相互争夺可用的线程池线程。

于 2013-05-11T22:32:23.420 回答