[unity] c# 扩展知识点其一 【个人复习笔记/有不足之处欢迎斧正/侵删】

.NET

微软的.Net既不是编程语言也不是框架,是类似于互联网时代、次时代、21世纪、信息时代之类的宣传口号,是一整套技术体系的统称,或者说是微软提供的技术平台的代号.

1.跨语言
只要是面向.NET平台的编程语言(C#、VB、 C++、 F#等等),用其中一种语言编写的内容可以无缝地用在另一种语言编写的应用程序中

CLS:一种语言互操作的便准规范

CLI :公共语言基础结构。是微软将CTS等内容提交给国际组织计算机制造联合会ECMA的一个工业标准


2.跨平台
一次编译, 不需要任何代码修改,应用程序就可以运行在任意有.NET框架实现的操作系统上,即代码不依赖于操作系统,也不依赖硬件环境

.net Framework:

体系结构

制作应用程序
编程语言+调用各种类库进行开发生成程序集
        1.只要支持CLS公共语言规范的语言都可以用于开发Windows下的各种应用程序和网站程序
        2.BCL (基础类库)和FCL (框架类库)是这个框架体系中为我们实现好的各种API
        3.程序集的表现就是后缀为.dll或者exe格式的文件

.Net Framework是一个主要用于跨语言开发Windows操作系统下的应用程序的框架结构,并不支持跨平台

.net Core

 是.Net Framework的翻版实现,它是一个开源项目,是基于.Net Framework来进行设计的主要目的就是跨平台,是.Net技术框架组成在Windows、MacOS、 类Linux系统 下的具体实现

Mono

相对.Net FrameWork最大的区别就是具备跨平台的能力,不仅可以运行在Windows、MacOS、Linux等操作系统,甚至还可以运行在PS3、XBOX、Wii等主机平台上

Mono与Unity

Unity Engine  :
提供UnityEngine.dlI动态库,各平台不同,C/C+ +编写,包含平台相关代码、图形API、物理引擎、灯光等等所有游戏引擎底层内容
Unity Editor (编辑器)
提供UnityEditor.dII动态库,大部分由C#编写,用户脚本最初可以使用C#、JavaScript、Boo语言编写, 项目代码最后由Mono编译

Mono主要构成部分:
1.C#编译器(mcs)
2.Mono Runtime类似CLR公共语言运行时(虚拟机)包括JIT (Just in time)即时编译器、AOT (Ahead of time)提前编译器、GC、类库加载器等等
3.BCL基础类库
4.Mono类库:提供很多超出.Net的一些额外功能,主要用于构建各种操作系统上的应用

C# 命名与可选参数、动态类型语法

Test(f:3.3f ,i:5 ,b:false);
//每个参数可以按照参数名字进行指定public void Test(int i,float f,bool b){}//可以配合可选参数的使用,跳过一些默认参数,直接赋值后面的默认参数
lu(1,s:"234");
public void lu(int i,bool b=false,string s="456"){}//动态类型
//dynamic 只在编译时存在,运行时不存在
//需要将UNity的.NET API兼容级别切换到.NET 4.x
//IL2CPP不支持C# dynamic关键字 ,且无法自动补全dynamic dyn =1;
object ji=2;
print(ji.GetType());
print(dyn.GetType());
//输出都是INT32

线程与线程池

UNITY中的线程:

        1. Unity支持多线程
        2. Unity中开启的多线程不能使用主线程中的对象
        3. Unity中开启多线程后一定要关闭

Thread t = new Thread (()=>{while(true){print("HFUTER");Thread.Sleep(1000);}});t.Start();

线程池

命名空间:System.Threading

类名:ThreadPool(线程池)

ThreadPool中有若干数量的线程,如果有任务需要处理时,会从线程池中获取个空闲的线程来执行任务,任务执行完毕后线程不会销毁,而是被线程池回收以供后续任务使用。当线程池中所有的线程都在忙碌时,又有新任务要处理时,线程池才会新建一个线程来处理该任务 ,如果线程数量达到设置的最大值,任务会排队,等待其他任务释放线程后再执行,线程池能减少线程的创建,节省开销,可以减少GC垃圾回收的触发

但是不能控制线程池中线程的执行顾序,也不能获取线程池内线程取消/异常/完成的通知

//获取可用的工作线程数和I/O线程数
int num1;
int num2;
ThreadPool.GetAvailableThreads(out num1,out num2);//获取最大可用的工作线程数和I/O线程数
ThreadPool.GetMaxThreads(out num1,out num2);ThreadPool.SetMaxThreads(20,20);
//设置最多开20个线程ThreadPool.GetMaxThreads(out nums1,out num2);

(线程池里的线程 就是一个个没有运行的 线程对象不存在关闭这一说)

Task 任务类

Task是在线程池基础上进行的改进,拥有线程池的优点,解决了使用线程池不易控制的弊端
是基于线程池的优点对线程的封装,可以更方便高效的进行多线程开发
一个Task对象就是一个线程

 创建Task

//无返回值
Task t1 =new Task(()=>{while(true){print("HFUTER");
Thread.Sleep(1000);
//1s
}
});
//是基于线程池规则的Task t2 =Task.Run(()=>{while(true){print("HFUTER2");
Thread.Sleep(1000);
//1s
}
});Task.Factory.StartNew(()=>{while(true){print("HFUTER3");
Thread.Sleep(1000);
//1s
}
});//有返回值
Task <int>t11 =new Task<int>(()=>{while(true){print("HFUTER");
Thread.Sleep(1000);
//1s
}
return 1;
});Task<string> t21 =Task.Run<string>(()=>{while(true){print("HFUTER2");
Thread.Sleep(1000);
//1s
}
return "yuan";
});Task<float>t33 = Task.Factory.StartNew<float>(()=>{while(true){print("HFUTER3");
Thread.Sleep(1000);
//1s
}return 4.5f;
});

