C++优秀串口库

serial::Serial Class Reference

#include <serial.h>

Data Structures

class  ScopedReadLock
class  ScopedWriteLock

Public Member Functions公有成员方法(编程用的都在这里了,那些私有的如果不开源一般跟我们没有关系了)

Serial (const std::string &port="", uint32_t baudrate=9600, Timeout timeout=Timeout(), 

bytesize_t bytesize=eightbits, parity_t parity=parity_none, 

stopbits_t stopbits=stopbits_one, flowcontrol_t flowcontrol=flowcontrol_none)构造函数

virtual ~Serial ()析构函数
void open ()
bool isOpen () const
void close ()
size_t available ()
size_t read (uint8_t *buffer, size_t size)
size_t read (std::vector< uint8_t > &buffer, size_t size=1)
size_t read (std::string &buffer, size_t size=1)
std::string read (size_t size=1)
size_t readline (std::string &buffer, size_t size=65536, std::string eol="\n")
std::string readline (size_t size=65536, std::string eol="\n")
std::vector< std::string > readlines (size_t size=65536, std::string eol="\n")
size_t write (const uint8_t *data, size_t size)
size_t write (const std::vector< uint8_t > &data)
size_t write (const std::string &data)
void setPort (const std::string &port)
std::string getPort () const
void setTimeout (Timeout &timeout)
void 

setTimeout (uint32_t inter_byte_timeout, uint32_t read_timeout_constant,

uint32_t read_timeout_multiplier, uint32_t write_timeout_constant,

uint32_t write_timeout_multiplier)

TimeoutgetTimeout () const
void setBaudrate (uint32_t baudrate)
uint32_t getBaudrate () const
void setBytesize (bytesize_t bytesize)
bytesize_tgetBytesize () const
void setParity (parity_t parity)
parity_tgetParity () const
void setStopbits (stopbits_t stopbits)
stopbits_tgetStopbits () const
void setFlowcontrol (flowcontrol_t flowcontrol)
flowcontrol_tgetFlowcontrol () const
void flush ()
void flushInput ()
void flushOutput ()
void sendBreak (int duration)
void setBreak (bool level=true)
void setRTS (bool level=true)
void setDTR (bool level=true)
bool waitForChange ()
bool getCTS ()
bool getDSR ()
bool getRI ()
bool getCD ()

Detailed Description(后面是对以上表格内容的详细介绍)

Class that provides a portable serial port interface.


Constructor & Destructor Documentation构造函数+析构函数

serial::Serial::Serial(const std::string & port = "",
uint32_t baudrate = 9600,
Timeouttimeout = Timeout(),
bytesize_tbytesize = eightbits,
parity_tparity = parity_none,
stopbits_tstopbits = stopbits_one,
flowcontrol_tflowcontrol = flowcontrol_none 
)

Creates a Serial object and opens the port if a port is specified, otherwise it remains closed until serial::Serial::open is called.

创建一个串口对象,如果制定了端口号,那么这个串口将打开,否则现在不会打开,会等到调用open函数的时候再打开

Parameters:

portA std::string containing the address of the serial port, which would be something like 'COM1' on Windows and '/dev/ttyS0' on Linux.(地址值:Windows系统类似于COM1,LINUX系统类似于/dev/ttyS0这样的款式)
baudrateAn unsigned 32-bit integer that represents the baudrate波特率:是一个32位的int类型数据
timeoutA serial::Timeout struct that defines the timeout conditions for the serial port.超时的时间值

See also:

serial::Timeout

Parameters:(对上面的timeout结构体详细介绍,一下是结构体的成员变量)

bytesize

字长

Size of each byte in the serial transmission of data, default is eightbits, possible values are: fivebits, sixbits, sevenbits, eightbits默认字长是8位,可以是5,6,7,8好像不能是9位

parity

效验位

Method of parity, default is parity_none, possible values are: parity_none, parity_odd, parity_even

stopbits

停止位

