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

如何获取堆栈跟踪(haskell)中的行号?

在Haskell中,要获取堆栈跟踪中的行号,可以使用GHC.Stack模块提供的函数srcLocStartLinesrcLocEndLine。这些函数可以从CallStack类型的值中提取源代码位置信息。

以下是一个示例代码,展示了如何获取堆栈跟踪中的行号:

代码语言:txt
复制
import GHC.Stack (CallStack, SrcLoc(..), getCallStack, srcLocStartLine, srcLocEndLine)

-- 定义一个函数,返回当前的堆栈跟踪
getStackTrace :: IO CallStack
getStackTrace = getCallStack

-- 获取堆栈跟踪中的行号
getLineNumbers :: IO [Int]
getLineNumbers = do
  stack <- getStackTrace
  return $ map extractLineNum stack
  where
    extractLineNum :: SrcLoc -> Int
    extractLineNum loc = srcLocStartLine loc

-- 示例函数,用于测试获取堆栈跟踪中的行号
exampleFunction :: IO ()
exampleFunction = do
  lineNumbers <- getLineNumbers
  putStrLn $ "Line numbers in stack trace: " ++ show lineNumbers

-- 运行示例函数
main :: IO ()
main = exampleFunction

在上述示例代码中,getStackTrace函数使用getCallStack函数获取当前的堆栈跟踪。然后,getLineNumbers函数从堆栈跟踪中提取源代码位置信息,并返回行号列表。最后,exampleFunction函数演示了如何使用getLineNumbers函数来获取堆栈跟踪中的行号。

请注意,由于Haskell是一种纯函数式编程语言,它的堆栈跟踪机制与其他语言可能有所不同。在Haskell中,堆栈跟踪通常用于调试目的,以帮助定位错误。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

「原创」如何快速获取银行、联行号的数据?

由于做的是POS前置交易系统,涉及到和商户进件以及交易相关的业务,需要向上游支付机构上送“联行号”,但是由于系统内的数据不全,经常出现找不到银行或者联行号有误等情况,导致无法进件。   ...先输入联行号进行查询,然后进去详情页,才能取到想要的数据。所以第一步需要先获取查询的接口,于是我又打开了熟悉的控制台。 ?   ...从上图可以发现这些请求都是在获取广告,并没有发现我们想要的接口,这个是啥情况,难道凭空变出来的嘛。并不是,主要是因为这个网站不是前后端分离的,所以这个时候我们需要从它的源码下手。 ?...剩下的两个网站相对比较简单,只需要更改相应的联行号,进行请求就可以获取到相应的数据,所以这里不过多赘述。 爬虫编写   经过上面的分析了,已经取到了我们想要的接口,可谓是万事俱备,只欠代码了。...比较下来其他的两个就比较简单,直接替换联行号就可以了,还有就是这个三个网站也没啥反扒的机制,所以很轻松的就拿到了数据。

