当前位置: 首页 > news >正文

2022年6月和7月的工作经历

6月

3D打标软件


3D打标软件,要求在Open3d上加几个2D文字。大致有如下几个方案:
依葫芦画瓢,但O3DVisualizer派生于gui::Window,我的程序派生于Visualizer。工作量不小。
利用OpenGL输出文字,Baidu的两种方法一个编译不过,一个根本就没效果。
利用Window API输出文字,本机上没问题。有两台机器显示高几率丢失。原因位置,可能是本机是集成显卡,那两台是独立显卡。
蹉跎一天多,最终利用Window API创建了几个Static显示文字。


同一个函数多线程执行时间


函数结束时间减去开始时间就是执行时间,如果是多线程,必须同一线程同一函数的结束时间减去同一线程同一函数的开始时间。手工计算太麻烦,于是写了个小工具。试用了一天发现,除了忘记限制同一线程,无其它问题。修正后,就好了。工具修正后,就不会出错了,手动计算这次没错不代表下次不出错。


7月


1.try


项目属性,加上 /EHa 后,可以try 到 catch (...) 我所知的所有异常,建议__try,这样可以得到崩溃时的堆栈。我实验了60种组合,5种C#调用方式(主线程、委托、线程、任务、线程池)、3种崩溃方式(本线程崩溃、AfxBeginThread崩溃、std::thread线程崩溃)、4类常见异常:
一,int* p = NULL;
*p = 3;
二,std::string str(NULL);
三, class Polymorphic { virtual void member() {} };
Polymorphic* p = NULL;
typeid(*p);
四,throw(1);
事后补充:CreateThread 也可以。


2.阴沟翻船


周五自己封装托管C++库,在用户的机器上启动不了。demo也是如此,情况如下:
一,托管C++和C# .netframe4.5,C++ 工具集v142。
二,传统c++的exe和dll都可以正常运行,C#的exe和C#的dll都是可以正常运行。
三,exe改成托管,也可运行。
用depend看,发现托管C++库链接了Debug版的运行库,改成MDd就好了。
猜测:
增加配置v142时复制了Debug而不是Release。


3.向日葵与VM冲突


 这两天发现VM不好用了,顶部悬浮工具栏不出来,alt+tab 多次才能到主机,无法从虚拟机复制文件到主机。可惨了,重启虚拟机都没用,只能重启主机。后来发现切换到主机,把向日葵的远程登陆关掉就好了,虽然还是麻烦,但是好多了。ToDesk似乎和VM不冲突,以前一直用todesk。发到微博后,收到ToDesk官方微博的回复。


4.死锁


和徐永昌谈到死锁,于是完成CCriticalGroup类以避免死锁,此类已经进入公司SVN库。线程一先后锁ab,线程二先后锁bc,线程三先后锁ca。运气不好的时候,3个线程对第一个锁加锁成功,无法对第二个锁加锁,因为已经被其它线程锁定了。
此类功能:
一,如果你按abc的顺序初始化CCriticalGroup类,无论你锁ab,还是锁ba,都是先锁a,再所b。
二,不需要自己维护临界区。
此类声明:

测试用例:

脉脉上有高人指点,std::scoped_lock std::lock std::lock_guard 可以解决死锁。VS2013、VS2015、VS2017不支持,VS2019默认不支持,改成C++17或C++20就支持了。

5.std::thread线程不触发SetUnhandledExceptionFilter 


发现std::thread启动的线程崩溃,不触发 SetUnhandledExceptionFilter ,没机会生成dump.txt和转储文件。一直手动__try,今天忙中抽闲研究一下发现std::thread的线程函数声明了noexcept。


6.系统卡死