Number of stop bits used, default is stopbits_one, possible values are: stopbits_one, stopbits_one_point_five, stopbits_two

flowcontrol

流控

Type of flowcontrol used, default is flowcontrol_none, possible values are: flowcontrol_none, flowcontrol_software, flowcontrol_hardware

Exceptions:

PortNotOpenedException

Serial::~Serial()[virtual]

Destructor

{delete pimpl_;
}

Member Function Documentation

size_t Serial::available()

Return the number of characters in the buffer.

{return pimpl_->available ();
}

void Serial::close()

Closes the serial port.

{pimpl_->close ();
}

void Serial::flush()

Flush the input and output buffers

{ScopedReadLock(this->pimpl_);ScopedWriteLock(this->pimpl_);pimpl_->flush ();read_cache_.clear ();
}

void Serial::flushInput()

Flush only the input buffer

{ScopedReadLock(this->pimpl_);pimpl_->flushInput ();
}

void Serial::flushOutput()

Flush only the output buffer

{ScopedWriteLock(this->pimpl_);pimpl_->flushOutput ();read_cache_.clear ();
}

uint32_t Serial::getBaudrate()const

Gets the baudrate for the serial port.获取波特率

Returns:

An integer that sets the baud rate for the serial port.

See also:

Serial::setBaudrate

Exceptions:

InvalidConfigurationException
{return uint32_t(pimpl_->getBaudrate ());
}

bytesize_t Serial::getBytesize()const

Gets the bytesize for the serial port.设置“数据字长”一般是8位

See also:

Serial::setBytesize

Exceptions:

InvalidConfigurationException
{return pimpl_->getBytesize ();
}

bool Serial::getCD()

Returns the current status of the CD line.

{return pimpl_->getCD ();
}

bool Serial::getCTS()

Returns the current status of the CTS line.

{return pimpl_->getCTS ();
}

bool Serial::getDSR()

Returns the current status of the DSR line.

{return pimpl_->getDSR ();
}

flowcontrol_t Serial::getFlowcontrol()const

Gets the flow control for the serial port.

See also:

Serial::setFlowcontrol

Exceptions:

InvalidConfigurationException
{return pimpl_->getFlowcontrol ();
}

parity_t Serial::getParity()const

Gets the parity for the serial port.

See also:

Serial::setParity

Exceptions:

InvalidConfigurationException
{return pimpl_->getParity ();
}

string Serial::getPort()const

Gets the serial port identifier.

See also:

Serial::setPort

Exceptions:

InvalidConfigurationException
{return pimpl_->getPort ();
}

bool Serial::getRI()

Returns the current status of the RI line.

{return pimpl_->getRI ();
}

stopbits_t Serial::getStopbits()const

Gets the stopbits for the serial port.

See also:

Serial::setStopbits

Exceptions:

InvalidConfigurationException
{return pimpl_->getStopbits ();
}

serial::Timeout Serial::getTimeout()const

Gets the timeout for reads in seconds.

Returns:

A Timeout struct containing the inter_byte_timeout, and read and write timeout constants and multipliers.

See also:

Serial::setTimeout

                          {return pimpl_->getTimeout ();
}

bool Serial::isOpen()const

Gets the open status of the serial port.

Returns:

Returns true if the port is open, false otherwise.

{return pimpl_->isOpen ();
}

void Serial::open()

Opens the serial port as long as the port is set and the port isn't already open.

If the port is provided to the constructor then an explicit call to open is not needed.

See also:

Serial::Serial

Exceptions:

std::invalid_argument
serial::SerialExecption
serial::IOException
{pimpl_->open ();
}

size_t Serial::read(uint8_t * buffer,
size_t size 
)

Read a given amount of bytes from the serial port into a given buffer.

这不就是我们的目的:从串口读取数据

