zoukankan      html  css  js  c++  java
  • c# 多线程的几种方式

    1.什么是线程?

    进程作为操作系统执行程序的基本单位,拥有应用程序的资源,进程包含线程,进程的资源被线程共享,线程不拥有资源。


    2.前台线程和后台线程的区别?

    程序关闭时,后台线程直接关闭,但前台线程会执行完后关闭。

    通过Thread类新建线程默认为前台线程。其他方式创建的都是后台线程。


    多线程的几种方式

    一. 异步多线程

            static void Main(string[] args)
            {
                Console.WriteLine("----------主程序开始,线程ID是{0}-----------------", Thread.CurrentThread.ManagedThreadId);
                for(int i = 0; i< 5;i++)
                {
                    Action<string> action = t =>
                    {
                        for(int k = 0; k< 1000000000;k++)
                        { }
                        Console.WriteLine("当前参数是{0},当前线程是{1}",t,Thread.CurrentThread.ManagedThreadId);
                    };
    
                    action.BeginInvoke("参数是" + i, null, null);
                }
                Console.WriteLine("----------主程序结束,线程ID是{0}-----------------", Thread.CurrentThread.ManagedThreadId);
                Console.Read();
            }
        }

    二. Threads线程

            static void Main(string[] args)
            {
                Console.WriteLine("----------主程序开始,线程ID是{0}-----------------", Thread.CurrentThread.ManagedThreadId);
                for(int i = 0; i< 5;i++)
                {
                    ParameterizedThreadStart threadStart = t =>
                    {
                        for (int k = 0; k < 1000000000; k++)
                        { }
                        Console.WriteLine("当前参数是{0},当前线程是{1}", t, Thread.CurrentThread.ManagedThreadId);
                    };
    
                    Thread thread = new Thread(threadStart);
    
                    thread.Start(i);
                }
                Console.WriteLine("----------主程序结束,线程ID是{0}-----------------", Thread.CurrentThread.ManagedThreadId);
    
                Console.Read();
            }

    三. ThreadPool线程池

            static void Main(string[] args)
            {
                Console.WriteLine("----------主程序开始,线程ID是{0}-----------------", Thread.CurrentThread.ManagedThreadId);
                for(int i = 0; i< 5;i++)
                {
                    WaitCallback waitCallback = t =>
                    {
                        for (int k = 0; k < 1000000000; k++)
                        { }
                        Console.WriteLine("当前参数是{0},当前线程是{1}", t, Thread.CurrentThread.ManagedThreadId);
                    };
    
                    ThreadPool.QueueUserWorkItem(waitCallback, i);
                }
                Console.WriteLine("----------主程序结束,线程ID是{0}-----------------", Thread.CurrentThread.ManagedThreadId);
    
                Console.Read();
            }

    四. Task

            static void Main(string[] args)
            {
                Console.WriteLine("----------主程序开始,线程ID是{0}-----------------", Thread.CurrentThread.ManagedThreadId);
    
                TaskFactory taskFactory = new TaskFactory();
    
                for (int i = 0; i< 5;i++)
                {
                    Action<object> action = t =>
                    {
                        for (int k = 0; k < 1000000000; k++)
                        { }
                        Console.WriteLine("当前参数是{0},当前线程是{1}", t, Thread.CurrentThread.ManagedThreadId);
                    };
    
                    taskFactory.StartNew(action,i);
                }
                Console.WriteLine("----------主程序结束,线程ID是{0}-----------------", Thread.CurrentThread.ManagedThreadId);
    
                Console.Read();
            }

    五. Parallel

            static void Main(string[] args)
            {
                Console.WriteLine("----------主程序开始,线程ID是{0}-----------------", Thread.CurrentThread.ManagedThreadId);
    
    
                Action action1 = () =>
                {
                    for (int k = 0; k < 1000000000; k++)
                    { }
                    Console.WriteLine("当前参数是1,当前线程是{0}", Thread.CurrentThread.ManagedThreadId);
                };
                Action action2 = () =>
                {
                    for (int k = 0; k < 1000000000; k++)
                    { }
                    Console.WriteLine("当前参数是2,当前线程是{0}", Thread.CurrentThread.ManagedThreadId);
                };
                Action action3 = () =>
                {
                    for (int k = 0; k < 1000000000; k++)
                    { }
                    Console.WriteLine("当前参数是3,当前线程是{0}", Thread.CurrentThread.ManagedThreadId);
                };
    
                Parallel.Invoke(action1, action2, action3);
    
                Console.WriteLine("----------主程序结束,线程ID是{0}-----------------", Thread.CurrentThread.ManagedThreadId);
    
                Console.Read();
            }
    上面简单介绍了5种多线程的使用方式,后续文章会记录每种多线程的详细使用方法.
  • 相关阅读:
    CentOS6.5 升级 Python 2.7 版本
    mysql 主从实施步骤
    innodb_log_buffer_size和innodb_buffer_pool_size参数说明
    mysql innodb_log_buffer_size和 innodb_buffer_pool_size设置
    8.2.1.8 IS NULL Optimization IS NULL 优化 (索引不存储NULL值)
    8.2.1.7 Use of Index Extensions 索引扩展使用
    8.2.1.5 Engine Condition Pushdown Optimization 引擎优化条件推入
    报表引擎API开发入门—简单程序数据集
    8.2.1.4 Index Merge Optimization
    8.2.1.3 Range Optimization 范围优化
  • 原文地址:https://www.cnblogs.com/yangxi1081/p/9639958.html
Copyright © 2011-2022 走看看