用户那有部分电脑卡顿,我在测试平台试验了,出现了两次。症状如下:
一,整个操作系统无响应,鼠标、键盘输入无效。
二,windows任务管理器不刷新。
三,系统时间不更新。
四,鼠标上的灯是亮的。拔掉鼠标,再插上,鼠标的灯不亮。利用机箱上“重启键”重启后,鼠标的灯亮了。
无响应时:CPU不到20%,内存不到50%,两块硬盘0%,1%,网卡不到100K。
和perfmon的记录一致。
我们的程序是普通程序,Win10用户态程序有可能把操作系统卡死么?会不会是硬件驱动的问题。
和此产品的主程沟通,他没用使用hook、系统回调、系统钩子之类。但不排除其他程序员无意中使用了,他入职前就已经有这套程序了。
0环就只有一个进程了system,这个进程有近200个线程,我们的工控机是8核,就算回调、钩子有问题也只会卡死少数几个线程啊。应该会变卡,但不会卡死。魏家瑜说驱动层不能同时执行,一个回调卡死整个系统。


7.用户态的程序能卡死操作系统么?


昨天怀疑系统的回调函数会让系统(多核)变卡,但不会完全卡死。今天在Win10(4核),C#2013实验了一下。
结果:启动20个TestListenDir.exe,修改文件、重命名文件 都不会让系统变卡,更不会卡死。新增加文件,系统变卡,CPU占用100%,TestListenDir.exe每个占用CPU近5%。系统时间正常更新。

using System.IO;
using System.Windows.Forms;

namespace TestListenDir
{
    public partial class Form1 : Form
    {
        class WatcherFTPDir
        {
            public void MonitorDirectory(string path)
            {
                try
                {
                    FileSystemWatcher fileSystemWatcher = new FileSystemWatcher();
                    fileSystemWatcher.IncludeSubdirectories = true;
                    fileSystemWatcher.Path = path;
                    fileSystemWatcher.Created += FileSystemWatcher_Created;
                    fileSystemWatcher.Changed += FileSystemWatcher_Changed;
                    fileSystemWatcher.Renamed += FileSystemWatcher_Renamed;
                    fileSystemWatcher.EnableRaisingEvents = true;                    
                }
                catch
                {
                    
                }
            }

            private void FileSystemWatcher_Created(object sender, FileSystemEventArgs e)
            {
                long iIndex = 0;
                //大约需要7秒
                for (long i = 0; i < (long)10000*1000*1000; i++)
               {
                   iIndex = i;
               }
                MessageBox.Show(iIndex.ToString());
            }

            private void FileSystemWatcher_Changed(object sender, FileSystemEventArgs e)
            {
                MessageBox.Show("修改文件:" + e.FullPath);
            }

            private void FileSystemWatcher_Renamed(object sender, FileSystemEventArgs e)
            {
                System.Threading.Thread.Sleep(1000 * 100);
            }          
        }

        WatcherFTPDir watch = new WatcherFTPDir();
        public Form1()
        {
            InitializeComponent();
            watch.MonitorDirectory("c:\\a");
        }
    }
}


8.程序崩溃,Windows事件查看器看不到


本公司的某产品,在我、客户那可以正常生成自定义异常文件dump.txt,在Windows事件查看器也可以看到崩溃信息。在主程序员那两者皆无。操作系统都是Win10。问题暂未解决。自动覆盖旧日志开启了,所以不是磁盘空间满了。弄了个简单demo,崩溃后,windows事件查看器看得到。


9.Stack buffer overflow


同事的程序崩溃了,我的模块并没生成dump.txt。幸运的是,可以在客户那100%重现,同事自己的机器不重现。只好用WinDbg调试,可以定位崩溃函数名和函数的偏移量和错误类型。第二次崩溃崩溃前,把程序界面尽量往右拉,给wdg留出位置。发现windbg显示了崩溃行,只是被程序界面挡住了。错误类型是:Stack buffer overflow。此类错误最典型的例子:
char  c[1];
strcpy_s(c,"abc1111111111111111111111111111111222");
根据这两条信息,同事找到缺陷,OpenCV版本不对,Mat 的析构函数会崩溃。


10.续


之前就知道 栈溢出(Stack overflow),无法触发UnHand,昨天发现栈缓存溢出(Stack buffer overflow)也无法触发UnHand。今天实验了一下,无论是否/EHa ,这两种溢出都不会触发try __try。 Windows事件查看器会有记录。

