提示exe文件已停止工作怎么办?新手求助

perfect_blue 2016-04-04 10:51:20
今天用VS2015在调试一个程序,一切正常,室友把路由器拔了然后重插,然后编译没问题,一运行就提示已停止工作,重启电脑也没改变。。。。求解啊。。。。
...全文
4845 11 打赏 收藏 转发到动态 举报
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
liuxiangxxl 2016-12-21
  • 打赏
  • 举报
回复
在哪都能看到赵四老师的回复,赵老师的精神可嘉,但是我觉得赵老师的回复多半就是对牛弹琴,有些是根本刮不到边的。个人意见
perfect_blue 2016-04-05
  • 打赏
  • 举报
回复
引用 5 楼 qq423399099 的回复:
这是runtime error (运行时错误)就是程序运行到一半,程序就崩溃了。 比如说: ①除以零 ②数组越界:int a[3]; a[10000000]=10; ③指针越界:int * p; p=(int *)malloc(5 * sizeof(int)); *(p+1000000)=10; ④使用已经释放的空间:int * p; p=(int *)malloc(5 * sizeof(int));free(p); *p=10; ⑤数组开得太大,超出了栈的范围,造成栈溢出:int a[100000000] 用楼主给的代码得到了-1.#IND,IND可能表示很小,不确定。 运行结果:
好的,问题表面上已经解决了。谢谢大家,然后解决方案是我把 Line(Line&t) { startpoint = t.startpoint; endpoint = t.endpoint; } 这段删了就好了。这段代码的出现是因为Line。h是我之前另一个项目里的当时有用到,然后这次我就直接复制了。h文件 然后我逐语句调试的时候就出现那个startpoint和endpoint一直都是(0.0)没有变。然后我把这个删了就运行成功,不过还没逐语句调试。现在想知道为什么删了这个就运行成功了?
cocoabird 2016-04-05
  • 打赏
  • 举报
回复
double S = sqrt(p*(p - borders[0].getDistance())*(p - borders[1].getDistance())*([code=c]p - borders[2].getDistance()));
这里错误
p - borders[2].getDistance()
是负值 sqrt(负数)是非法计算
paschen 版主 2016-04-05
  • 打赏
  • 举报
回复
不要直接运行程序,运行调试程序,出错了点中断,通过调用堆栈定位出错位置,通过各窗口观察分析原因
小灸舞 2016-04-05
  • 打赏
  • 举报
回复
这是runtime error (运行时错误)就是程序运行到一半,程序就崩溃了。
比如说:
①除以零
②数组越界:int a[3]; a[10000000]=10;
③指针越界:int * p; p=(int *)malloc(5 * sizeof(int)); *(p+1000000)=10;
④使用已经释放的空间:int * p; p=(int *)malloc(5 * sizeof(int));free(p); *p=10;
⑤数组开得太大,超出了栈的范围,造成栈溢出:int a[100000000]

用楼主给的代码得到了-1.#IND,IND可能表示很小,不确定。
运行结果:



chouxiaoya8100 2016-04-05
  • 打赏
  • 举报
回复
引用 9 楼 zhao4zhong1 的回复:
崩溃的时候在弹出的对话框按相应按钮进入调试,按Alt+7键查看Call Stack即“调用堆栈”里面从上到下列出的对应从里层到外层的函数调用历史。双击某一行可将光标定位到此次调用的源代码或汇编指令处,看不懂时双击下一行,直到能看懂为止。
好的做法是, 自己写demo,学习时候,就学会打印日志, 会打印日志,帖子都不用发了。
赵4老师 2016-04-05
  • 打赏
  • 举报
回复
崩溃的时候在弹出的对话框按相应按钮进入调试,按Alt+7键查看Call Stack即“调用堆栈”里面从上到下列出的对应从里层到外层的函数调用历史。双击某一行可将光标定位到此次调用的源代码或汇编指令处,看不懂时双击下一行,直到能看懂为止。
perfect_blue 2016-04-04
  • 打赏
  • 举报
