C# 线程无法开启窗口的原因

在 C# 里面, 主窗口拥有主线程, 主线程产生子线程监控 Socket 埠, 子线程一收到数据流就会给主线程发送一个事件, 创建一个窗口. 现在的情况是子线程能够收到数据流, 主窗口能够收到子线程发送过来的事件, 能够创建一个窗口. 这个窗口有问题: 窗口状态像死掉程序的窗口一样, 反白的.
开发碰到很棘手的问题, 寻找解决方法. 品味程序出错过程, 逐步跟踪程序执行过程, 每一行代码每一条语句全部执行, 怪了, 大白天碰到鬼了. 主窗口加入一个按钮, 按钮的作用就是执行主窗口的事件, 启动程序, 点击按钮, 程序正确创建一个窗口, 按照这个测试结果来看, 事件处理中的代码没有任何问题. 在执行程序, 跟踪, 寻找出错的过程. 我觉得程序没有问题, 不应该出现错误; 但是真的出错了, 说明程序一定有问题, 问题是什么呢, 没有答案; 想起以前高人语录: 计算器程序设计就是这么简单, 别管教授专家高手, 写程序出来到计算器上面一跑就知道谁的程序正确, 是骡子是马需要牵出来溜溜. 呀, 找不到答案, 转而上网, 到论坛尽量寻找这种错误相关信息, 时间浪费很多, 结果不是很好, 没有找到答案. 之后和 faust 聊天, 询问这种问题, 他指出一定是讯息回圈和线程之间交互这两个问题中的一个. 顺着 faust 的思路到论坛寻找答案, 很快找到相关讯息.
揭晓最终解决答案, 事件是一个同步处理过程, 就是说虽然子线程触发主窗口事件, 可是执行的线程仍然是子线程, 创建一个窗口 From frm1 = new Form(); Form.Show(); 能够执行, 可是无法收到 Windows Print() 事件, 所以窗口创建没有问题, 就是没有画出窗口上面的东东, 所以窗口像死掉的窗口一样, 反白的. 找到原因怎么处理问题呢? 在线程里面使用 delegateDefine delegateTest = new delegateDefine(this.m_from.eventFunction); this.m_from.Invoke(delegateTest); 就能正常执行程序了. 解决里面最重要的是 Invoke, 如果有兴趣可以看看 Invoke 的介绍.
从问题出现到问题搞定, 花费十个小时, 太辛苦了.