相关文章:

2022年6月和7月的工作经历

6月 3D打标软件 3D打标软件&#xff0c;要求在Open3d上加几个2D文字。大致有如下几个方案&#xff1a; 依葫芦画瓢&#xff0c;但O3DVisualizer派生于gui::Window&#xff0c;我的程序派生于Visualizer。工作量不小。 利用OpenGL输出文字&#xff0c;Baidu的两种方法一个编…...

【图像处理】SIFT角点特征提取原理

一、说明 提起在OpenCV中的特征点提取&#xff0c;可以列出Harris&#xff0c;可以使用SIFT算法或SURF算法来检测图像中的角特征点。本篇围绕sift的特征点提取&#xff0c;只是管中窥豹&#xff0c;而更多的特征点算法有&#xff1a; Harris & Stephens / Shi–Tomasi 角点…...

flutter开发实战-应用更新apk下载、安装apk、启动应用实现

flutter开发实战-应用更新apk下载、安装apk、启动应用实现 在开发过程中&#xff0c;经常遇到需要更新下载新版本的apk文件&#xff0c;之后进行应用更新apk下载、安装apk、启动应用。我们在flutter工程中实现下载apk&#xff0c;判断当前版本与需要更新安装的版本进行比对判断…...

DispatcherServlet初始化之Spring容器创建1.0

一、前言 在SpringMVC框架中&#xff0c;DispatcherServlet扮演着非常重要的角色&#xff0c;它负责接收所有的HTTP请求并将其分发给相应的处理器。在DispatcherServlet的初始化过程中&#xff0c;会创建一个Spring容器来管理应用程序中的Bean。 二、步骤 1、加载配置文件&a…...

CSS的基础

CSS美化HTML&#xff0c;布局网页 CSS最大的价值&#xff1a;由HTML专注去做结构呈现&#xff0c;样式给CSS&#xff0c;结构&#xff08;HTML)与样式&#xff08;CSS&#xff09;相分离 CSS主要由选择器以及一条或多条声明 在<head></head>中实现CSS在<body…...

mathtype如何嵌入到word中?详细mathtype安装步骤教程

mathtype是一款功能特别强大的数学方式编辑软件&#xff0c;为用户提供各种强大的数学公式符号帮助用户进行计算&#xff0c;并且速度很快。有小伙伴知道mathtype如何嵌入到word中吗&#xff0c;这里小编就给大家详细介绍一下mathtype嵌入到word中的方法&#xff0c;有需要的小…...

云安全之访问控制的常见攻击及防御

访问控制攻击概述 访问控制漏洞即应用程序允许攻击者执行或者访问某种攻击者不具备相应权限的功能或资源。 常见的访问控制可以分为垂直访问控制、水平访问控制及多阶段访问控制 (上下文相关访问控制)&#xff0c;与其相应的访问控制漏洞为也垂直越权漏洞(普通用户可以访问或…...

Java编程技巧:跨域

目录 1、跨域概念2、后端CORS&#xff08;跨域资源共享&#xff09;配置原理3、既然请求跨域了&#xff0c;那么请求到底发出去没有&#xff1f;4、通过后端CORS&#xff08;跨域资源共享&#xff09;配置解决跨域问题代码4.1、SpringBoot&#xff08;FilterRegistrationBean&a…...

react create-react-app 配置less

环境信息&#xff1a; create-react-app:v5 react:18.2.0 node:18.16.0 如果你不必须使用 less 建议直接使用scss。 因为less配置会遇到很多问题。 配置less过程&#xff1a; 如果你只需要 sass的话&#xff0c;就可以直接使用sass。因为默认配置了scss。 npm、yarn、cnpm、…...

树的表示——孩子兄弟表示法

从图中可以看出&#xff0c;树的每个结点&#xff0c;都有不确定的指向他们的孩子的节点&#xff0c;如果我们定义这样一个结构体来便是数的结构的话&#xff1a; struct TreeNode { int val; struct TreeNodep1; struct TreeNodep1; … }; 是不能够表示一棵树的&#xff0c;因…...