回复
引用 3 楼 yuelengdihai 的回复:
代码贴上来看看
#pragma once class Point { protected: int m_x, m_y; public: Point(){} Point(int x, int y) { m_x = x; m_y = y; } int getx() { return m_x; } int gety() { return m_y; } }; #pragma once #include"Point.h" #include<cmath> class Line { protected: Point startpoint, endpoint; double distance; public: Line(){} Line(Point m_startpoint, Point m_endpoint) { startpoint = m_startpoint; endpoint = m_endpoint; } double Line::getDistance() { double a=startpoint.getx() - endpoint.getx(), b = startpoint.gety() - endpoint.gety(); distance = sqrt(a*a+b*b); return distance; } Line(Line&t) { startpoint = t.startpoint; endpoint = t.endpoint; } }; #pragma once #include"Point.h" #include<cmath> class Line { protected: Point startpoint, endpoint; double distance; public: Line(){} Line(Point m_startpoint, Point m_endpoint) { startpoint = m_startpoint; endpoint = m_endpoint; } double Line::getDistance() { double a=startpoint.getx() - endpoint.getx(), b = startpoint.gety() - endpoint.gety(); distance = sqrt(a*a+b*b); return distance; } Line(Line&t) { startpoint = t.startpoint; endpoint = t.endpoint; } }; #pragma once #include"Line.h" class Polygon { protected: int m_num; Line *borders; public: Polygon(){} Polygon(Point points[], int num);//赋值构造函数 int getnum()const { return m_num; }//返回边的个数 double getperimeter()const;//返回多边形的周长 }; Polygon::Polygon(Point p[],int num) { this->m_num = num; borders = new Line[num]; for (int i = 0; i < m_num; i++) this->borders[i] = Line(p[i], p[(i + 1) / m_num]); } double Polygon::getperimeter()const { double perimeter=0; for (int i = 0; i < m_num; i++) perimeter+=this->borders[i].getDistance(); return perimeter; }#pragma once #include"Polygon.h" class Triangle:public Polygon { public: Triangle(Point points[]); double getArea()const; }; Triangle::Triangle(Point points[]):Polygon(points, 3){} double Triangle::getArea()const { double p = (borders[0].getDistance() + borders[1].getDistance()+ borders[2].getDistance()) / 2; double S = sqrt(p*(p - borders[0].getDistance())*(p - borders[1].getDistance())*(p - borders[2].getDistance())); return S; } #include"Triangle.h" #include<iostream> using namespace std; void main() { int ax = 0, ay = 0, bx = 0, by = 1, cx = 1, cy = 0; Point p[3] = { Point(ax,ay),Point(bx,by),Point(cx,cy) }; Triangle test(p); cout << test.getArea()<<endl; } 几个头文件和一个CPP我直接贴了
cocoabird 2016-04-04
  • 打赏
  • 举报
回复
代码贴上来看看
perfect_blue 2016-04-04
  • 打赏
  • 举报
回复
引用 1 楼 butters10 的回复:
你IP地址是自动分配的,然后你程序里面写死了,我猜的。。。
写死了?
stephen_csdn 2016-04-04
  • 打赏
  • 举报
回复
你IP地址是自动分配的,然后你程序里面写死了,我猜的。。。
内容概要:本文围绕“非线性流量的数据驱动Koopman模型预测控制研究”展开,提出一种基于数据驱动的Koopman算子理论方法,用于构建非线性系统的线性化状态空间模型,并结合模型预测控制(MPC)实现对复杂非线性系统的高效控制。研究通过引入扩展动态模态分解(EDMD)等观测函数,将非线性动力学映射至高维特征空间,在该空间中实现近似线性化表征,进而融合线性MPC框架进行优化求解。全文系统阐述了Koopman算子的数学基础、隐式线性化机制及在非线性流量控制中的建模流程,并通过Matlab代码完成了算法实现与仿真实验,验证了该方法在处理无精确物理模型、强非线性、时变动态系统中的有效性与鲁棒性,尤其适用于工业流程控制、能源系统调度等实际工程场景。; 适合人群:具备自动控制理论、非线性系统分析基础,熟悉Matlab编程,从事控制工程、系统辨识、智能优化、能源系统建模等方向的研究生、科研人员及工程技术人员。; 使用场景及目标:①应用于难以建立精确数学模型的复杂非线性系统(如流体动力系统、电力电子系统、机器人动力学等)的建模与实时控制;②实现数据驱动下的模型预测控制,提升系统响应速度与控制精度;③为先进控制策略(如MPC)提供一种可行的线性化建模范式,推动现代控制理论与数据科学、机器学习的深度融合。; 阅读建议:建议读者结合提供的Matlab代码深入理解Koopman方法的具体实现过程,重点关注观测函数构造、核函数选择、矩阵逼近、降维处理及MPC控制器设计等关键技术环节,并尝试将其迁移至其他非线性系统中进行复现实验与性能对比,以全面掌握其适用范围与局限性。
内容概要:本文详细介绍了一种基于Simulink的光伏储能单相逆变器并网仿真模型,系统涵盖了光伏阵列、储能单元、DC-AC单相逆变器及并网接口的完整结构,重点实现了储能环节的能量管理与逆变器并网控制策略的建模仿真。通过Simulink平台构建系统模型,验证了逆变器输出电能质量、并网稳定性以及控制系统的动态响应性能,采用SPWM调制、PI闭环控制等关键技术,确保并网电流与电网电压同频同相,满足并网电能质量要求。该模型不仅可用于分布式能源系统的仿真研究,还可作为新能源并网技术的教学与工程实践工具。; 适合人群:电气工程、自动化、新能源科学与工程等相关专业的高校本科生、研究生、科研人员,以及从事光伏发电系统设计、储能控制与并网技术研发的工程技术人员。; 使用场景及目标:①深入理解光伏储能系统中能量转换、存储与并网控制的整体工作原理;②支持课程设计、毕业设计或科研项目中对单相逆变器控制策略(如SPWM、PI调节、锁相技术等)的仿真验证与参数优化;③为后续研究更复杂的控制算法(如MPPT、低电压穿越、谐波抑制等)提供可扩展的仿真基础平台。; 阅读建议:建议结合MATLAB/Simulink环境动手搭建与调试模型,逐步理解各模块(如光伏建模、储能充放电控制、逆变器驱动、锁相环、PI调节器等)的功能与交互关系,重点关注控制系统的设计逻辑与参数整定过程,并可通过修改负载条件或电网参数测试系统鲁棒性,为进一步拓展至三相系统或多机并网场景奠定基础。

65,212

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