The read function will return in one of three cases:(我觉得一般不用管后面这几种情况)

  • The number of requested bytes was read.
    • In this case the number of bytes requested will match the size_t returned by read.
  • A timeout occurred, in this case the number of bytes read will not match the amount requested, but no exception will be thrown. One of two possible timeouts occurred:
    • The inter byte timeout expired, this means that number of milliseconds elapsed between receiving bytes from the serial port exceeded the inter byte timeout.
    • The total timeout expired, which is calculated by multiplying the read timeout multiplier by the number of requested bytes and then added to the read timeout constant. If that total number of milliseconds elapses after the initial call to read a timeout will occur.
  • An exception occurred, in this case an actual exception will be thrown.

Parameters:函数参数

bufferAn uint8_t array of at least the requested size.一个uint8_t数据类型的数组,长度至少达到size指定大小
sizeA size_t defining how many bytes to be read.

Returns:函数返回值

A size_t representing the number of bytes read as a result of the call to read.(从串口读取了多少个字符串就把字符串长度作为返回值,所以可以根据返回值是否等于size参数判断是否发生异常)

{ScopedReadLock (this->pimpl_);return this->pimpl_->read (buffer, size);
}

size_t Serial::read(std::vector< uint8_t > & buffer,
size_t size = 1 
)

Read a given amount of bytes from the serial port into a give buffer.这跟上边那个数组几乎完全一样

Parameters:

bufferA reference to a std::vector of uint8_t.
sizeA size_t defining how many bytes to be read.

Returns:

A size_t representing the number of bytes read as a result of the call to read.

{ScopedReadLock (this->pimpl_);uint8_t *buffer_ = new uint8_t[size];size_t bytes_read = this->pimpl_->read (buffer_, size);buffer.insert (buffer.end (), buffer_, buffer_+bytes_read);delete[] buffer_;return bytes_read;
}

size_t Serial::read(std::string & buffer,
size_t size = 1 
)

Read a given amount of bytes from the serial port into a give buffer.

Parameters:

bufferA reference to a std::string.
sizeA size_t defining how many bytes to be read.

Returns:

A size_t representing the number of bytes read as a result of the call to read.

{ScopedReadLock (this->pimpl_);uint8_t *buffer_ = new uint8_t[size];size_t bytes_read = this->pimpl_->read (buffer_, size);buffer.append (reinterpret_cast<const char*>(buffer_), bytes_read);delete[] buffer_;return bytes_read;
}

string Serial::read(size_t size = 1)

Read a given amount of bytes from the serial port and return a string containing the data.

Parameters:

sizeA size_t defining how many bytes to be read.

Returns:

A std::string containing the data read from the port.

{std::string buffer;this->read (buffer, size);return buffer;
}

这里

size_t serial::Serial::readline(std::string & buffer,
size_t size = 65536,
std::string eol = "\n" 
)

Reads in a line or until a given delimiter has been processed.

Reads from the serial port until a single line has been read.

Parameters:

bufferA std::string reference used to store the data.
sizeA maximum length of a line, defaults to 65536 (2^16)
eolA string to match against for the EOL.

Returns:

A size_t representing the number of bytes read.

std::string serial::Serial::readline(size_t size = 65536,
std::string eol = "\n" 
)

Reads in a line or until a given delimiter has been processed.

Reads from the serial port until a single line has been read.

Parameters:

sizeA maximum length of a line, defaults to 65536 (2^16)
eolA string to match against for the EOL.

Returns:

A std::string containing the line.

vector< string > Serial::readlines(size_t size = 65536,
std::string eol = "\n" 
)

Reads in multiple lines until the serial port times out.

This requires a timeout > 0 before it can be run. It will read until a timeout occurs and return a list of strings.

Parameters:

sizeA maximum length of combined lines, defaults to 65536 (2^16)
eolA string to match against for the EOL.

Returns:

A vector<string> containing the lines.