附: 异步委派程序设计范例
下列程序代码示范 .NET 异步程序设计的用法,使用简单类别将一些数字因子分解。
[C#]
using System;
using System.Threading;
using System.Runtime.Remoting;
using System.Runtime.Remoting.Messaging;

// Create an asynchronous delegate.
public delegate bool FactorizingAsyncDelegate (
int factorizableNum,
ref int primefactor1,
ref int primefactor2);

// Create a class that factorizers the number.
public class PrimeFactorizer
{
public bool Factorize(
int factorizableNum,
ref int primefactor1,
ref int primefactor2)
{
primefactor1 = 1;
primefactor2 = factorizableNum;

// Factorize using a low-tech approach.
for (int i=2;i<factorizableNum;i++)
{
if (0 == (factorizableNum % i))
{
primefactor1 = i;
primefactor2 = factorizableNum / i;
break;
}
}

if (1 == primefactor1 )
return false;
else
return true ;
}
}

// Class that receives a callback when the results are available.
public class ProcessFactorizedNumber
{
private int _ulNumber;

public ProcessFactorizedNumber(int number)
{
_ulNumber = number;
}

// Note that the qualifier is one-way.
[OneWayAttribute()]
public void FactorizedResults(IAsyncResult ar)
{
int factor1=0, factor2=0;

// Extract the delegate from the AsyncResult.
FactorizingAsyncDelegate fd = (FactorizingAsyncDelegate)((AsyncResult)ar).AsyncDelegate;

// Obtain the result.
fd.EndInvoke(ref factor1, ref factor2, ar);

// Output the results.
Console.WriteLine("On CallBack: Factors of {0} : {1} {2}",
_ulNumber, factor1, factor2);
}
}

// Class that shows variations of using Asynchronous
public class Simple
{
// The following demonstrates the Asynchronous Pattern using a callback.
public void FactorizeNumber1()
{
// The following is the client code.
PrimeFactorizer pf = new PrimeFactorizer();
FactorizingAsyncDelegate fd = new FactorizingAsyncDelegate (pf.Factorize);

int factorizableNum = 1000589023, temp=0;

// Create an instance of the class that is going
// to be called when the call completes.
ProcessFactorizedNumber fc = new ProcessFactorizedNumber(factorizableNum);

// Define the AsyncCallback delegate.
AsyncCallback cb = new AsyncCallback(fc.FactorizedResults);

// You can use any object as the state object.
Object state = new Object();

// Asynchronously invoke the Factorize method on pf.
IAsyncResult ar = fd.BeginInvoke(
factorizableNum,
ref temp,
ref temp,
cb,
state);

//
// Do some other useful work.
//. . .
}

// The following demonstrates the Asynchronous Pattern using a BeginInvoke, followed by waiting with a time-out.
public void FactorizeNumber2()
{
// The following is the client code.
PrimeFactorizer pf = new PrimeFactorizer();
FactorizingAsyncDelegate fd = new FactorizingAsyncDelegate (pf.Factorize);

int factorizableNum = 1000589023, temp=0;

// Create an instance of the class that is going
// to be called when the call completes.
ProcessFactorizedNumber fc = new ProcessFactorizedNumber(factorizableNum);

// Define the AsyncCallback delegate.
AsyncCallback cb =
new AsyncCallback(fc.FactorizedResults);

// You can use any object as the state object.
Object state = new Object();

// Asynchronously invoke the Factorize method on pf.
IAsyncResult ar = fd.BeginInvoke(
factorizableNum,
ref temp,
ref temp,
null,
null);

ar.AsyncWaitHandle.WaitOne(10000, false);

if (ar.IsCompleted)
{
int factor1=0, factor2=0;

// Obtain the result.
fd.EndInvoke(ref factor1, ref factor2, ar);

// Output the results.

Console.WriteLine("Sequential : Factors of {0} : {1} {2}",
factorizableNum, factor1, factor2);

}
}

public static void Main(String[] args)
{
Simple simple = new Simple();
simple.FactorizeNumber1();
simple.FactorizeNumber2();
}
}

时间: 2024-08-22 14:20:52

C# 线程无法开启窗口的原因的相关文章

win7系统如何开启窗口透明功能

  win7系统如何开启窗口透明功能         1.首先,咱们返回到win7电脑的桌面界面,然后在桌面随便找一块空白处,右键点击,选择个性化. 2.在弹出来的个性化窗口之中,咱们点击界面下方的窗口颜色选项. 3.之后就会出现如下图中所示的窗口颜色和外观设置界面了,咱们看到界面中部有一个"启用透明效果"的选项,如果大家想要开启窗口透明效果功能的话,就直接在这里将该项勾选上,然后点击下方的保存修改按钮即可.

分析win7远程桌面开启失败的原因

很多人对于远程控制的认知,还停留在QQ的远程控制里面.但是现在越来越多的人上班的时候,用一台电脑而家里还有一台电脑开着,有的时候,需要用家里的电脑控制上班用的电脑或者上班用的电脑需要控制家里的电脑.这时候就不可能通过QQ的远程控制来实现了.这里没有教你如何实现2台电脑的互相控制,而是叫你win7要实现2台电脑互相控制的先决条件,也就是win7远程桌面开启失败的原因 . 1 win7远程桌面开启失败的原因 : 1:防火墙没有关闭 2:有没有设置账号跟密码 3:开启windows服务 2 要开启远程

win7电脑如何开启窗口透明功能

  说起来,aero特效功能算是win7 64位旗舰版的亮点所在了,它不仅可以让咱们的win7电脑界面看起来更加的华丽,也能让咱们感受到系统更加强大的立体感,特别是当aero特效应用在缩略图.动画等窗口之上时,这种华丽的感觉也就更加凸显,下面,咱们就来介绍一下关于这个功能的另一个常用功能,如何关闭和启动窗口的透明效果. 1.首先,咱们返回到win7电脑的桌面界面,然后在桌面随便找一块空白处,右键点击,选择个性化. 2.在弹出来的个性化窗口之中,咱们点击界面下方的窗口颜色选项. 3.之后就会出现如

Win7系统还原无法开启是什么原因?

  系统还原无法打开,建议及逐步采取以下步骤: 第一,有可能没有开启Microsoft Software Shadow Copy Provider此项服务或者是优化软件关闭了此服务,使用系统还原功能必须开启此服务. 在开始搜索框中输入services,点击services.exe打开服务管理器,找到该服务项开启即可. 第二,有可能C盘没有开启系统保护所致,打开即可.右击计算机图标,选择属性,点击左侧的系统保护,看看是否C盘开启了系统还原. 如果没有的话,点击配置,选择第一项即可. 第三,最后的一

猎豹免费Wifi开启失败的原因与解决办法

最近很多安装金山新毒霸的朋友都会看到,一个猎豹免费Wifi广告对话框,内容为"猎豹免费Wifi--永久免费无线路由器--从此手机免费上次,从此尽享无线快乐!",如下图所示.很多网友按照提示,点击立即开启Wifi,导致无法实现其所神呼的永久免费上网.猎豹免费Wifi开启失败是什么原因呢? 其实猎豹免费Wifi只不过是一个简单的将电脑网络共享为Wifi无线网络的工具,其实与Wifi共享精灵等软件功能一样,但是有一个前提是,您的电脑必须有无线网卡,并且开启了无线网卡,才能实现将可以上网的电脑

Silverlight+WCF 实战-网络象棋最终篇之非线程阻塞倒计时窗口(四)

前言: 在前面的系列中,我们虽然完成了其大部分功能,但是,离正真运行,还是有一大段距离 当你F5运行时,在弹出对话框之后,如果你不即时点确定,或者上个WC回来之后,你会发现已经提示出错了 这节开始,我们将对其进行一小步一小步的优化,来避免一些明显容易引发的错误.   感知一下最原始的消息弹出框如下图:     一:传统消息框,容易引发命案   1:原始的消息框,是线程阻塞类型的,很容易引发超时问题 线程阻塞?怎么理解? 简单的说就是,WCF服务端给客户端发送了消息提示之后,一直进入等待状态,直到

c# 线程池老是中断 什么原因呢?

问题描述 protectedvoidbtn_Single2_Click(objectsender,EventArgse){try{if(txtSingle2.Text.Trim()==""){return;}M_BaseInfomodel=newB_BaseInfo().SelectOneBaseInfo_List(Convert.ToInt32(txtSingle2.Text.Trim()));ThreadPool.SetMaxThreads(5,5);for(inti=0;i<

线程中开启窗体 请教下

问题描述 需求是窗体from1开线程线程中循环打开窗体from2from3中也有线程确实不会写写成这样帮忙看看有两个错误1.正在终止线程2.由于代码已经过优化或者本机框架位于调用堆栈之上,无法计算表达式的值.voidlinkDevice(){while(true){Thread.Sleep(1000);if(SpeechHelper.Read("S.txt").ToUpper()=="SENDOK"){for(inti=0;i<bdt.Rows.Count;i

11g备库无法开启ADG的原因分析

今天碰到一个有些奇怪的问题,但是奇怪的现象背后都是有本质的因果. 下午在做一个环境的检查时,发现备库是在mount阶段,这可是一个11gR2的库,没有ADG实在是太浪费了,对于这种情况感觉太不应该了. 所以尝试启动至open阶段,发现状态一直是read only,在ADG中应该是READ ONLY WITH APPLY才对啊. 使用dg broker设置为READ-ONLY,备库的数据库日志如下:      Standby Database:           stestdb3, Enable