C# C/S 架构问题

ericle03 2009-04-28 09:16:19
socket的 accept 问题,代码如下
try
{
while(true)
{
Socket socket=new Socket(...,..,..);
socket.Bind(...);
socket.listen(...);
Socket newSocket=socket.accept();
if(newSocket!=null)
{
Thread thread=new Thread(run);
thread.Start();
richBox.text="111";
}
}
}
catch(..)
{..}
基本上,这个就是核心的代码了,
不过有下面几个地方报错;

报错内容 " 一般来说一个socket只允许访问一次," 每个socket只接受一个客户端连接就不能再 accept了,

第二个问题, richbox1 无法访问,报错内容 “无法对非线程richbox1访问” , 小生郁闷了,

如果使用java 这些个问题我都能很容易得处理,不过 C#中,我该怎么处理呢?

注: richbox是server端的一个 控件
...全文
149 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
friend555 2009-04-30
  • 打赏
  • 举报
回复
学习
Sysping1 2009-04-28
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 jingshuaizh 的回复:]
引用 3 楼 DREAM_LSQ 的回复:
Socket socket=new Socket(...,..,..);
socket.Bind(...);
socket.listen(...);
这三条语句应该放到while的外面。并且不用了就要释放socket。

2、线程间的直接访问是不安全的,可以使用代理(delegate)来处理。


richbox1访问 要用 invoke
VS2005 多线程问题--窗体中的线程安全调用 part1(2008-08-26 11:19:02)标签:杂谈 分类:ASP.NET/C#
访问 Windows 窗体控件本质上不是…
[/Quote]
UP,UP,UP!
蓝海D鱼 2009-04-28
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 DREAM_LSQ 的回复:]
Socket socket=new Socket(...,..,..);
socket.Bind(...);
socket.listen(...);
这三条语句应该放到while的外面。并且不用了就要释放socket。

2、线程间的直接访问是不安全的,可以使用代理(delegate)来处理。
[/Quote]

richbox1访问 要用 invoke
VS2005 多线程问题--窗体中的线程安全调用 part1(2008-08-26 11:19:02)标签:杂谈 分类:ASP.NET/C#
访问 Windows 窗体控件本质上不是线程安全的。如果有两个或多个线程操作某一控件的状态,则可能会迫使该控件进入一种不一致的状态。还可能出现其他与线程相关的 bug,包括争用情况和死锁。确保以线程安全方式访问控件非常重要。

.NET Framework 有助于在以非线程安全方式访问控件时检测到这一问题。在调试器中运行应用程序时,如果创建某控件的线程之外的其他线程试图调用该控件,则调试器会引发一个 InvalidOperationException,并提示消息:“从不是创建控件 control name 的线程访问它。”

有三种方法可以从线程访问Win窗体的控件:非线程安全方式;线程安全调用;使用BackgroundWorker进行的线程安全调用。其中,只有线程的安全调用可以宏观并行处理。(另外两种方式都是在线程运行时接受命令,但在线程执行完以后才执行)。

一:对Windows窗体控件的非线程安全调用

该方式是从辅助线程直接调用。调用应用程序时,调试器会引发一个InvalidOperationException,警告对控件的调用不是线程安全的。

可以通过将 CheckForIllegalCrossThreadCalls 属性的值设置为 false 来禁用此异常。这会使控件以与在 Visual Studio 2003 下相同的方式运行。

具体做法如下:



public Form1()
...{
InitializeComponent();
Control.CheckForIllegalCrossThreadCalls = false;//这一行是关键 用于对线程的不安全调用
}


二:对Windows窗体控件的线程安全调用

对窗体控件的线程安全调用需要用委托的方式。

主要思路:

1、查询控件的 InvokeRequired 属性。

2、如果 InvokeRequired 返回 true,则使用实际调用控件的委托来调用 Invoke。

3、如果 InvokeRequired 返回 false,则直接调用控件。

例子:在TextBox控件中输出相应的信息,SetText为textbox的内容设置方法,SetTextDelegate的委托类型封装 SetText方法。TextBox控件的InvokeRequired返回true是,SetText方法创建SetTextDelegate的一个实例,并调用窗体的Invoke方法。是的SetText方法被创建TextBox控件的线程调用。



// 该事件句柄创建一个对窗体控件线程安全调用的线程

private void setTextSafeBtn_Click( object sender, EventArgs e)
...{
this.demoThread =
new Thread(new ThreadStart(this.ThreadProcSafe));

this.demoThread.Start();
}

// 该方法在Worker线程中执行并且发出一个线程安全的调用

private void ThreadProcSafe()
...{
this.SetText("This text was set safely.");
}

//如果被调用的线程和创建的TextBox控件不同,该方法就创建一个SetTextCallback,

// 并且用Invoke方法异步调用自己。
// 如果相同,则直接调用方法设置Text的属性。

private void SetText(string text)
...{
// 获取的InvokeRequired将调用的线程ID和创建的线程ID向比较。
//如果两个线程ID不同,则返回true

if (this.textBox1.InvokeRequired)
...{
SetTextCallback d = new SetTextCallback(SetText);
this.Invoke(d, new object[] ...{ text });
}
else
...{
this.textBox1.Text = text;
}
}
sushou2009 2009-04-28
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 yangqidong 的回复:]
try
{
Socket socket=new Socket(...,..,..);
socket.Bind(...);
socket.listen(...);
while(true)
{
Socket newSocket=socket.accept();
if(newSocket!=null)
{
Thread thread=new Thread(run);
thread.Start();
richBox.text="111";
}
}
}
catch(..)
{..}

和java其实差不多
[/Quote]

UP一下~~
saisky 2009-04-28
  • 打赏
  • 举报
回复
恩,委托处理
DREAM_LSQ 2009-04-28
  • 打赏
  • 举报
回复
Socket socket=new Socket(...,..,..);
socket.Bind(...);
socket.listen(...);
这三条语句应该放到while的外面。并且不用了就要释放socket。

2、线程间的直接访问是不安全的,可以使用代理(delegate)来处理。
快40的码农 2009-04-28
  • 打赏
  • 举报
回复
要用到委托:
希望对楼主有所启发
delegate void SetTextCallback(string text);
private void SetText(string text)
{
if (this.inforMg.InvokeRequired)
{
SetTextCallback d = new SetTextCallback(SetText);
this.Invoke(d, new object[] { text });
}
else
{
this.inforMg.Text = text;
}
}
yangqidong 2009-04-28
  • 打赏
  • 举报
回复
try
{
Socket socket=new Socket(...,..,..);
socket.Bind(...);
socket.listen(...);
while(true)
{
Socket newSocket=socket.accept();
if(newSocket!=null)
{
Thread thread=new Thread(run);
thread.Start();
richBox.text="111";
}
}
}
catch(..)
{..}

和java其实差不多

111,126

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Creator Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