[C#]模拟多人不同面值购票找零的多线程代码解决办法
[C#]模拟多人不同面值购票找零的多线程代码
这篇文章,纯属语言转换文章,引用了他人的思路,修改成C#的线程思想,还有许多不完善的地方,希望在讨论中不断完善.
原来的文章是一个Java写的,作者是java2000_net(老紫竹)
原文地址:http://blog.csdn.net/java2000_net/archive/2008/10/19/3083836.aspx
一个偶然的机会,我看到了那篇文章,感觉思路挺有趣,就想把他转换成C#的来学习.时间紧凑,到12月初才有空来做.(这里罗嗦下,很崇拜两个.net专家:高歌,sp1234)
在这里顺便暗喜下在CSDN混的这几个月,.net版块技术排名挤入四位数.^-^,散分.
这篇文章,纯属语言转换文章,引用了他人的思路,修改成C#的线程思想,还有许多不完善的地方,希望在讨论中不断完善.
原来的文章是一个Java写的,作者是java2000_net(老紫竹)
原文地址:http://blog.csdn.net/java2000_net/archive/2008/10/19/3083836.aspx
一个偶然的机会,我看到了那篇文章,感觉思路挺有趣,就想把他转换成C#的来学习.时间紧凑,到12月初才有空来做.(这里罗嗦下,很崇拜两个.net专家:高歌,sp1234)
在这里顺便暗喜下在CSDN混的这几个月,.net版块技术排名挤入四位数.^-^,散分.
- C# code
public class Test
{
static SalesLady saleslady = new SalesLady(14, 0, 0);
static EventWaitHandle wh = new AutoResetEvent(false);
static void Main()
{
int[] moneies = { 10, 10, 5, 10, 5, 10, 5, 5, 10, 5, 10, 5, 5, 10, 5 };
Thread[] aThreadArray = new Thread[20];
Console.WriteLine("现在开始售票:");
for (int i = 0; i < moneies.Length; i++)
{
CustomerClass cc = new CustomerClass(i + 1, moneies[i]);
aThreadArray[i] = new Thread(cc.run);
aThreadArray[i].Start();
Thread.Sleep(0);
}
for (int i = 0; i < moneies.Length; i++)
{
try
{
aThreadArray[i].Join();
}
catch (Exception e)
{
Console.WriteLine(e.ToString());
}
}
Console.WriteLine("票已售完" + saleslady.memontoes);
Console.Read();
}
class SalesLady
{
public int memontoes, five, ten;
public SalesLady(int m, int f, int t)
{
memontoes = m;
five = f;
ten = t;
}
public String ruleForSale(int num, int money)
{
String s = null;
if (memontoes <= 0)
return "对不起,已经售完";
if (money == 5)
{
memontoes--;
five++;
s = "给你票,你的钱正好。";