多线程仿三菱

2024-03-23 13:32
文章标签 多线程 三菱

本文主要是介绍多线程仿三菱,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

from threading import Thread
import serial
from time import sleep
from threading import Thread
import cv2

port= serial.Serial(“COM1”,9600,parity=serial.PARITY_EVEN,stopbits= serial.STOPBITS_ONE,bytesize=7)
camera = cv2.VideoCapture(0)
img = None
datas = [0x02, 0x30, 0x30, 0x31, 0x31, 0x46, 0x30, 0x31, 0x03, 0x36, 0x43]
def Sum_Check(datas):
if (len(datas) ==0):
return False
sum = 0
for i in range(1,len(datas)-2):
sum+= datas[i]
sum %=256
sum_h = sum//16
sum_l = sum%16
sumcheck_H = 0
sumcheck_L = 0
if sum_h<10:
sumcheck_H = sum_h+0x30
else:
sumcheck_H = sum_h + 0x37
if sum_l<10:
sumcheck_L = sum_l +0x30
else:
sumcheck_L = sum_l + 0x37

if sumcheck_H != datas[len(datas)-2]:return Falseif sumcheck_L != datas[len(datas)-1]:return False
return True'''public static bool check(byte[] data){if (data.Length == 0) return false;if (data == null) return false;int sum = 0;for (int i = 1; i < data.Length - 2; i++){sum += data[i];}sum %= 256;int sum_H = sum / 16;int sum_L = sum % 16;int newsum_h = sum_H < 10 ? sum_H + 0x30 : sum_H + 0x37;int newsum_l = sum_L < 10 ? sum_L + 0x30 : sum_L + 0x37;if (newsum_h != data[data.Length - 2] || newsum_l != data[data.Length - 1]){return false;}return true;}
:return: 
'''

def savepicture():
pass
def main():
if port.isOpen():
port.close()
port.open()
while True:
# print(Thread.name)
if (cv2.waitKey(10) & 0xff) ==ord(‘s’):

        name = input("请输入端口号")if port.isOpen():port.close()port.name=nameport.open()port.write(datas)sleep(1)datas_Receive = port.read(6)str1 = ""for data in datas_Receive:str1+=" 0x"str1+= str(data)# str1 = " 0x".join(datas_Receive)isright = Sum_Check(datas_Receive)if isright:print("数据正确 " + str1)value_h = 0value_l = 0if datas_Receive[1]<0x39:value_h = datas_Receive[1]-0x30else:value_h = datas_Receive[1] - 0x37if datas_Receive[2]<0x39:value_l = datas_Receive[2]-0x30else:value_l = datas_Receive[2] - 0x37intreceive = value_h*16+value_lif(intreceive & 0x08)==0x08:print('开始气泡检测')cv2.imwrite("1.jpg",img)'''int value_h = data[1]<=0x39? data[1] - 0x30:data[1] -0x37;int value_l = data[2] <= 0x39 ? data[2] - 0x30 : data[2] - 0x37;return value_h * 16 + value_l;'''else:print("wrong")# print(str1)# print(datas_Receive)

if name == ‘main’:
thread1 =Thread(target=main)

thread1.start()
# thread1.join()
ret,frame = camera.read()
while True:ret,frame = camera.read()img = cv2.flip(frame,1)cv2.imshow("",img)cv2.waitKey(10)
# main()

这篇关于多线程仿三菱的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/838446

相关文章

SpringBoot中使用 ThreadLocal 进行多线程上下文管理及注意事项小结

《SpringBoot中使用ThreadLocal进行多线程上下文管理及注意事项小结》本文详细介绍了ThreadLocal的原理、使用场景和示例代码,并在SpringBoot中使用ThreadLo... 目录前言技术积累1.什么是 ThreadLocal2. ThreadLocal 的原理2.1 线程隔离2

Java多线程父线程向子线程传值问题及解决

《Java多线程父线程向子线程传值问题及解决》文章总结了5种解决父子之间数据传递困扰的解决方案,包括ThreadLocal+TaskDecorator、UserUtils、CustomTaskDeco... 目录1 背景2 ThreadLocal+TaskDecorator3 RequestContextH

C#多线程编程中导致死锁的常见陷阱和避免方法

《C#多线程编程中导致死锁的常见陷阱和避免方法》在C#多线程编程中,死锁(Deadlock)是一种常见的、令人头疼的错误,死锁通常发生在多个线程试图获取多个资源的锁时,导致相互等待对方释放资源,最终形... 目录引言1. 什么是死锁?死锁的典型条件:2. 导致死锁的常见原因2.1 锁的顺序问题错误示例:不同

浅析Rust多线程中如何安全的使用变量

《浅析Rust多线程中如何安全的使用变量》这篇文章主要为大家详细介绍了Rust如何在线程的闭包中安全的使用变量,包括共享变量和修改变量,文中的示例代码讲解详细,有需要的小伙伴可以参考下... 目录1. 向线程传递变量2. 多线程共享变量引用3. 多线程中修改变量4. 总结在Rust语言中,一个既引人入胜又可

多线程解析报表

假如有这样一个需求,当我们需要解析一个Excel里多个sheet的数据时,可以考虑使用多线程,每个线程解析一个sheet里的数据,等到所有的sheet都解析完之后,程序需要提示解析完成。 Way1 join import java.time.LocalTime;public class Main {public static void main(String[] args) thro

Java 多线程概述

多线程技术概述   1.线程与进程 进程:内存中运行的应用程序,每个进程都拥有一个独立的内存空间。线程:是进程中的一个执行路径,共享一个内存空间,线程之间可以自由切换、并发执行,一个进程最少有一个线程,线程实际数是在进程基础之上的进一步划分,一个进程启动之后,进程之中的若干执行路径又可以划分成若干个线程 2.线程的调度 分时调度:所有线程轮流使用CPU的使用权,平均分配时间抢占式调度

Java 多线程的基本方式

Java 多线程的基本方式 基础实现两种方式: 通过实现Callable 接口方式(可得到返回值):

JAVA- 多线程

一,多线程的概念 1.并行与并发 并行:多个任务在同一时刻在cpu 上同时执行并发:多个任务在同一时刻在cpu 上交替执行 2.进程与线程 进程:就是操作系统中正在运行的一个应用程序。所以进程也就是“正在进行的程序”。(Windows系统中,我们可以在任务管理器中看 到进程) 线程:是程序运行的基本执行单元。当操作系统执行一个程序时, 会在系统中建立一个进程,该进程必须至少建立一个线

多线程篇(阻塞队列- LinkedBlockingDeque)(持续更新迭代)

目录 一、LinkedBlockingDeque是什么 二、核心属性详解 三、核心方法详解 addFirst(E e) offerFirst(E e) putFirst(E e) removeFirst() pollFirst() takeFirst() 其他 四、总结 一、LinkedBlockingDeque是什么 首先queue是一种数据结构,一个集合中

多线程篇(阻塞队列- LinkedBlockingQueue)(持续更新迭代)

目录 一、基本概要 1. 构造函数 2. 内部成员 二、非阻塞式添加元素:add、offer方法原理 offer的实现 enqueue入队操作 signalNotEmpty唤醒 删除线程(如消费者线程) 为什么要判断if (c == 0)时才去唤醒消费线程呢? 三、阻塞式添加元素:put 方法原理 图解:put线程的阻塞过程 四、非阻塞式移除:poll方法原理 dequ