云阳有没有做网站的,黑龙江能建公司官网,网站icp备案号怎么查询,网站建设的钱计入什么科目c#中的?
1. 空值类型#xff08;Nullable Types#xff09;
? 可以用于值类型#xff08;例如 int、bool 等#xff09;#xff0c;使它们可以接受 null。通常#xff0c;值类型不能为 null#xff0c;但是通过 ? 可以表示它们是可空的。
int? number null; // …c#中的?
1. 空值类型Nullable Types
? 可以用于值类型例如 int、bool 等使它们可以接受 null。通常值类型不能为 null但是通过 ? 可以表示它们是可空的。
int? number null; // 可空类型可以为 null2. 空条件运算符Null-conditional Operator
这个 ? 用在对象或委托前面用于在调用成员或方法时检查对象是否为 null。如果对象为 null那么整个表达式返回 null而不是抛出异常。
MyClass obj null;
int? length obj?.Length; // 如果 obj 为 nulllength 会是 null 而不是抛出异常在委托上也可以用来安全地调用委托避免调用 null 委托时抛出异常
Action action null;
action?.Invoke(); // 如果 action 是 null什么也不做而不会抛出异常3. 空合并运算符Null-coalescing Operator
?? 是另一个与 ? 相关的运算符它用于提供一个默认值当左侧表达式为 null 时返回右侧的值。
string name null;
string displayName name ?? Unknown; // 如果 name 是 nulldisplayName 为 Unknown4. 空合并赋值运算符Null-coalescing Assignment Operator
从 C# 8.0 开始?? 是空合并赋值运算符它判断变量是否为空如果为空就把后面的值给赋上(这里是把后面的“hello world 赋值给message”)。
string message null;
message ?? Hello, World!; // 如果 message 是 null赋值为 Hello, World!5. 三元运算符Ternary Conditional Operator
最后就是最简单常见的用法三元运算符? A:B 条件判断值。
int x 5;
string result (x 3) ? Greater : Less; // 如果 x 大于 3result 是 Greater抽象类 变量和字段抽象类可以定义实例变量字段和静态变量它们可以赋值并存储数据和普通类没有区别。
public abstract class Animal
{public string Name { get; set; } Unnamed Animal; // 普通属性private int age 5; // 私有字段public int GetAge(){return age; // 非抽象方法可以访问私有字段}
}
必须继承才能使用因为抽象类不能直接实例化任何抽象类中的方法、字段和属性都只能通过继承它的类来使用。
单例panel GUI.Label
GUI.Label的重载主要有以下几种
GUI.Label(Rect position, string text)根据指定位置绘制文本标签。GUI.Label(Rect position, GUIContent content)使用GUIContent对象绘制标签可以包含文本和图像。GUI.Label(Rect position, string text, GUIStyle style)使用指定样式绘制标签。GUI.Label(Rect position, GUIContent content, GUIStyle style)使用指定样式和GUIContent绘制标签。
GUI
核心五参 GUI里的东西都是在代码里写的现在更多的是程序测试的作用在lateupdate 和ondisable之间执行只有继承mono才能在OnGUI里写ui unity编译器版本不同issue
使用不同版本的 Unity 编译器时可能会遇到以下问题 API 不兼容 新版本可能移除或更改某些 API导致编译错误或警告。 脚本行为变化 脚本的执行顺序、生命周期方法如 Awake, Start的行为可能会有所不同。 资源导入设置 材质、模型和其他资源在新版本中可能需要重新导入可能导致外观变化。 新特性和弃用 新版本中引入的新特性可能无法在旧版本中使用而被弃用的特性可能在新版本中仍会触发警告。 编辑器界面变化 编辑器的布局和功能可能会有所不同影响工作流程。
git再触发
gitlab是帮用户协同开发的然后里面的概念为组同一个组的就可以协同修改一个项目
组的概念 组 组是一个集合通常包含多个项目和用户。它可以用于组织和管理团队的工作。同一个组的成员可以协同开发共享项目和资源。 项目 一个组可以有一个或多个项目。项目是具体的代码库和开发环境团队成员可以在其中进行协作。 协同开发 组内成员可以对项目进行代码修改、提交、合并请求等操作进行协同开发。组中的权限可以根据角色如拥有者、维护者、开发者等进行设置以控制不同用户的访问和操作权限。
组员权限是怎么样的有等级制度吗
权限等级 拥有者Owner 具有最高权限可以管理组和所有项目设置成员权限删除项目等。 维护者Maintainer 可以进行大多数管理操作包括合并请求、推送代码、管理项目设置等。 开发者Developer 可以推送代码、创建分支、提交合并请求但不能删除项目或修改某些设置。 报告者Reporter 主要用于查看和评论代码可以查看项目但不能推送或更改代码。 访客Guest 权限最低通常只能查看公开项目的信息无法进行任何修改。
首先是进组然后得到组长给的权限这个组里的所有项目都可以看
项目成员
项目可以从组中自动继承成员。如果您将一个项目添加到组中组内的成员可以根据角色访问该项目。也就是你开了新项目默认就把你组里的人全拉进去了但是在项目里你也可以自己再调控成员的权限 只有你自己创建的组你是组长才可以往组里拉人 可以只项目拉人不让他进组是吗是的在 GitLab 中您可以单独将用户添加到某个项目而不将他们添加到整个组。 但在你组里的人会自动继承到你的项目里要改他的权限就必须改组里他的权限 项目单独拉进的人可以改权限组里的则是直接继承权限只能改组的权限
组里可做多个项目每个项目又可单独修改人员而如果是组的人员会继承组里的权限 组里的人在项目里权限只能更高不能更低
组开项目组员权限只能比组里高不能低项目可以邀请非组员任意设置权限大小
组可多个组里的项目也可多个除了组员的权限各个项目相互独立
mono生命周期函数执行顺序
Awake()在对象创建时调用用于初始化。
Start()在所有 Awake() 完成后首次激活时调用适合依赖其他组件的初始化。
梯队一样 执行顺序 Unity 在每一帧中依次检查并调用不同的生命周期方法按以下顺序 Awake()首先检查所有对象的 Awake() 方法并执行。OnEnable()接着检查所有对象的 OnEnable() 方法并执行。Start()然后检查所有对象的 Start() 方法并执行。FixedUpdate()按固定时间间隔调用适用于物理更新。在每个物理帧中执行。Update()最后进入每帧调用的 Update() 方法。LateUpdate()在所有 Update() 方法之后调用所有对象的 LateUpdate() 方法。OnGUIOnDisable()如果对象在这一帧中被失活OnDisable() 会在所有更新方法之后被调用。 激活与失活的影响 激活如果一个对象被激活它的 OnEnable() 会被调用。首次激活时如果对象还没有调用过 Awake() 和 Start()则会按照顺序执行。失活当对象失活时OnDisable() 会被调用之后的 Update() 不会再执行。
FixedUpdate 和 LateUpdate
FixedUpdate
用途FixedUpdate 主要用于处理物理相关的逻辑比如 Rigidbody 的移动和碰撞检测。调用频率它在固定时间间隔内被调用不受帧率影响通常每秒调用 50 次可在项目设置中调整。使用示例 void FixedUpdate()
{// 处理物理运动Rigidbody rb GetComponentRigidbody();rb.MovePosition(rb.position Vector3.forward * Time.fixedDeltaTime);
}LateUpdate 用途LateUpdate 在所有 Update 方法执行后调用适合处理相机跟随、动画等逻辑这样可以确保在更新其他对象后再执行。调用频率与 Update 相同每帧调用一次。使用示例 void LateUpdate()
{// 确保在所有更新后执行比如相机跟随Camera.main.transform.position new Vector3(transform.position.x, transform.position.y 5, transform.position.z - 10);
}FixedUpdate用于物理计算适合处理 Rigidbody。LateUpdate用于依赖于其他对象更新后的逻辑比如相机跟随。
对象失活的注意事项 对象失活 当一个 GameObject 被设为失活时它及其所有子对象的组件包括脚本、渲染器等都不会运行。这意味着 Update、Awake、Start 等生命周期方法都不会被调用。 脚本的执行顺序 Unity 在游戏运行时根据对象的激活状态来决定是否调用脚本的方法。例如只有在对象激活时Awake 和 Start 方法才会被执行。 对象状态的影响 如果您希望在对象激活后执行某些逻辑您需要确保在激活之前设置好所需的数据。可以使用其他方法如事件、消息系统等来在对象激活后通知它执行特定的操作。 检测对象状态 在脚本中可以使用 gameObject.activeSelf 和 gameObject.activeInHierarchy 来检查对象的状态以便在需要时做出适当的响应。
被失活对象的 OnDisable 方法会在当前帧的末尾被调用意味着在调用 SetActive(false) 之后该对象的逻辑在这一帧内可以继续运行直到该帧结束。 1. Controller.cs控制器脚本 这个脚本会在每帧中打印一条消息并在第二次更新时将目标对象失活。 using UnityEngine;public class Controller : MonoBehaviour
{public GameObject targetObject; // 目标对象private int frameCount 0;void Update(){frameCount;Debug.Log(Controller Update - Frame: frameCount);// 在第2帧将目标对象失活if (frameCount 2){Debug.Log(Disabling targetObject);targetObject.SetActive(false);}}
}2. Target.cs目标对象脚本 这个脚本会在每帧中打印一条消息并在被失活时打印另外一条消息。 using UnityEngine;public class Target : MonoBehaviour
{void Update(){Debug.Log(Target Update - Im still active!);}void OnDisable(){Debug.Log(Target has been disabled.);}
}使用说明 创建对象 在 Unity 中创建两个对象一个名为 Controller挂载 Controller.cs另一个名为 Target挂载 Target.cs。 连接目标 在 Controller 对象的 Inspector 中将 Target 对象拖放到 targetObject 字段中。 运行场景 当您运行场景时您将看到控制器每帧打印的信息。到达第二帧时控制器会调用 SetActive(false) 使目标对象失活。 输出示例 在控制台中您可能会看到类似如下的输出 关键点 在第二帧Target 的 Update 方法仍然被调用直到 SetActive(false) 后该对象的 OnDisable 方法被调用。通过这个示例您可以直观感受 SetActive(false) 的效果。 在 Unity 中当您调用 SetActive(false) 使对象失活时所有 MonoBehaviour 的生命周期方法包括 Update、FixedUpdate、LateUpdate 和其他方法会继续在当前帧执行直到该帧结束。
数据保存的问题
对于一个panel脚本挂载到对象身上如果一开始对象就是失活的里面的脚本也不会被执行 也就是里面的初始化数据什么的对象赋值和引用什么的都不成立该对象甚至也为空
如果您需要在对象失活时更新数据例如分数、状态等您可以通过其他脚本或类来管理这些数据。在失活状态下您无法直接修改该对象的数据但可以通过外部逻辑进行修改。
如何保持数据一致性
在激活时更新显示 当您再次激活对象时可以在 OnEnable 方法中读取这些字段并在 UI 或其他地方显示最新的数据。 . 面板数据的保存 数据管理可以通过脚本保存面板的数据例如使用 ScriptableObject、PlayerPrefs 或自定义数据结构。 在失活时保持数据如果一个对象失活其数据不会被清除。您可以在脚本中定义一个变量来保存面板状态然后在对象被激活时读取该数据并更新 UI。 大多数的信息显示同步问题我们看到的打开什么界面的信息显示
其实都是对该显示信息的对象的数值的及时更改达成效果的实际上这个显示信息数据的对象更应该看做是一个数据显示器激活和失活都只是一个显示器的启动和关闭每次如果是要加载新的对象则是一个新的显示器已有显示器的激活和失活则是保留了上一次数据赋值的显示器而已
这个显示器同样存在自己的信息比如transform和各种挂在自己身上的组件因为和外部信息有时候的确是有灰色地带所以确实因为面向对象过头反而让信息有些混乱
NGUI
层级的 depth
NGUI 中层级的 depth 值决定了 UI 元素的渲染顺序depth 值越大元素就会越上面越小的 depth 值则表示该元素位于更底层。
一个slider有三个sprite对象挂谁身上
slider详解
最标准的slider创建为一个空widget不一定要父子关系
带上thumbforegroundbackground三个sprite
fore是slider中变化的sprite所以他attach了collider也没用的foreground作为slider组件挂载对象时除外
collider是作为fore变化的触发区域更详细的说是启动点击拖动的触发区域必须要的不然不能拖动 这个组件关键在于附上了的三个物体仅得到这三个物体的单个组件信息共同达成slider的功能
组件功能总结将该组件下的background的sprite范围thumb的sprite范围 作为拖动触发区域调整foreground的sprite
slider组件与挂载在哪个对象无关仅需在组件内的三个对象信息即可得到slider的完全效果
注若slider脚本挂载对象为foregroundforeground自己的已有条也是可以点的反而繁琐不推荐
概括
最好任一对象挂slider三个sprite往上拖collider加在back或者thumb作为拖动触发区
StreamingAssets
在 Unity 中StreamingAssets 文件夹用于存储游戏在运行时需要直接访问的文件。这些文件可以是文本文件、图像、音频、视频或其他资源Unity 不会对它们进行压缩或加密因此可以在运行时直接读取。
主要特点 直接访问StreamingAssets 中的文件可以通过 Application.streamingAssetsPath 轻松访问。这意味着你可以在游戏运行时直接读取这些文件而不需要使用 Unity 的资源管理器。 平台独立Unity 会根据不同的平台如 Windows、macOS、Android、iOS 等处理 StreamingAssets 中的文件。文件路径在不同平台上可能有所不同但 Unity 会提供正确的路径。 未压缩与资源文件不同StreamingAssets 中的文件不会被 Unity 的打包系统压缩或更改格式因此你可以保存原始文件适合需要读取外部数据的场景。
常见用途
配置文件存储游戏的配置数据如设置、关卡信息等。外部数据加载外部数据文件如 JSON、XML 或文本文件。音频和视频存储大文件如音频和视频以便在游戏中直接播放。
忽略触发器 通过使用 QueryTriggerInteraction你可以在进行物理查询时选择不考虑变成触发器的 Collider。这允许你在射线检测或重叠检测时灵活地决定是否要将触发器包含在内。 RaycastHit hit;
if (Physics.Raycast(ray, out hit, maxDistance, layerMask, QueryTriggerInteraction.Ignore))
{// 处理与非触发器碰撞的逻辑
} 具体用法 QueryTriggerInteraction 有三个选项 UseGlobal使用全局设置通常取决于项目的物理设置可以在unity设置里找到默认情况下会考虑触发器。 Ignore在进行物理查询时忽略所有触发器。这意味着只有非触发器的 Collider 会被考虑。 Collide在进行物理查询时将触发器视为有效的碰撞体这样触发器也会被包含在查询结果中 Collider 组件有一个选项可以勾选“Is Trigger”。当你勾选这个选项时这个 Collider 将变成触发器。
触发器功能触发器不会产生物理碰撞效果物体可以穿过它。
意味着当物体进入或离开触发器区域时会触发相应的事件比如 OnTriggerEnter 或 OnTriggerExit。你可以在这些事件中编写代码以处理进入或离开触发器时要执行的操作。
比如你想制作一个区域当玩家进入这个区域时触发某个事件如打开门、播放动画等这时就可以使用触发器。
忽略碰撞Physics.IgnoreCollision
定义有时候你可能不希望某两个物体之间产生任何碰撞反应不论它们是否为触发器。可以通过编程来实现。
用法
你可以在代码中使用 Physics.IgnoreCollision(colliderA, colliderB) 来忽略两个 Collider 之间的碰撞。这样colliderA 和 colliderB 在物理计算中将不会相互影响。 void Start() {Collider colliderA GameObject.Find(ObjectA).GetComponentCollider();Collider colliderB GameObject.Find(ObjectB).GetComponentCollider();Physics.IgnoreCollision(colliderA, colliderB);
}默认不勾选带了collider的就是真物理碰撞器要是勾了is trigger 就会变成空间感应器
Input.GetAxis
在 Unity 中用于获取轴向输入的值通常用于处理用户的输入例如键盘、鼠标或游戏手柄的输入。这个函数返回一个 float 值表示某个轴的输入值范围通常在 -1 到 1 之间。
具体来说它经常用于移动或旋转角色、物体等场景。比如
Horizontal 轴对应键盘上的左右箭头键或 A、D 键返回值会在 -1左和 1右之间变化。Vertical 轴对应上下箭头键或 W、S 键返回值在 -1下和 1上之间变化。
了解所有的git之类的奇奇怪怪的东西
签出分支 (Checkout Branch) 是 Git 中一个常用的操作主要用于以下几个目的 切换分支 当你执行签出操作时Git 会将你的工作目录切换到指定的分支。这样你就可以开始在该分支上进行开发或查看该分支的内容。 创建新分支 使用 git checkout -b new-branch-name 命令时可以创建一个新分支并立即切换到该分支。这允许你在新分支上开始新的开发工作而不影响其他分支。 恢复文件状态 如果你想查看某个分支在某个特定提交时的状态可以使用签出操作恢复到那个状态。这可以用来检查历史版本或调试。 推送分支是从a推送到b什么意思是把a里的修改合并到b里吗 没戳你理解得很对。 推送分支这是指你在本地所做更改的分支比如你在开发一个新功能的分支 a。 从 a 推送到 b这意味着你要将本地分支 a 的更改推送到远程的分支 b。如果 b 是远程仓库中的一个分支那么推送操作会将 a 中的修改合并到 b 中。 关键点 推送实际上是将本地的提交更改记录发送到远程仓库。为 a 如果目标分支 b 目前在远程仓库中存在推送后 b 会更新的状态。如果目标分支 b 在远程仓库中不存在通常会创建一个新的分支。 所以推送是一种把你在本地开发的内容上传到远程的方式而不只是简单的合并。 在 Git 中“提交”和“提交并推送”有以下区别 提交 (Commit) 本地操作提交是把你当前的修改记录保存到本地的 Git 仓库中。提交之后这些更改只会保存在你自己的计算机上其他人无法看到这些修改。提交的作用是创建一个“快照”记录你当前的代码状态。 提交并推送 (Commit and Push) 本地远程操作提交并推送首先会在本地保存你的修改和普通提交一样然后把这些修改推送到远程仓库比如 GitHub、GitLab 等。推送之后其他人就能在远程仓库中看到你的更改下载或合并你的代码。
总结
如果只是提交 (Commit)修改只会保存到你本地其他人看不到。如果提交并推送 (Commit and Push)修改不仅会保存到本地还会同步到远程仓库其他人才能看到并获取你的修改。
所以如果你想把修改上传给别人需要选择“提交
git是什么软 CI/CD 是一种自动化流程帮助你管理代码的更新和发布。 持续集成 (CI)每当你或其他人修改代码并提交时系统会自动运行测试确保这些修改没有引入错误。 持续交付 (CD)当代码通过测试后系统会自动将代码部署到服务器上使得新版本随时可以上线。
设置 CI/CD 意味着你为项目配置了这些自动化流程可以减少手动操作提高开发效率和软件质量。 SSH 密钥可以看作是一种密码但它更安全因为它由一对密钥公钥和私钥组成。使用 SSH 密钥的主要原因是 安全性SSH 密钥比传统密码更安全避免了密码泄露的风险。 身份验证当你尝试推送或拉取代码时系统会使用你的密钥来验证你的身份。
如果你不设置 SSH 密钥就无法通过 SSH 进行推送和拉取因为系统无法确认你是否有权限访问该存储库。你可以选择使用 HTTPS 连接这样就不需要 SSH 密钥但每次操作时需要输入用户名和密码。 代码托管允许开发者在云端存储和管理代码仓库。 协作工具提供合并请求、问题追踪、代码审查等工具支持团队协作。 CI/CD 集成都支持持续集成和持续交付CI/CD自动化构建和测试流程。 项目管理提供项目管理功能如任务板和里程碑以便团队更好地组织工作。
区别
平台和用户群Gitee 更加关注中国用户提供中文界面和本地化服务而 GitLab 是国际化的支持多种语言。自托管选项GitLab 提供自托管版本允许用户在自己的服务器上运行 GitLab而 Gitee 主要是一个云平台。
总的来说GitLab 和 Gitee 的主要功能相似但它们的定位和用户群体有所不同。 Git 和 Gitee 之间的关系如下 GitGit 是一个分布式版本控制系统用于跟踪代码更改和管理项目的历史记录。它是一种工具可以在本地和远程仓库中使用。 GiteeGitee 是一个基于 Git 的代码托管平台类似于 GitHub。它提供了一个在线平台用于存储、共享和协作开发项目。Gitee 允许开发者使用 Git 命令来管理代码但它提供了图形界面、问题追踪、代码审查等附加功能。
# 进入项目目录
cd ~/MyUnityProject# 查看当前状态
git status# 拉取最新的更改
git pull origin main# 修改了脚本中的变量添加了新物体# 查看修改内容
git diff# 添加所有修改的文件
git add .# 提交更改
git commit -m 更新了变量值添加了新物体# 推送更改到远程仓库
git push origin main# 创建一个新分支用于新功能开发
git checkout -b new-game-mechanic# 在新分支上进行一些修改# 查看当前状态
git status# 添加更改
git add .# 提交新功能的更改
git commit -m 添加新的游戏机制# 切换回主分支
git checkout main# 合并新功能分支到主分支
git merge new-game-mechanic# 删除已合并的功能分支
git branch -d new-game-mechanic# 推送更新后的主分支
git push origin main不用这些guigit也可以用么
是的Git 完全可以通过命令行使用。实际上许多开发者更喜欢使用命令行因为它提供了更大的灵活性和控制。你可以使用命令来执行所有 Git 操作如提交、推送、拉取、分支管理等。命令行方式在处理复杂操作或自动化任务时特别有效。只要熟悉相关命令就可以高效地使用 Git。
GitExtensions 是一个 Git 的图形用户界面GUI工具它使得使用 Git 更加直观和方便。虽然 GitExtensions 本身不是 Git但它提供了一个界面帮助用户更轻松地执行 Git 的各种操作比如提交、推送、拉取和合并等。因此你可以把它看作是一个增强 Git 使用体验的工具。 离线意思是不联网我也可以上传吗
不完全是。在 Git 中离线操作 指的是你可以在本地进行修改和提交而不需要时时联网。具体来说 本地更改和提交你可以在没有网络连接的情况下修改代码并使用 git commit 将更改记录到本地仓库。 上传一旦你有了网络连接就可以使用 git push 将本地的提交上传到远程仓库。这个过程需要联网。 同步同样地若想从远程获取其他人的更改使用 git pull也需要联网。 Git 的离线操作指的是开发者可以在本地进行更改而无需时刻连接到远程仓库。具体来说 本地更改你可以在自己的计算机上修改代码、提交更改甚至创建分支而不需要立即上传到远程仓库。 同步当你完成本地的工作后可以通过 git push 将你的更改上传到远程仓库或使用 git pull 从远程获取最新的更改。 冲突解决如果其他人已经更新了远程仓库而你在本地进行了更改推送时可能会遇到冲突。这时Git 会提示你先拉取pull远程的更改解决冲突后再进行推送。 常来说多个人一起写一个项目不会在同一时间一起写是吗因为如果有人已经改了那就会比较麻烦或者说两个人协商好写完全不耦合的东西然后互相没拉取对方的情况下都提交这时虽然提示冲突但实际上只要安排好两个人有正常的提交顺序就行只不过依然提示为冲突
是的你的理解是正确的。如果三个人同时对同一个项目进行修改情况可能会这样
版本1项目的初始状态。开发者A 上传了更改使版本变为 版本2。开发者B 和 开发者C 仍然在使用 版本1并进行各自的修改假设他们的修改将版本变为 版本3。
如果 开发者B 和 开发者C 试图上传他们的更改基于 版本1而不先拉取 版本2就会出现冲突。Git 会提示有冲突要求他们手动解决这些问题决定如何合并他们的更改。因此在多人协作时及时拉取最新的更改非常重要以避免冲突。 当多个人同时更改同一部分代码时Git 提供工具来帮助解决这些冲突
协作多个开发者可以同时在同一个项目上工作通过推送push和拉取pull操作共享更改。
正是这样分支允许你在不影响原项目的情况下进行实验和开发。如果分支上的功能经过测试并且可用你可以将其合并到主分支中如果功能不再需要可以直接删除分支原项目不会受到影响。这种灵活性使得团队开发更高效减少了错误和冲突的风险。
Git 是一个分布式版本控制系统它可以帮助多个开发者共同协作管理和修改同一个项目的代码。以下是一些 Git 的主要功能和特点 版本控制Git 记录每次代码更改的历史可以轻松查看和恢复到之前的版本。 分支管理开发者可以在不同的分支上独立工作不会影响主代码库分支可以随时合并。 项目代码的一个独立版本。在分支上你可以进行实验性开发、修复 bug 或添加新功能而不会影响主分支通常是 main 或 master的稳定性。 协作多个开发者可以同时在同一个项目上工作通过推送push和拉取pull操作共享更改。 离线操作由于 Git 是分布式的开发者可以在本地进行更改之后再与远程仓库同步。 解决冲突当多个人同时更改同一部分代码时Git 提供工具来帮助解决这些冲突。
总之Git 是一个强大的工具特别适合团队协作和管理复杂的项目。如果你有兴趣可以进一步了解它的命令和工作流程 GameObject.Instantiate(GameObject.CreatePrimitive(PrimitiveType.Sphere),fa);
会在里面先生成一个初始然后把这个初始又当预设体生成了一次所以会生成双倍数 Vector3 a new Vector3(Random.Range(-100, 100), Random.Range(-100, 100), Random.Range(-100, 100));
GameObject.Instantiate(GameObject.CreatePrimitive(PrimitiveType.Sphere), fa); // 只设置父物体 newObject.transform.localPosition a; // 设置相对父物体的位移 直接调用该一般函数一般函数里存对invoke的调用 延迟执行如果不要repeat就在函数里面嵌套 延迟函数只声明一次之后会记住自己执行 在运行时会根据对象的实际类型调用其对应的方法而不是根据变量的类型。Java 的多态主要体现在方法重写上而不是变量。 一般情况下的 int
位数32 位范围 有符号 int-2^31 到 2^31 - 1即约 -2.1 × 10^9 到 2.1 × 10^9
longlong是2的64次方9.2*10^18
v.push_back()
这个方法会将计算得到的结果追加到 vector v 的末尾。
在 C 中数组的大小必须是一个常量表达式在编译时已知的常量
数组大小必须是编译时已知的常量在 C 中数组的大小必须是编译时常量这意味着你不能使用运行时的变量来定义数组的大小。例如const int maxn1e3; 确保 maxn 是一个编译时常量从而数组 c[maxn][maxn] 的大小在编译时就确定了。
const int maxn 1000; // 编译时常量
int arr[maxn]; // 正确数组大小是编译时已知的const 表示不可修改的常量const 修饰的变量在定义后不能修改。例如const int maxn 1e3; 表示 maxn 的值为 1000且在程序运行过程中它不能被更改。如果你尝试修改它编译器会报错。
const int maxn 1000;
maxn 2000; // 错误编译器会报错因为 maxn 是 const#include bits/stdc.h
#include bits/stdc.h 是一个非标准的头文件通常只在某些编译器如 GCC的环境下提供用于快速包含几乎所有的标准库头文件。它包含了几乎所有常见的 C 标准库类似于 一站式 的解决方案