c# 写的一个 *** 作数据库的程序,因为要循环对数据库进行 *** 作,导致堆栈溢出,请问有什么好的解决办法

c# 写的一个 *** 作数据库的程序,因为要循环对数据库进行 *** 作,导致堆栈溢出,请问有什么好的解决办法,第1张

你这个情况, 我感觉应该是属于 处理超时 了
也就是你一个 数据库命令, 执行时间超过 60秒了, 数据库还没有处理完
不知道你是什么数据库

如果是 SQL Server 的话, 好像是可以使用一个 异步的处理机制来处理的。
也就是 把命令发给数据库, 然后直接返回。
数据库长时间处理完毕后, 再回调一个方法。

select from 表名 limit ,
问号1是开始a位置。问号2结束b位置
一般你需要传入两个值 (第几页pageindex,显示多少页pagesize)。
然后 计算 a=pageindexpagesize-1; b=(pageindex-1)pagesize-1;

溢出判断方法一
用Xf和Yf表示被加数和加数补码的符号位,Zf为补码和的符号位当出现Xf = Yf= 0两数同为正,而Zf为负,即Zf=1时,有上溢当出现Xf =Yf = 1两数同为负,而Zf为正,即Zf= 0时,有下溢
溢出判断方法二
当数值最高位有进位位C1=1,符号位没有进位C0=0时,或当数值最高位没有进位位C1=0,符号位有进位C0=1时,结果有溢出
溢出判断方法三:
用变形补码进行双符号位运算在变形补码中,正数符号以"00"表示,负数的符号以"11"表示一般称左边的符号位为第一符号位,右边的符号位为第二符号位若运算结果的符号位为"01",则表明有正溢出产生若运算结果的符号"10",则表明有负溢出产生

那就用decimal吧
decimal(p, s)。
其中:p:为指定精度或对象能够控制的数字个数。
s:为指定可放到小数点右边的小数位数或数字个数。
p和s必须遵守以下规则:0 <= s <= p <= 38

数据溢出
在计算机中,当要表示的数据超出计算机所使用的数据的表示范围时,则产生数据的溢出。
溢出原因
数据类型超过了计算机字长的界限就会出现数据溢出的情况。导致内存溢出问题的原因有很多,比如:
(1) 使用非类型安全(non-type-safe)的语言如 C/C++ 等。
(2) 以不可靠的方式存取或者复制内存缓冲区
(3)编译器设置的内存缓冲区太靠近关键数据结构。
因素分析
1内存溢出问题是 C 语言或者 C++ 语言所固有的缺陷,它们既不检查数组边界,又不检查类型可靠性(type-safety)。众所周知,用 C/C++ 语言开发的程序由于目标代码非常接近机器内核,因而能够直接访问内存和寄存器,这种特性大大提升了 C/C++ 语言代码的性能。只要合理编码,C/C++应用程序在执行效率上必然优于其它高级语言。然而,C/C++ 语言导致内存溢出问题的可能性也要大许多。其他语言也存在内存溢出问题,但它往往不是程序员的失误,而是应用程序的运行时环境出错所致。
2 当应用程序读取用户(也可能是恶意攻击者)数据,试图复制到应用程序开辟的内存缓冲区中,却无法保证缓冲区的空间足够时(换言之,假设代码申请了 N 字节大小的内存缓冲区,随后又向其中复制超过 N 字节的数据)。内存缓冲区就可能会溢出。想一想,如果你向 12 盎司的玻璃杯中倒入 16 盎司水,那么多出来的 4 盎司水怎么办?当然会满到玻璃杯外面了!
3 最重要的是,C/C++编译器开辟的内存缓冲区常常邻近重要的数据结构。假设某个函数的堆栈紧接在在内存缓冲区后面时,其中保存的函数返回地址就会与内存缓冲区相邻。此时,恶意攻击者就可以向内存缓冲区复制大量数据,从而使得内存缓冲区溢出并覆盖原先保存于堆栈中的函数返回地址。这样,函数的返回地址就被攻击者换成了他指定的数值;一旦函数调用完毕,就会继续执行“函数返回地址”处的代码。非但如此,C++ 的某些其它数据结构,比如 v-table 、例外事件处理程序、函数指针等,也可能受到类似的攻击。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://www.outofmemory.cn/yw/12937222.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-29
下一篇 2023-05-29

发表评论

登录后才能评论

评论列表(0条)

保存