怎样在Unity里面进行代码的查错
继续讲一下在Unity写代码的查错问题,面对新手,老鸟请自动跳过。
对于程序基础比较薄弱的部分Unity使用者,经常会遇到某个项目不能运行,或者运行的时候没有出现自己想要得到的结果。这时候,很有可能是项目里面的代码报错了,或者代码写错了。代码报错的最直接表现是有错误打印,一般在Unity窗口最下面会出现错误打印,不过只会出现一行,我们可以打开Unity的打印输出窗口来确定有没有报错。
从Window标签页下面打开Console,就可以打开输出窗口:
比如这样的:
Console窗口也有一些操作的选项,比如左边有几个选项:
Clear:点击一下,可以把现有的所有打印清除掉
Collapse:可以把同一个地方输出的打印折叠起来,同类型打印只显示一条
Clear on Play:在每次运行项目的时候清除上一次输出的打印
Error Pause:当出现error级别的错误打印时,项目会暂停运行。
右边也有三个小按钮,一个是白色的气泡图标,一个是黄色的三角形图标,一个是红色的气泡图标,后面还跟着数字。
这三个按钮分别对应Unity的三个打印级别:Log、Warning和Error。后面的数字是该类型的打印的条数。如果想隐藏某个级别的打印,可以在这里操作。
介绍完打印输出窗口之后,接下来就说一下代码发生错误的2种类型。第一种,是编译错误。第二种是运行错误
1、编译错误:
这是指项目内的代码存在语法错误,导致了在编译的时候编不过。
很多新手可能都会问过别人,上图出现的提示是什么意思?为什么自己的项目不能运行?
这里所表达的意思,就是你的代码里面有编译级别的错误,需要先把报错的地方解决掉了,才能继续运行。
这时候我们需要打开Console窗口去看看究竟是哪里的代码写错了:
这里很清楚的说明了错误出现在哪一个类的哪一行,比如上面这个例子就是出现在DebugTest类的第9行。
我这样写代码,没用声明变量param1,就直接使用了,那么代码在编译的时候找不到param1的声明,所以报错了。只需要改成int param1 = 1+2;就不会报错了。编译级别的报错还有可能是因为你少打了个分号、少输入了一个括号之类导致的,所以需要小心。
另外一种错误,是逻辑错误,也就是运行时才会出现的错误。
比如我这样写代码:
然后编译通过了,但在运行时报错了:
我这个报错是特意模拟了跨越了很多个方法调用的报错,所以报错的时候会出现堆栈,显示出报错的方法调用的每一个过程,报错堆栈如红色箭头所示,是从下到上的。
上面已经说出了错误出现的2种常见的情况,针对于编译错误,其实很好查了,还没运行的时候就出现,哪里错了就查哪里的代码来修改。不好查的一般是逻辑错误。我们需要在运行的时候,知道某个方法在调用的时候的变量变化情况、输入输出的参数有没有异常之类的,才能定位到问题出在哪里。
这时候一般就有2种方法去查错,第一种是程序断点,另外一种是加打印输出。
怎样在Unity里断点查问题,我在2013年的时候已经写过文章说明了,过程大同小异,也就不再重复,可以跳转来看看:
http://liweizhaolili.blog.163.com/blog/static/162307442013214485190/
需要说的是,很多朋友不知道什么是断点,这一点很重要。在可以断点的环境下,断点是查问题最快的手段,是程序员最基本的技能之一。断点具体的含义可以自行百度一下,我简单的概括就是,可以在你写代码的地方的某一行点一下,然后程序运行到那一行的时候,自动停下来,让你去看看当前程序运行时,每个参数的具体的值是什么。然后你可以逐行代码继续往下运行,继续观察变量改变的情况,最后定位到出问题的地方。
能断点是一件很幸福的时候,但某些时候是不能断点的,比如你发布了release版本的安装包之后,你就不能再连接编辑器去断点了,或者写lua脚本的时候虽然也能通过一些特别的方法去断点,但我还是觉得麻烦于是也习惯用打印来定位问题。
刚才说过,Unity有三种打印级别,在代码里面可以主动的进行打印:
比如我这样写,得出的结果是:
Unity就会根据我指定的打印级别,把内容打印出来了。
有些情况下,由于打印的数量很多,你会发现没有办法很容易的找到你想打印的内容。这里我推荐一个插件,叫做ConsolsE。
这个插件的界面和一般的Console界面类似,不过多了一个过滤框,然后右边三种打印类型的最大数量不再是999+,而是实际打印的条数。
当我想查看某个关键字的打印内容时,我就可以在过滤框里面输入:
这时候,显示的内容就只会是包含我输入的关键字的打印结果了。
说了这么长,其实内容很少,总结一下,出现代码错误有2种情况,第一种是编译错误,第二种是逻辑错误。编译错误哪里报错改哪里,逻辑报错有2种查错手段,断点和打印。
相关文章
- git进行代码版本管理
- WCF入门教程(四)通过Host代码方式来承载服务 一个WCF使用TCP协议进行通协的例子 jquery ajax调用WCF,采用System.ServiceModel.WebHttpBinding System.ServiceModel.WSHttpBinding协议 学习WCF笔记之二 无废话WCF入门教程一[什么是WCF]
- 对“XXX::Invoke”类型的已垃圾回收委托进行了回调。这可能会导致应用程序崩溃、损坏和数据丢失。向非托管代码传递委托时,托管应用程序必须让这些委托保持活动状态,直到确信不会再次调用它们
- Jenkins打包Gitlab代码发布到远程Linux服务器
- 使用LLVM进行代码覆盖率检查
- vs code 进行硬件设计实用插件-语法高亮、语法检查、自动例化、Testbench生成、对齐、代码块等
- 21 面向对象编程 方法回顾和加深 代码:方法的定义 代码:方法的调用
- 从SVN上拉取代码到本地进行开发
- C++代码使用 gperftools 工具进行性能分析
- PHP代码审计----5、密码散列安全
- 《众妙之门——JavaScript与jQuery技术精粹》——2.4 进行代码复查的人员需要提供的信息
- 【21天学习经典算法】插入排序(附Python完整代码)
- 使用pycharm debug 深度学习代码
- 《Swift iOS应用开发实战》——2.5与代码进行关联
- git clone 如何通过proxy进行远程代码仓库拷贝下载
- 如何优化代码和RAM大小
- 微信公众号开发之创建菜单栏代码示例(php)
- 使用 JUnit 进行 Java 代码的单元测试
- 常量和静态变量会先载入内存后在进行执行php代码
- C语言课程设计|通讯录管理系统(含完整代码)
- 华为OD机试 - 停车场最大距离(JavaScript) | 机试题+算法思路+考点+代码解析 【2023】
- 华为OD机试 - 翻转单词顺序(Python) | 机试题+算法思路+考点+代码解析 【2023】
- 华为OD机试 - 新学校选址(Python)| 真题+思路+考点+代码+岗位
- SonarQube代码质量管理平台安装与使用
- Android Studio使用Lint进行代码检查
- Git 之 提交代码时的默认提交规则标签简单说明整理 feat/fix/doc/styles/revert/test/build等
- JavaScript代码压缩工具UglifyJS和Google Closure Compiler的基本用法
- java二维码生成与解析代码实现