放飞你的梦想--翱翔我的天空 | 会员登陆 | 繁體中文 | 站点地图 | 站长博客
 | 网站首页 | 文章中心 | IT 前沿 | 清怡画风 | 视频教程 | 资源下载 | 精彩图库 | 博客文赏 | 天空论坛 | 访客留言 | 音乐版 | 
    本站全新推出IT 前沿频道欢迎大家访问 地址 http://it.tkbbs.com  [风雪残士  2005年12月9日]            本站推出新浪VIVI收藏夹服务,欢迎使用  [风雪残士  2005年10月18日]        
您现在的位置: 翱翔翼站 >> 文章中心 >> 编程开发 >> 网页开发 >> ASP.NET >> 文章正文 今天是:
.NET关于同步、异步及Socket 【字体:
作 者:佚名 文章来源:网络 更新:2006-8-15 1:36:33 点击:







以SOCKET通信中的异步方法为例:

public static ManualResetEvent ConnectDone = new ManualResetEvent(false);

 

    public static void ConnectCallback(IAsyncResult ar)

    {

        Socket sClient = (Socket)ar.AsyncState;

       

        sClient.EndConnect(ar);

       

        Console.WriteLine("Socket connected to {0}", sClient.RemoteEndPoint.ToString());

        ConnectDone.Set();

}

 

    public static void Main(string[] arg)

    {

        try

        {

            IPHostEntry ipHost = Dns.Resolve("127.0.0.1");

            IPAddress ipAddr = ipHost.AddressList[0];

            IPEndPoint endPoint = new IPEndPoint(ipAddr, 11000);

           

            Socket sClient = new Socket(AddressFamily.InterNetwork,

                                        SocketType.Stream, ProtocolType.Tcp);

           

            sClient.BeginConnect(endPoint, new AsyncCallback(ConnectCallback),

                                 sClient);

           

            for (int i = 0; i <5; i++)

                Console.WriteLine("Do Some Other Work.");

           

            byte[] byteData = Encoding.ASCII.GetBytes("Some Data.");

           

ConnectDone.WaitOne();

           

            sClient.BeginSend(byteData, 0, byteData.Length, 0,

                              new AsyncCallback(SendCallback), sClient);

           

            ………

    }

 

(注:ManualResetEvent 允许线程通过发信号互相通信。通常,此通信涉及一个线程在其他线程进行之前必须完成的任务。

ManualResetEvent就像一个信号灯,可以利用它的信号来通知其它线程。它有几个重要的方法:Reset(),Set(),WaitOne()。初始化该对象时,用户可以指定其默认的状态(有信号/无信号),在初始化以后,该对象将保持原来的状态不变直到它的Reset()或者Set()方法被调用,Reset()方法将其设置为无信号状态,Set()方法将其设置为有信号状态。WaitOne()方法使当前线程挂起直到ManualResetEvent对象处于有信号状态,此时该线程将被激活。)

 

本例中,主线程调用ConnectDone.WaitOne();后,主线程阻塞,直到连接操作(即ConnectCallback)完成,因为连接操作完成之后,执行了ConnectDone.Set()将信号灯设置为有信号,由于调用了ManualResetEvent.WaitOne()方法而处在等待状态的主线程将接收到这个信号,于是它接着往下执行,完成后边的工作。

 

同步与异步:

简单地说,同步即程序执行一个方法,等该方法返回之后,继续往下走,

异步:即程序调用一个方法后立即返回,“宏观”而言,主线程与方法线程并行执行。

就本例而言,socket的异步方法BeginConnect被调用后,接着执行主线程中该语句之后的代码,即:

for (int i = 0; i <5; i++)

Console.WriteLine("Do Some Other Work.");

byte[] byteData = Encoding.ASCII.GetBytes("Some Data.");

如果调用的是同步方法,那么,输出“Socket connected to…”一定会在“Do Some Other Work.”之前,因为主线程必须等待同步方法的返回,但是在异步的情况下,将可能在5行“Do Some Other Work.”之间的某个时刻出现“Socket connected to…”的输出(实际情况还依赖于操作系统的线程调度)。

至于在sClient.BeginSend(…)方法之前调用ConnectDone.WaitOne(),则是由于前者依赖于连接操作(即ConnectCallback)的完成,须得同步一下。



文章录入:风雪残士    责任编辑:风雪残士 
  • 上一篇文章:

  • 下一篇文章:
  • 发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    相关文章
    delphi多线程程序示例(与.ne…
    关于在Delphi中应用Iinterne…
    delphi多线程程序示例(与.ne…
    delphi8里在VCL.net使用Ado.…
    基于阻塞Socket(Indy)的远程…
    在delphi.net的VCL.net里使用…
    在Delphi.net中调用COM/COM+
    谈Delphi下Internet的编程技…
    netmessagebuffersend示例
    DELPHI与INTERNET2
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    最新文章 TOP10
    最新热门 TOP10
    最新推荐TOP10
    翱翔翼站拥有本站所有版权! Copyright © 2005 - 2008 5-IT.COM
    本站维护 :风雪残士

    浙ICP备05039908号
    努力打造国内最全的电脑技术资料库