注意:Result获取结果时会阻塞线程

//同步执行
Task t =new Task(()=>{Thread.Sleep(1000);
});
t.RunSynchronously();//wait方法,等待任务执行完毕,再执行后面的内容
Task lu =new Task(()=>{Thread.Sleep(1000);
});Task ji =new Task(()=>{Thread.Sleep(1000);
});lu.Wait();//WaitAny
Task.WaitAny(lu,ji);
//至少一个任务完成才会执行后面的逻辑

异步方法async和await

async和await一般需要配合Task进行使用
async用于修饰函数、lambda表达式、 匿名函数
await用于在函数中和async配对使用,主要作用是等待某个逻辑结束,此时逻辑会返回函数外部继续执行,直到等待的内容执行结束后,再继续执行异步函数内部逻辑
在一 个async异步函数中可以有多个await等待关键字

public async void TestAsync(){print("123");
//不能使用ref和out关键字await Task.Run(()=>{});}

资源异步加载可以是使用async和await

不过unity大部分异步加载方式不支持async和await(c# 5 才推出的功能,老的异步加载内容不兼容)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/503534.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

雅马哈伺服器TS-S系列说明具体详情内容可参看PDF目录内容

雅马哈伺服器TS-S系列说明具体详情内容可参看PDF目录内容

快递平台独立版小程序源码|带cps推广营销流量主+前端

源码介绍&#xff1a; 快递代发快递代寄寄件小程序可以对接易达云洋一级总代 快递小程序&#xff0c;接入云洋/易达物流接口&#xff0c;支持选择快递公司&#xff0c;三通一达&#xff0c;极兔&#xff0c;德邦等&#xff0c;功能成熟 如何收益: 1.对接第三方平台成本大约4元…

低密度奇偶校验码LDPC(七)——SPA和积译码算法的简化

一、SPA译码算法的实际应用 查找表与拟合 盒加SPA译码器 二、SPA译码算法的简化算法 最小和算法(MSA) 归一化最小和算法(Normalized MSA, NMSA) 偏移最小和算法(Offset MSA, OMSA) 三、NMSA算法的Matlab实现 function [x_hat, iter_this_time] Layered_NMSA_BP_decoder(ll…

【C语言】linux内核xmit_one函数

一、中文注释 static int xmit_one(struct sk_buff *skb, struct net_device *dev,struct netdev_queue *txq, bool more) {unsigned int len;int rc;// 如果全局ptype列表或者设备特定的ptype列表不为空&#xff0c;则执行网络接口层网络层的NIT&#xff08;Network Tap&…

GenAI助力DevOps,塑造软件工程的未来

自 2022 年以来&#xff0c;GenAI 无疑已成为一种普遍的技术趋势。在本文中&#xff0c;我们将探索 DevOps 中令人兴奋的 GenAI 领域&#xff0c;讨论其潜在优势、局限性、新兴趋势和最佳实践&#xff0c;深入了解 AI 支持的 DevOps 前沿世界&#xff0c;并探索这一强大组合如何…

31-k8s集群svc的代理模式-iptables修改为ipvs

一、概述 学到这里&#xff0c;我们都知道&#xff0c;k8s集群的外部网络分发&#xff0c;借助kube-proxy组件来完成&#xff1b; 问题&#xff1a;我们为什么要将代理模式修改为ipvs而不继续使用iptables呐&#xff1f; 因为&#xff1a; 1&#xff0c;iptables底层使用四表五…

SpringBoot整合Redis及其持久化机制(二)

SpringBoot整合Redis及其持久化机制 1、Redis全局命令1.2、Redis事务 2、Redis持久化2.1、RDB方式2.1.1、客户端触发机制2.1.2、服务端触发机制2.2.3、配置生成快照名称和位置2.2.4、优点2.2.5、缺点 2.2、AOF方式2.2.1、优点2.2.2、缺点 2.3、RDB-AOF混合方式2.4、持久化机制的…

路由守卫:前置守卫和后置守卫

聚沙成塔每天进步一点点 本文内容 ⭐ 专栏简介路由守卫&#xff1a;前置守卫和后置守卫1. 前置守卫使用方式全局前置守卫局部前置守卫 2. 后置守卫使用方式全局后置守卫 案例&#xff1a;路由跳转前后权限验证总结 ⭐ 写在最后 ⭐ 专栏简介 Vue学习之旅的奇妙世界 欢迎大家来到…

Node.js中的数据加密和安全传输

在当今日益数字化的世界中&#xff0c;数据安全一直是一个备受关注的话题。Node.js作为一种流行的后端开发技术&#xff0c;其在数据加密和安全传输方面的应用也备受关注。本篇博客将深入探讨Node.js中的数据加密和安全传输相关内容&#xff0c;并为读者提供一些示例代码&#…

1209. 带分数 刷题笔记

思路 暴力匹配 读入目标数 n 看n是否与ab/c相等 因为c里面的除法是整除 我们将 nab/c 转换为 c*na*cb 那么如何获得a,b&#xff0c;c 依题意 a&#xff0c;b&#xff0c;c三个数由1-9九个数字组成 且每个数字只能出现一次 由此 我们可以搜出123456789的全部排列方式…

【YOLO v5 v7 v8 小目标改进】ODConv:在卷积核所有维度(数量、空间、输入、输出)上应用注意力机制来优化传统动态卷积

ODConv&#xff1a;在卷积核所有维度&#xff08;数量、空间、输入、输出&#xff09;上应用注意力机制来优化传统的动态卷积 提出背景传统动态卷积全维动态卷积效果 小目标涨点YOLO v5 魔改YOLO v7 魔改YOLO v8 魔改 论文&#xff1a;https://openreview.net/pdf?idDmpCfq6Mg…

数据库-第二/三章 关系数据库和标准语言SQL【期末复习|考研复习】

前言 总结整理不易&#xff0c;希望大家点赞收藏。 给大家整理了一下计数据库系统概论中的重点概念&#xff0c;以供大家期末复习和考研复习的时候使用。 参考资料是王珊老师和萨师煊老师的数据库系统概论(第五版)。 文章目录 前言第二、三章 关系数据库和标准语言SQL2.1 关系2…