Windows11安装MySQL8.1

安装过程中遇到任何问题均可以参考(这个博客只是单纯升级个版本和简化流程) Windows安装MySQL8教程-CSDN博客 到官网下载mysql8数据库软件 MySQL :: Download MySQL Community Server 下载完后,解压到你需要安装的文件夹 其中的配置文件内容了如下 [mysqld]# 设置3306端口po…...

Linux编程——经典链表list_head

1. 关于list_head struct list_head是Linux内核定义的双向链表&#xff0c;包含一个指向前驱节点和后继节点的指针的结构体。其定义如下&#xff1a; struct list_head {struct list_head *next, *prev; //双向链表&#xff0c;指向节点的指针 };1.1 链表的定义和初始化 有两…...

基于51单片机NEC协议红外遥控发送接收仿真设计( proteus仿真+程序+原理图+报告+讲解视频)

基于51单片机NEC协议红外遥控发送接收仿真设计 讲解视频1.主要功能&#xff1a;2.仿真3. 程序代码4. 原理图5. 设计报告6. 设计资料内容清单&&下载链接 基于51单片机NEC协议红外遥控发送接收仿真设计 51单片机红外发送接收仿真设计( proteus仿真程序原理图报告讲解视频…...

Jmeter分布式压力测试

目录 1、场景 2、原理 3、注意事项 4、slave配置 5、master配置 6、脚本执行 1、场景 在做性能测试时&#xff0c;单台机器进行压测可能达不到预期结果。主要原因是单台机器压到一定程度会出现瓶颈。也有可能单机网卡跟不上造成结果偏差较大。 例如4C8G的window server机…...

Rust :mod.rs和lib.rs中use的作用

一、mod.rs和lib.rs mod.rs往往是把同一目录下的n个rs文件综合在一起的有效方式&#xff1b; lib.rs是一个库或子库层次综合在一起的有效方式&#xff1b; 下面举个实例来说明。生成一个rusttoc本地库&#xff08;由cargo new rusttoc --lib所生成&#xff09;&#xff0c;目录…...

ISP图像信号处理——平场校正介绍以及C++实现

参考文章1&#xff1a;http://t.csdn.cn/h8TBy 参考文章2&#xff1a;http://t.csdn.cn/6nmsT 参考网址3&#xff1a;opencv平场定标 - CSDN文库 平场校正一般先用FPN(Fixed Pattern Noise)固定图像噪声校正,即暗场校正&#xff1b;再用PRNU(Photo Response Non Uniformity)…...

【深入了解Java String类】

目录 String类 常用方法 字符串的不可变性 String的内存分析 StringBuilder类 解释可变和不可变字符串 常用方法 面试题&#xff1a;String&#xff0c;StringBuilder&#xff0c;StringBuffer之间的区别和联系 String类的OJ练习 String类 【1】直接使用&#xff0c…...

基于SpringBoot的知识管理系统

目录 前言 一、技术栈 二、系统功能介绍 用户管理 文章分类 资料分类 文章信息 论坛交流 资料下载 三、核心代码 1、登录模块 2、文件上传模块 3、代码封装 前言 随着信息互联网信息的飞速发展&#xff0c;无纸化作业变成了一种趋势&#xff0c;针对这个问题开发一个…...

Pytorch基础:Tensor的reshape方法

在Pytorch中&#xff0c;reshape是Tensor的一个重要方法&#xff0c;它与Numpy中的reshape类似&#xff0c;用于返回一个改变了形状但数据和数据顺序和原来一致的新Tensor对象。注意&#xff1a;此时返回的数据对象并不一定是新的&#xff0c;这取决于应用此方法的Tensor是否是…...

【数据库——MySQL】(13)过程式对象程序设计——存储函数、错误处理以及事务管理

目录 1. 存储函数2. 存储函数的应用3. 错误处理4. 抛出异常5. 事务处理6. 事务隔离级7. 应用实例参考书籍 1. 存储函数 要 创建 存储函数&#xff0c;需要用到 CREATE 语句&#xff1a; CREATE FUNCTION 存储函数名([参数名 类型, ...])RETURNS 类型[存储函数体]注意&#xff1…...