3.9K60
  • 如何在Python中保留异常装饰器的堆栈跟踪

    当函数在装饰器中抛出异常时,默认情况下,堆栈跟踪信息将指向装饰器函数,而不是实际引发异常的函数。这使得调试和定位问题变得困难。...2、解决方案为了保留异常装饰器的堆栈跟踪信息,我们可以使用以下两种方法:使用 raise 语句的三参数形式在 Python 2.x 中,我们可以使用 raise 语句的三参数形式来指定异常类型、异常实例和堆栈跟踪信息...这样,堆栈跟踪信息就会指向函数 bottom,而不是函数 middle。使用 traceback 模块在 Python 3 中,我们还可以使用 traceback 模块来获取和操作堆栈跟踪信息。...try_except 装饰器会捕获函数 middle 中抛出的异常,并使用 traceback 模块获取堆栈跟踪信息。...上面就是我对于堆栈跟踪的一些理解,如果有任何不懂的可以评论区留言讨论,在实际应用中,异常处理方式可能因需求而异。

    13910

    如何对CDH集群中的Impala打印线程堆栈

    本文直接演示如何在 CDH 集群中打印 Impala 进程的线程堆栈,不再需要编译源码。当然第一次操作时还是需要下载一些工具,可以在集群中固定选一台机器来配置环境,以后再操作时就比较方便了。 1....下载对应版本的 Impala 源码,可以在 cloudera github 的 release 页面查找:https://github.com/cloudera/Impala/releases 本例中...上述方式生成的 symbol 文件不带有文件名和行号,如果想尽可能地结合代码,可以下载并解析对应系统的 rpm/deb 包。...symbol 信息就包含文件名和行号了。...解析的输出包含了很多寄存器的值,有点影响阅读,可以把它们去掉: grep -v = /tmp/resolved.txt | grep -v 'Found by' | less 这样能看到比较舒服的堆栈:

    3.2K11

    C#.NET 如何在第一次机会异常 FirstChanceException 中获取比较完整的异常堆栈

    在 FirstChangeException 事件中,我们通常只能拿到异常堆栈的第一帧,这对于我们捕捉到异常是好的,但对分析第一次机会异常可能并不利。...本文介绍如何在 FirstChangeException 事件中拿到比较完整的异常堆栈,而不只是第一帧。...另外,你也可以用 ExceptionDispatchInfo 让内部异常的堆栈也连接起来,详见我的另一篇博客: 使用 ExceptionDispatchInfo 捕捉并重新抛出异常 - 吕毅 获取较完整的第一次机会异常堆栈...我们需要等到 FirstChanceException 事件中的异常被 catch 到,就能获取到第一次抛出的地方到 catch 处之间的所有帧。...因为我们只需要当前调用堆栈中的异常处理执行完成即可。

    39840

    如何手动获取 Spring 容器中的 bean?

    ApplicationContextAware 接口的作用: 先来看下 Spring API 中对于 ApplicationContextAware 这个接口的描述: ?...即是说,当一个类实现了这个接口之后,这个类就可以方便地获得 ApplicationContext 中的所有bean。...换句话说,就是这个类可以直接获取Spring配置文件中,所有有引用到的bean对象。 如何使用 ApplicationContextAware 接口? 如何使用该接口?很简单。...getContext(){ return context; } } 如此一来,我们就可以通过该工具类,来获得 ApplicationContext,进而使用其getBean方法来获取我们需要的...2、在Spring配置文件中注册该工具类 之所以我们能如此方便地使用该工具类来获取,正是因为Spring能够为我们自动地执行 setApplicationContext 方法,显然,这也是因为IOC的缘故

    2.6K10

    Java 中是如何获取 IP 属地的

    细心的小伙伴可能会发现,抖音新上线了 IP 属地的功能,小伙伴在发表动态、发表评论以及聊天的时候,都会显示自己的 IP 属地信息 下面,我就来讲讲,Java 中是如何获取 IP 属地的,主要分为以下几步...通过 HttpServletRequest 对象,获取用户的 IP 地址 通过 IP 地址,获取对应的省份、城市 首先需要写一个 IP 获取的工具类,因为每一次用户的 Request ...在我们获取到用户的 IP 地址后,那么就可以获取对应的 ip 信息了 我在 Github 冲浪的时候,发现了 Ip2region 项目。...,需要下载仓库中的 ip2region.db 文件,然后放到 resource 目录下 然后,通过内置的三种算法,分别转换用户 ip 地址     public static String getCityInfo...所以我们还需要对这个方法进行一下封装,得到获取 IP 属地的信息。

    2.7K20

    以太坊主网上测试工具推荐

    如果你想进行确定性测试(不会在星期二通过,而星期五失败),我强烈建议你使用dapp.tools.其背后使用hevm,这是Haskell的EVM实现 使用Haskell编写的EVM(而不是Python或JS...这样可以大大减少测试时间,尤其是当测试需要与主网协议进行大量交互时 调试失败的交易 在沙箱中 如果你使用的是dapp.tools, buidler,或brownie,那应该恭喜你,他们已经将日志记录和堆栈跟踪内置到了测试框架本身...hevm 堆栈跟踪 但是,如果你使用的是ganache-cli的框架。那就得放慢你脚步,去放置revert消息,以找出问题所在。 有一些人会说,ganache-cli有一个debugger。...Ethtx.info和bloxy.info提供了有关指定交易哈希的详细堆栈跟踪(我怀疑它背后使用的是openethereum的[debug_tracetransaction](https://geth.ethereum.org...ethtx.info堆栈跟踪示例 有用的链接 etherscan - 通用区块链浏览器 bloxy - 更高级的区块链浏览器 ethtx - 堆栈跟踪 4bytes - 函数签名数据库 furucombo

    1.2K20

    Python中如何获取列表中重复元素的索引?

    一、前言 昨天分享了一个文章,Python中如何获取列表中重复元素的索引?,后来【瑜亮老师】看到文章之后,又提供了一个健壮性更强的代码出来,这里拿出来给大家分享下,一起学习交流。...= 1] 这个方法确实很不错的,比文中的那个方法要全面很多,文中的那个解法,只是针对问题,给了一个可行的方案,确实换个场景的话,健壮性确实没有那么好。 二、总结 大家好,我是皮皮。...这篇文章主要分享了Python中如何获取列表中重复元素的索引的问题,文中针对该问题给出了具体的解析和代码演示,帮助粉丝顺利解决了问题。...最后感谢粉丝【KKXL的螳螂】提问,感谢【瑜亮老师】给出的具体解析和代码演示。

    13.4K10

    如何在 React 中获取点击元素的 ID?

    在 React 应用中,我们经常需要根据用户的点击事件来执行相应的操作。在某些情况下,我们需要获取用户点击元素的唯一标识符(ID),以便进行进一步的处理。...本文将详细介绍如何在 React 中获取点击元素的 ID,并提供示例代码帮助你理解和应用这个功能。使用事件处理函数在 React 中,我们可以使用事件处理函数来获取点击元素的信息。...示例代码下面是一个示例代码,演示了如何使用事件处理函数来获取点击元素的 ID:import React from 'react';const ClickElement = () => { const...示例代码以下是一个示例代码,演示了如何使用 ref 来获取点击元素的 ID:import React, { useRef } from 'react';const ClickElement = () =...结论本文详细介绍了在 React 中获取点击元素的 ID 的两种方法:使用事件处理函数和使用 ref。

    3.5K30

    【编程基础】Android中如何获取资源的尺寸?

    在Android中为了实现不同屏幕的适配,经常会用到在不同dimen.xml文件中对于同一dimen ID定义不同的大小,然后在代码中通过getDimension函数来获取,下面就来说说几种getDimension...getDimension()是基于当前DisplayMetrics进行转换,获取指定资源id对应的尺寸。文档里并没说这里返回的就是像素,要注意这个函数的返回值是float,像素肯定是int。...getDimensionPixelOffset()与getDimension()功能类似,不同的是将结果转换为int,并且偏移转换(offset conversion,函数命名中的offset是这个意思...getDimension和getDimensionPixelOffset的功能类似,都是获取某个dimen的值,但是如果单位是dp或sp,则需要将其乘以density,如果是px,则不乘,并且getDimension...我用的手机的density是2.0所以所以会乘以2。

    2.5K70

    Hystrix降级逻辑中如何获取触发的异常?

    通过之前Spring Cloud系列教程中的《Spring Cloud构建微服务架构:服务容错保护(Hystrix服务降级)》一文,我们已经知道如何通过Hystrix来保护自己的服务不被外部依赖方拖垮的情况...但是实际使用过程中经常碰到开发反应“莫名”触发了降级逻辑的情况。 为了更精准的定位触发原因,或是在降级逻辑中需要根据不同的异常做不同的处理时,在降级方法中,我们希望可以获取到主逻辑中抛出的异常信息。...接下来就来介绍一下Hystrix两种不同实现方式中如何在降级逻辑中获取异常信息的方法。...注解方式 先介绍一下用注解方式定义的Hystrix命令是如何在降级逻辑中获取异常的,实现非常简单,先看下面的例子: @HystrixCommand(fallbackMethod = "fallback"...重点看 fallback函数中的最后一个传参 Throwablethrowable。通过这样的简单定义,开发人员就可以很方便的获取触发降级逻辑的异常信息,用作日志记录或者其它复杂的业务逻辑了。

    1.7K30

    Hystrix降级逻辑中如何获取触发的异常?

    通过之前Spring Cloud系列教程中的《Spring Cloud构建微服务架构:服务容错保护(Hystrix服务降级)》一文,我们已经知道如何通过Hystrix来保护自己的服务不被外部依赖方拖垮的情况...但是实际使用过程中经常碰到开发反应“莫名”触发了降级逻辑的情况。 为了更精准的定位触发原因,或是在降级逻辑中需要根据不同的异常做不同的处理时,在降级方法中,我们希望可以获取到主逻辑中抛出的异常信息。...接下来就来介绍一下Hystrix两种不同实现方式中如何在降级逻辑中获取异常信息的方法。...注解方式 先介绍一下用注解方式定义的Hystrix命令是如何在降级逻辑中获取异常的,实现非常简单,先看下面的例子: @HystrixCommand(fallbackMethod = "fallback"...重点看 fallback函数中的最后一个传参 Throwablethrowable。通过这样的简单定义,开发人员就可以很方便的获取触发降级逻辑的异常信息,用作日志记录或者其它复杂的业务逻辑了。

    1.8K30

    如何使用JavaScript获取HTML表单中的值?

    在开发中,我们经常需要获取用户在表单中输入的数据,然后进行处理或提交到服务器。今天我们就来聊一聊,如何用JavaScript获取HTML表单中的值。...使用 FormData 构造函数 FormData 是一个非常方便的工具,它可以把表单中的所有数据打包成键值对的形式。...const formData = new FormData(form):FormData对象会自动读取表单中的所有输入字段,并将其封装成键值对的形式。...假设你在开发一个在线购物的系统,用户在填写订单表单后点击提交,你可以用上面的方法获取到用户的所有输入数据,然后进行验证或发送到服务器。...它不仅简化了数据获取的过程,而且能够很好地与后端API集成。在下次你需要处理表单数据时,不妨试试这个方法,希望这篇文章能帮助你更好地掌握这一技巧。

    19910

    如何快速获取AWR中涉及到的表

    最近遇到一个很少见的需求,是关于应用测试方面的。 具体来说,这个应用的测试需求要基于一个固定的时间点数据,而且只能测试一轮,再测试就需要还原到测试前状态。...因为我们使用的存储是分层的(热数据在Flash上,冷数据在传统机械盘),但因为每次测试都需要将数据库闪回还原到固定时间点,效果不佳,所以需要尽可能的预热测试涉及的对象。...而相关对象,最佳方式是应用直接提供,这样最准确;但是各种原因,应用无法提供,那么DB层面观察,从测试期间的AWR获取,可以有不同维度: 1.精确找到所有I/O慢的TOP SQL,收集相关表进行预热 2....尽可能找更多AWR中的SQL,收集相关表进行预热 如果是第一种方式,需要人工去定位,SQL数量会很少的几条。...到flash中: alter table Z_OBJ storage(cell_flash_cache keep);

    16230
    领券