首页
学习
活动
专区
圈层
工具
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在 Java 代码里正确的打日志

实现方式统一使用: Logback框架 打日志的正确方式 什么时候应该打日志 当你遇到问题的时候,只能通过debug功能来确定问题,你应该考虑打日志,良好的系统,是可以通过日志进行问题定为的。...当你碰到if…else 或者 switch这样的分支时,要在分支的首行打印日志,用来确定进入了哪个分支 经常以功能为核心进行开发,你应该在提交代码前,可以确定通过日志可以看到整个流程 基本格式 必须使用参数化信息的方式...说明 如果代码中出现以下代码,可以进行优化: //1. 获取用户基本薪资 //2. 获取用户休假情况 //3....计算用户应得薪资 优化后的代码: logger.debug("开始获取员工[{}] [{}]年基本薪资",employee,year); logger.debug("获取员工[{}] [{}]年的基本薪资为...logger.debug("员工[{}] [{}]年[{}]月应得薪资为[{}]",employee,year,month,actualSalary); TRACE 基本概念 特别详细的系统运行完成信息,业务代码中

68910
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    握草,你竟然在代码里下毒!

    - 这点代码乍一看没什么问题,看明白了就是代码里下砒霜!它的目的就一个,要让所有的key成一个链表放到HashMap中,而且把有用的key放到链表的最后,增加get时的耗时!...点评:你们公司是按照代码行数打绩效?不做格式化、不整洁、不看IDEA工具提示,代码是写给人看的!啥有不是! 6....点评:下次记得把产品经理也打日志里去,要死一起死! 10....三、总结 好的代码千篇一律,差的程序升值加薪!,这些有毒的代码,淋漓尽致的展示了程序员的才华出众,同时也严重怀疑就是钱给少了! 敲黑板:想在这编码这条路上走的更远,还是需要脚踏实地的把根基打牢。...,本篇文章就到这里,有意思的代码还有很多,欢迎在评论区留下你的鬼畜代码!

    45220

    握草,你竟然在代码里下毒!

    这点代码乍一看没什么问题,看明白了就是代码里下砒霜!它的目的就一个,要让所有的key成一个链表放到HashMap中,而且把有用的key放到链表的最后,增加get时的耗时!...点评:你们公司是按照代码行数打绩效?不做格式化、不整洁、不看IDEA工具提示,代码是写给人看的!啥有不是! 6....点评:下次记得把产品经理也打日志里去,要死一起死! 10....三、总结 好的代码千篇一律,差的程序升值加薪!,这些有毒的代码,淋漓尽致的展示了程序员的才华出众,同时也严重怀疑就是钱给少了! 敲黑板:想在这编码这条路上走的更远,还是需要脚踏实地的把根基打牢。...,本篇文章就到这里,有意思的代码还有很多,欢迎在评论区留下你的鬼畜代码 ? ! ---- bugstack虫洞栈 沉淀、分享、成长,让自己和他人都能有所收获!

    46610

    Java|在 IDEA 里自动生成 MyBatis 模板代码

    背景 基于 MyBatis 开发的项目,新增数据库表以后,总是需要编写对应的 Entity、Mapper 和 Service 等等 Class 的代码,这些都是重复的工作,我们可以想一些办法来自动生成这些代码...近几年版本的 IDEA 里已经自带了 Database Tools and SQL 插件,可以连接数据库进行常用的操作,并且,它还自带了数据库表对应 POJO 类的代码生成器:在 Database 面板里配置好数据源以后...需求 基于项目情况,我们对生成的代码有如下要求: Entity 需要继承指定基类,数据库表的公共字段放在基类里; Mapper、Service 和 ServiceImpl 分别需要实现指定的类继承关系;...Case.LOWER.apply(s[0]) + s[1..-1] } 大功告成,现在右键一个数据库表,依次选择 Scripted Extensions、Generate MyBatis Code.groovy,在弹出的目录选择框里选择想要放置代码的目录...,即可生成期望的模板代码了。

    20310

    别在 Java 代码里乱打日志了,这才是正确的打日志姿势

    实现方式统一使用: Logback框架 打日志的正确方式 什么时候应该打日志 当你遇到问题的时候,只能通过debug功能来确定问题,你应该考虑打日志,良好的系统,是可以通过日志进行问题定为的。...当你碰到if…else 或者 switch这样的分支时,要在分支的首行打印日志,用来确定进入了哪个分支 经常以功能为核心进行开发,你应该在提交代码前,可以确定通过日志可以看到整个流程 基本格式 必须使用参数化信息的方式...说明 如果代码中出现以下代码,可以进行优化: //1. 获取用户基本薪资 //2. 获取用户休假情况 //3....计算用户应得薪资 优化后的代码: logger.debug("开始获取员工[{}] [{}]年基本薪资",employee,year); logger.debug("获取员工[{}] [{}]年的基本薪资为...logger.debug("员工[{}] [{}]年[{}]月应得薪资为[{}]",employee,year,month,actualSalary); TRACE 基本概念 特别详细的系统运行完成信息,业务代码中

    42720

    别在 Java 代码里乱打日志了,这才是正确的打日志姿势!

    实现方式统一使用: Logback框架 打日志的正确方式 什么时候应该打日志 当你遇到问题的时候,只能通过debug功能来确定问题,你应该考虑打日志,良好的系统,是可以通过日志进行问题定为的。...当你碰到if…else 或者 switch这样的分支时,要在分支的首行打印日志,用来确定进入了哪个分支 经常以功能为核心进行开发,你应该在提交代码前,可以确定通过日志可以看到整个流程 基本格式 必须使用参数化信息的方式...说明 如果代码中出现以下代码,可以进行优化: //1. 获取用户基本薪资 //2. 获取用户休假情况 //3....计算用户应得薪资 优化后的代码: logger.debug("开始获取员工[{}] [{}]年基本薪资",employee,year); logger.debug("获取员工[{}] [{}]年的基本薪资为...logger.debug("员工[{}] [{}]年[{}]月应得薪资为[{}]",employee,year,month,actualSalary); TRACE 基本概念 特别详细的系统运行完成信息,业务代码中

    50720

    别在C++代码里乱打日志了,这才是正确的打日志姿势!

    初学代码时,Jungle的第一行代码是实现打印“hello world”,打印到控制台。在后来的学习中,Jungle又学会了设断点调试代码,在适当的地方通过断点来观察变量的值。...但在实际的软件项目中,试想一下,通过输出到控制台或者通过设断点来调试代码,可能吗? 客户现场,会让你现场打印到控制台上调试吗? 报了error的软件项目,你能够明确知道软件crash的位置吗?...你能保证设断点可以还原error时候的现场吗? 概率性的error事件,设断点还奏效吗? 如果是时效性的代码(比如USB连接) ,设断点调试还合理吗?...4 测试 Jungle将上述设计实现的日志系统应用到了之前写的一些小程序里,比如在之前的“欲戴王冠,必承其重”——深度解析职责链模式的代码。如何添加呢?...就是将两个文件(头文件和源文件)加入工程,包含头文件,再在需要打log的地方加上Jungle在日志类里定义的宏即可。

    2.4K30

    pycharm上传代码到gitlab_可以在gitlab里查看代码

    2.pycharm从gitlab上拉取代码 (1) 依次点击下图中的1–>2—>3标记处,会出现(2)中的弹框 (2)填写如下:在URL处,填写gitlab拉取代码的地址,点击Test后,会出现一个弹框...(3)在pycharm的右下方会显示你正在使用的分支 3.Pychram切换gitlab其他分支 (1)点击你所在分支,即可出现下图,点击你要切换的分支,Checkout As…就可以了。...Pycharm下提交代码到gitlab分支上 ***每次编辑前可以pull一次,push之前也最好pull一次,先更新本地代码,再把本地修改提交到gitlab上去。...【push】是将本地仓库的代码提交至远端。 5. Pycharm 合并gitlab分支 假设我们现在有分支A和分支B,要求:把分支B的代码合并至分支A 。...此时,分支B的代码已经合并到(本地)分支A了。 (3)将现在分支A的代码【push】至远端,此时,分支B的代码在远端也合并至分支A。至此,成功完成了将分支B代码合并到分支A完成。

    2.1K20

    别在C++代码里乱打日志了,这才是正确的打日志姿势!(二)

    在上一篇文章别在C++代码里乱打日志了,这才是正确的打日志姿势!中,Jungle设计实现了C++日志系统,并将其用于之前已有的小程序中,测试结果也是OK的。那是否就说明这个Log系统没问题呢?...每个线程里打印全局变量(即全局共享资源)的值。下面是输出的日志,一共运行了两次(第5、6行隔开): 问题来啦! 首先,在第一次运行输出的日志里,出现了乱码!...其次,在第二次运行输出的日志里,一行log里好像打印了两次日志(第8行)! 问题出在哪里呢? 为什么会出现乱码?...线程安全的日志系统 在单例模式的设计实现里已经提到了线程安全,Jungle用互斥锁达到了互斥的目的。...在Log类成员里声明一个CRITICAL_SECTION对象criticalSection,初始化时: InitializeCriticalSection(&criticalSection); 当然,最好在释放资源时加上下述代码

    48130

    某程序员竟然在深夜偷偷在代码里下毒!

    这点代码乍一看没什么问题,看明白了就是代码里下砒霜!它的目的就一个,要让所有的key成一个链表放到HashMap中,而且把有用的key放到链表的最后,增加get时的耗时!...点评:你们公司是按照代码行数打绩效?不做格式化、不整洁、不看IDEA工具提示,代码是写给人看的!啥有不是! 6....这个时候遇到异常,要做一些流程处理,最起码要打日志和报警。 点评:业务开发很多时候都是为了解决异常流程,就像擦屁屁的纸80%的面积是保护手的。怎么滴,我看你这代码,是非要一直抠破呀! 8....,不打入参信息 } } ---- 指数:⭐ 解毒:日志里只打了异常,没有入参信息,当你的方法有大量的调用时,很难快速定位问题。...点评:下次记得把产品经理也打日志里去,要死一起死! 10.

    37720

    【玩转腾讯云】在云函数里为 Next.js 跑 SSR

    通常我们在部署SSR的时候,会担心运维等问题,但如果我们把它部署在云开发上就可以不必担心~ 我们部署看看喽~ 环境准备 安装node.js 安装云开发工具@cloudbase/cli npm i @cloudbase...└─functions └─app index.js 然后我们进入到项目中 $ cd nextSSR 在 functions文件夹下创建next.js...$ npm install --save serverless-http 在next应用的根目录下项目根目录/functions/next应用根目录新建index.js,并将下列代码添加进去...中新建next.config.js并将下列代码拷入 // next.config.js module.exports = { assetPrefix: '/next' } 这样我们的项目就配置差不多了...我们进入到云开发管理页面 [6da1f8d3-d961-4a84-89ab-5304eac292f5.png] 我们看到在云函数的函数代码中可以找到我们刚才上传的文件 我们点击预览即可浏览页面啦~ 在函数配置可以通过触发云函数来进行浏览我们的页面

    3.2K1010
    领券