{ScopedReadLock (this->pimpl_);std::vector<std::string> lines;size_t eol_len = eol.length ();uint8_t *buffer_ = static_cast<uint8_t*>(alloca (size * sizeof (uint8_t)));size_t read_so_far = 0;size_t start_of_line = 0;while (read_so_far < size) {size_t bytes_read = this->read_ (buffer_+read_so_far, 1);read_so_far += bytes_read;if (bytes_read == 0) {if (start_of_line != read_so_far) {lines.push_back (string (reinterpret_cast<const char*> (buffer_ + start_of_line),read_so_far - start_of_line));}break; // Timeout occured on reading 1 byte}if (string (reinterpret_cast<const char*>(buffer_ + read_so_far - eol_len), eol_len) == eol) {// EOL foundlines.push_back(string(reinterpret_cast<const char*> (buffer_ + start_of_line),read_so_far - start_of_line));start_of_line = read_so_far;}if (read_so_far == size) {if (start_of_line != read_so_far) {lines.push_back(string(reinterpret_cast<const char*> (buffer_ + start_of_line),read_so_far - start_of_line));}break; // Reached the maximum read length}}return lines;
}

void Serial::sendBreak(int duration)

Sends the RS-232 break signal. See tcsendbreak(3).

{pimpl_->sendBreak (duration);
}

void Serial::setBaudrate(uint32_t baudrate)

Sets the baudrate for the serial port.

Possible baudrates depends on the system but some safe baudrates include: 110, 300, 600, 1200, 2400, 4800, 9600, 14400, 19200, 28800, 38400, 56000, 57600, 115200 Some other baudrates that are supported by some comports: 128000, 153600, 230400, 256000, 460800, 921600

Parameters:

baudrateAn integer that sets the baud rate for the serial port.

Exceptions:

InvalidConfigurationException
{pimpl_->setBaudrate (baudrate);
}

void Serial::setBreak(bool level = true)

Set the break condition to a given level. Defaults to true.

{pimpl_->setBreak (level);
}

void Serial::setBytesize(bytesize_tbytesize)

Sets the bytesize for the serial port.

Parameters:

bytesizeSize of each byte in the serial transmission of data, default is eightbits, possible values are: fivebits, sixbits, sevenbits, eightbits

Exceptions:

InvalidConfigurationException
{pimpl_->setBytesize (bytesize);
}

void Serial::setDTR(bool level = true)

Set the DTR handshaking line to the given level. Defaults to true.

{pimpl_->setDTR (level);
}

void Serial::setFlowcontrol(flowcontrol_tflowcontrol)

Sets the flow control for the serial port.

Parameters:

flowcontrolType of flowcontrol used, default is flowcontrol_none, possible values are: flowcontrol_none, flowcontrol_software, flowcontrol_hardware

Exceptions:

InvalidConfigurationException
{pimpl_->setFlowcontrol (flowcontrol);
}

void Serial::setParity(parity_tparity)

Sets the parity for the serial port.

Parameters:

parityMethod of parity, default is parity_none, possible values are: parity_none, parity_odd, parity_even

Exceptions:

InvalidConfigurationException
{pimpl_->setParity (parity);
}

void Serial::setPort(const std::string & port)

Sets the serial port identifier.

Parameters:

portA const std::string reference containing the address of the serial port, which would be something like 'COM1' on Windows and '/dev/ttyS0' on Linux.

Exceptions:

InvalidConfigurationException
{ScopedReadLock(this->pimpl_);ScopedWriteLock(this->pimpl_);bool was_open = pimpl_->isOpen ();if (was_open) close();pimpl_->setPort (port);if (was_open) open ();
}

void Serial::setRTS(bool level = true)

Set the RTS handshaking line to the given level. Defaults to true.

{pimpl_->setRTS (level);
}

void Serial::setStopbits(stopbits_tstopbits)

Sets the stopbits for the serial port.

Parameters:

stopbitsNumber of stop bits used, default is stopbits_one, possible values are: stopbits_one, stopbits_one_point_five, stopbits_two

Exceptions:

InvalidConfigurationException
{pimpl_->setStopbits (stopbits);
}

void Serial::setTimeout(serial::Timeout & timeout)

Sets the timeout for reads and writes using the Timeout struct.

There are two timeout conditions described here:

  • The inter byte timeout:
    • The inter_byte_timeout component of serial::Timeout defines the maximum amount of time, in milliseconds, between receiving bytes on the serial port that can pass before a timeout occurs. Setting this to zero will prevent inter byte timeouts from occurring.
  • Total time timeout:
    • The the constant and multiplier component of this timeout condition, for both read and write, are defined in serial::Timeout. This timeout occurs if the total time since the read or write call was made exceeds the specified time in milliseconds.
    • The limit is defined by multiplying the multiplier component by the number of requested bytes and adding that product to the constant component. In this way if you want a read call, for example, to timeout after exactly one second regardless of the number of bytes you asked for then set the read_timeout_constant component of serial::Timeout to 1000 and the read_timeout_multiplier to zero. This timeout condition can be used in conjunction with the inter byte timeout condition with out any problems, timeout will simply occur when one of the two timeout conditions is met. This allows users to have maximum control over the trade-off between responsiveness and efficiency.

Read and write functions will return in one of three cases. When the reading or writing is complete, when a timeout occurs, or when an exception occurs.

Parameters:

timeoutA serial::Timeout struct containing the inter byte timeout, and the read and write timeout constants and multipliers.

See also:

serial::Timeout

{pimpl_->setTimeout (timeout);
}

void serial::Serial::setTimeout(uint32_t inter_byte_timeout,
uint32_t read_timeout_constant,
uint32_t read_timeout_multiplier,
uint32_t write_timeout_constant,
uint32_t write_timeout_multiplier 
)[inline]

Sets the timeout for reads and writes.

  {Timeout timeout(inter_byte_timeout, read_timeout_constant,read_timeout_multiplier, write_timeout_constant,write_timeout_multiplier);return setTimeout(timeout);}

bool Serial::waitForChange()

Blocks until CTS, DSR, RI, CD changes or something interrupts it.

Can throw an exception if an error occurs while waiting. You can check the status of CTS, DSR, RI, and CD once this returns. Uses TIOCMIWAIT via ioctl if available (mostly only on Linux) with a resolution of less than +-1ms and as good as +-0.2ms. Otherwise a polling method is used which can give +-2ms.

Returns:

Returns true if one of the lines changed, false if something else occurred.

Exceptions:

SerialException
{return pimpl_->waitForChange();
}

size_t Serial::write(const uint8_t * data,
size_t size 
)

Write a string to the serial port.

Parameters:

dataA const reference containing the data to be written to the serial port.
sizeA size_t that indicates how many bytes should be written from the given data buffer.

Returns:

A size_t representing the number of bytes actually written to the serial port.

{ScopedWriteLock(this->pimpl_);return this->write_(data, size);
}

size_t Serial::write(const std::vector< uint8_t > & data)

Write a string to the serial port.

Parameters:

dataA const reference containing the data to be written to the serial port.

Returns:

A size_t representing the number of bytes actually written to the serial port.

{ScopedWriteLock(this->pimpl_);return this->write_ (&data[0], data.size());
}

size_t serial::Serial::write(const std::string & data)

Write a string to the serial port.

Parameters:

dataA const reference containing the data to be written to the serial port.

Returns:

A size_t representing the number of bytes actually written to the serial port.


The documentation for this class was generated from the following files:

  • include/serial/serial.h
  • src/serial.cc

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/211528.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

用chatGPT开发项目:我想的无人的智慧树网站 流量之神 利用人工智能的算法将人吸引住 GPT4是不是越来越难用了,问一下就要证明一下自己是不是人类

广度发散&#xff1a;让AI给出时代或今日或你关注的热点事件 比如采集新闻头条&#xff0c;根据内容或标题&#xff0c;以不同的角度&#xff0c;或各种人群的角色&#xff0c;生成50篇简短的文章。一下就能占传统的搜索引擎。这是AI最擅长的【千人千面&#xff0c;海量生成】…

【中国海洋大学】操作系统随堂测试6整理

1. IO系统的层次机构包括&#xff1a;IO硬件、中断处理程序、&#xff08;&#xff09;程序、设备独立性软件、用户层软件。 答&#xff1a;设备驱动 2. IO设备和控制器之间的接口包括三种类型的信号&#xff1a;数据信号线、控制信号线和&#xff08;&#xff09;&#xff1…

qt反射基础

最近研究了一下QT的反射机制&#xff0c; Qt的元对象系统除了提供信号/槽机制的特性之外&#xff0c;它还提供了以下特性: QObject::metaObject() 返回关联的元对象 QMetaObject::className() 在运行时状态下返回类名 QObject::inherits() 判断类的继承关系 QObject::tr()&…

鸿蒙开发之封装优化

面向对象开发离不开封装&#xff0c;将重复的可以复用的代码封装起来&#xff0c;提高开发效率。 基于之前的List&#xff0c;对代码进行封装。 1、抽取component 将List的头部抽离出来作为一个新的component。可以创建一个新的ArkTS文件&#xff0c;写我们的头部代码 为了…

代理模式:解析对象间的间接访问与控制

目录 引言 理解代理模式 不同类型的代理模式 代理模式的应用场景 代理模式的优缺点 优点 缺点 实际案例&#xff1a;Java中的代理模式应用 结语 引言 代理模式是软件设计模式中的一种结构型模式&#xff0c;旨在为其他对象提供一种代理以控制对这个对象的访问。它允许你…

消息队列使用指南

介绍 消息队列是一种常用的应用程序间通信方法&#xff0c;可以用来在不同应用程序或组件之间传递数据或消息。消息队列就像一个缓冲区&#xff0c;接收来自发送方的消息&#xff0c;并存储在队列中&#xff0c;等待接收方从队列中取出并处理。 在分布式系统中&#xff0c;消…

死锁问题,4个必要条件+避免死锁

目录 引入 死锁 概念 示例 多把锁 单锁 4个必要条件 用途 引入 我们用加锁的方式保证了多个线程访问临界资源时,不会出现数据紊乱的问题 但是,锁的引入,会导致出现其他的问题 死锁 概念 在多线程或多进程的并发环境中&#xff0c;两个或多个进程或线程被永久阻塞&…

esxi全称“VMware ESXi

esxi全称“VMware ESXi”&#xff0c;是可直接安装在物理服务器上的强大的裸机管理系统&#xff0c;是一款虚拟软件&#xff1b;ESXi本身可以看做一个操作系统&#xff0c;采用Linux内核&#xff0c;安装方式为裸金属方式&#xff0c;可直接安装在物理服务器上&#xff0c;不需…

数据结构算法-希尔排序算法

引言 在一个普通的下午&#xff0c;小明和小森决定一起玩“谁是老板”的扑克牌游戏。这次他们玩的可不仅仅是娱乐&#xff0c;更是要用扑克牌来决定谁是真正的“大老板”。 然而&#xff0c;小明的牌就像刚从乱麻中取出来的那样&#xff0c;毫无头绪。小森的牌也像是被小丑掷…

Agent学习笔记

背景&#xff1a;LLM → \to → Agent ChatGPT为代表的大语言模型就不用过多的介绍了&#xff0c;ChatGPT很强大&#xff0c;但是也有做不到的东西。例如&#xff1a; 实时查询问题&#xff1a;实时的天气&#xff0c;地理位置&#xff0c;最新新闻报道&#xff0c;现实世界…

十年婚姻·总结八

十年婚姻总结八 女人一生的合伙人不能只是帅哥哥 女人一生的合伙人不能只是帅哥哥 浪漫的本质还是你的筹码。 比如你送男人5万的手表&#xff0c;但你没什么其他筹码&#xff08;皮肤粗糙蜡黄、没人脉金钱资源、长的胖&#xff09;。 那个男人会觉得你胡闹&#xff0c;你送的…

分类预测 | SSA-HKELM-Adaboost麻雀算法优化混合核极限学习机的数据分类预测

分类预测 | SSA-HKELM-Adaboost麻雀算法优化混合核极限学习机的数据分类预测 目录 分类预测 | SSA-HKELM-Adaboost麻雀算法优化混合核极限学习机的数据分类预测分类效果基本描述程序设计参考资料 分类效果 基本描述 1.SSA-HKELM-Adaboost麻雀算法优化混合核极限学习机的数据分类…

引用文献算作重复率么【一文读懂】

大家好&#xff0c;今天来聊聊引用文献算作重复率么&#xff0c;希望能给大家提供一点参考。 以下是针对论文重复率高的情况&#xff0c;提供一些修改建议和技巧&#xff1a; 引用文献算作重复率么 在学术研究和论文撰写过程中&#xff0c;引用文献是不可或缺的一部分小发猫伪…

shell学习1——txt文件备份,文件名加个年月日的后缀,如test.txt对于备份文件为test.txt_20231205

跟B站Up主学习shell脚本——阿铭linux 3461576172505894 需求 txt文件备份&#xff0c;文件名加个年月日的后缀&#xff0c;如test.txt对于备份文件为test.txt_20231205 代码 #!/bin/bash ##定义后缀变量 suffixdate %Y%m%d##找到/test/目录下的txt文件 for f in find /tes…

ubuntu源配置文件/etc/apt/sources.list不存在

若使用命令sudo apt-get update报错&#xff1a;apt-get:找不到命令&#xff0c;八成是源配置文件/etc/apt/sources.list不存在。但是一般来说不会不存在&#xff0c;若真的不小心删除的话&#xff0c;我们也可以进行恢复。 首先创建/etc/apt/sources.list文件&#xff0c;然后…

安卓与串口通信-如何区分连接的设备?

前言与背景 一般来说&#xff0c;不管是在什么平台上需要与外接硬件交互&#xff0c;第一件事都是应该能够正确的识别出目标硬件。 例如在 Windows 上&#xff0c;当一个新的外设设备被插入到我们的电脑时&#xff0c;系统会通过 Hardware IDs 、Compatible IDs 来确定连接的…

看图学源码之 Atomic 类源码浅析二(cas + 分治思想的原子累加器)

原子累加器 相较于上一节看图学源码 之 Atomic 类源码浅析一&#xff08;cas 自旋操作的 AtomicXXX原子类&#xff09;说的的原子类&#xff0c;原子累加器的效率会更高 XXXXAdder 和 XXXAccumulator 区别就是 Adder只有add 方法&#xff0c;Accumulator是可以进行自定义运算方…

ufw常用命令解析

命令 举例 解释 ufw enable — 启用防火墙 ufw disable — 禁用防火墙 ufw status — 查看防火墙状态与规则 ufw default ARG sudo ufw default allow sudo ufw default deny 将默认策略设置为允许所有未明确规定的流量 将默认策略设置为拒绝所有未明确规定的流量…

大数据技术5:OLAP引擎对比分析

前言&#xff1a;数据仓库建设&#xff0c;初级的理解就是建表&#xff0c;将业务数据、日志数据、消息队列数据等&#xff0c;通过各种调度任务写入到表里供OLAP引擎使用。但要想建好数仓也是一个复杂、庞大的工程&#xff0c;比如要考虑&#xff1a;数据清洗、数据建模&#…

001 LLM大模型之Transformer 模型

参考《大规模语言模型--从理论到实践》 目录 一、综述 二、Transformer 模型 三、 嵌入表示层&#xff08;位置编码代码&#xff09; 一、综述 语言模型目标是建模自然语言的概率分布&#xff0c;在自然语言处理研究中具有重要的作用&#xff0c;是自然 语言处理基础任务之一…