在软件开发中正确使用MySQL日期时间类型的深度解析

在日常软件开发场景中&#xff0c;时间信息的存储是底层且核心的需求。从金融交易的精确记账时间、用户操作的行为日志&#xff0c;到供应链系统的物流节点时间戳&#xff0c;时间数据的准确性直接决定业务逻辑的可靠性。MySQL作为主流关系型数据库&#xff0c;其日期时间类型的…...

超短脉冲激光自聚焦效应

前言与目录 强激光引起自聚焦效应机理 超短脉冲激光在脆性材料内部加工时引起的自聚焦效应&#xff0c;这是一种非线性光学现象&#xff0c;主要涉及光学克尔效应和材料的非线性光学特性。 自聚焦效应可以产生局部的强光场&#xff0c;对材料产生非线性响应&#xff0c;可能…...

大话软工笔记—需求分析概述

需求分析&#xff0c;就是要对需求调研收集到的资料信息逐个地进行拆分、研究&#xff0c;从大量的不确定“需求”中确定出哪些需求最终要转换为确定的“功能需求”。 需求分析的作用非常重要&#xff0c;后续设计的依据主要来自于需求分析的成果&#xff0c;包括: 项目的目的…...

简易版抽奖活动的设计技术方案

1.前言 本技术方案旨在设计一套完整且可靠的抽奖活动逻辑,确保抽奖活动能够公平、公正、公开地进行,同时满足高并发访问、数据安全存储与高效处理等需求,为用户提供流畅的抽奖体验,助力业务顺利开展。本方案将涵盖抽奖活动的整体架构设计、核心流程逻辑、关键功能实现以及…...

Qt Widget类解析与代码注释

#include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this); }Widget::~Widget() {delete ui; }//解释这串代码&#xff0c;写上注释 当然可以&#xff01;这段代码是 Qt …...

关于nvm与node.js

1 安装nvm 安装过程中手动修改 nvm的安装路径&#xff0c; 以及修改 通过nvm安装node后正在使用的node的存放目录【这句话可能难以理解&#xff0c;但接着往下看你就了然了】 2 修改nvm中settings.txt文件配置 nvm安装成功后&#xff0c;通常在该文件中会出现以下配置&…...

为什么需要建设工程项目管理?工程项目管理有哪些亮点功能?

在建筑行业&#xff0c;项目管理的重要性不言而喻。随着工程规模的扩大、技术复杂度的提升&#xff0c;传统的管理模式已经难以满足现代工程的需求。过去&#xff0c;许多企业依赖手工记录、口头沟通和分散的信息管理&#xff0c;导致效率低下、成本失控、风险频发。例如&#…...

高频面试之3Zookeeper

高频面试之3Zookeeper 文章目录 高频面试之3Zookeeper3.1 常用命令3.2 选举机制3.3 Zookeeper符合法则中哪两个&#xff1f;3.4 Zookeeper脑裂3.5 Zookeeper用来干嘛了 3.1 常用命令 ls、get、create、delete、deleteall3.2 选举机制 半数机制&#xff08;过半机制&#xff0…...

spring:实例工厂方法获取bean

spring处理使用静态工厂方法获取bean实例&#xff0c;也可以通过实例工厂方法获取bean实例。 实例工厂方法步骤如下&#xff1a; 定义实例工厂类&#xff08;Java代码&#xff09;&#xff0c;定义实例工厂&#xff08;xml&#xff09;&#xff0c;定义调用实例工厂&#xff…...

第一篇:Agent2Agent (A2A) 协议——协作式人工智能的黎明

AI 领域的快速发展正在催生一个新时代&#xff0c;智能代理&#xff08;agents&#xff09;不再是孤立的个体&#xff0c;而是能够像一个数字团队一样协作。然而&#xff0c;当前 AI 生态系统的碎片化阻碍了这一愿景的实现&#xff0c;导致了“AI 巴别塔问题”——不同代理之间…...