【C++】POCO学习总结(十三):类型和字节序、错误处理和调试、获取系统信息

本文主要是介绍【C++】POCO学习总结(十三):类型和字节序、错误处理和调试、获取系统信息,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【C++】郭老二博文之:C++目录

1、类型

POCO为固定大小的整数定义了类型
头文件:#include “Poco/Types.h”

  • Poco::Int8
  • Poco::Int16,
  • Poco::Int32,
  • Poco::Int64
  • Poco::UInt8
  • Poco::UInt16
  • Poco::UInt32
  • Poco::UInt64
  • Poco::IntPtr, Poco::UIntPtr:与指针大小相同的整数(32 or 64 bits)

2、long类型和指针类型

POCO有两个宏来确定long类型和指针类型的大小。
如果指针为64位,则有宏定义:POCO_PTR_IS_64_BIT,否则无
如果long为64位,则有宏定义:POCO_LONG_IS_64_BIT,否则无

3、Poco::ByteOrder 字节序

3.1 本机字节序

POCO使用宏来确定当前主机的字节顺序:

  • POCO_ARCH_LITTLE_ENDIAN:如果本机是小端序
  • POCO_ARCH_BIG_ENDIAN:如果本机是大端序

3.2 字节序转换

类Poco::ByteOrder提供了字节顺序转换的静态方法。
所有功能均可用于:Int16, UInt16, Int32, UInt32, Int64, UInt64

  • IntXX flipBytes(IntXX value):将字节顺序从大端改为小端,反之亦然
  • IntXX toBigEndian(IntXX value):将主机字节序转换为大端
  • IntXX toLittleEndian(IntXX value):将主机字节序转换为小端
  • IntXX fromBigEndian(IntXX value):从大端字节序转换为主机字节序
  • IntXX fromLittleEndian(IntXX value):将小端字节序转换为主机字节序
  • IntXX tonnetwork (IntXX值):将主机字节序转换为网络字节序
  • IntXX fromNetwork(IntXX value):将网络字节顺序转换为主机字节顺序
  • 网络字节顺序为大端

3.3 示例

vi ByteOrderTest.cpp

#include "Poco/ByteOrder.h"
#include <iostream>
using Poco::ByteOrder;
using Poco::UInt16;
int main(int argc, char** argv)
{#ifdef POCO_ARCH_LITTLE_ENDIANstd::cout << "little endian" << std::endl;#elsestd::cout << "big endian" << std::endl;#endifUInt16 port = 80;UInt16 networkPort = ByteOrder::toNetwork(port);return 0;
}

编译:

g++ ByteOrderTest.cpp -I ~/git/poco/install/include -L ~/git/poco/install/lib -lPocoFoundationd

输出:(大部分电脑都是小端)

little endian

4、Poco::Any 任意类型

4.1 说明

Poco::Any的实例可以保存任何内置或用户定义类型的值。
Poco: Any支持值语义。
该值可以通过类型安全的方式提取。
必须知道值的类型才能提取它。
Poco::AnyCast()和Poco::RefAnyCast()函数模板用于提取值。

4.2 示例

vi any.cpp

#include "Poco/Any.h"
#include "Poco/Exception.h"
#include <iostream>using Poco::Any;
using Poco::AnyCast;
using Poco::RefAnyCast;int main(int argc, char** argv)
{Any any(42);int i = AnyCast<int>(any); // okayint& ri = RefAnyCast<int>(any); // okaystd::cout << "i = " << i << "; ri = " << ri << std::endl;try{short s = AnyCast<short>(any); // throws BadCastException}catch (Poco::BadCastException&){std::cout << "BadCastException" << std::endl;}return 0;
}

编译:

g++ any.cpp -I ~/git/poco/install/include -L ~/git/poco/install/lib -lPocoFoundationd

输出:

i = 42; ri = 42
BadCastException

5、Poco::DynamicAny 动态任意类型

5.1 说明

头文件:#include “Poco/DynamicAny.h”
Poco::DynamicAny的实例可以保存动态任意类型的值。
Poco::DynamicAny支持值语义。
该值可以通过类型安全的方式提取。
支持各种类型(标准类型,std::string)的安全隐式和显式转换(检查范围)。

注意事项:(禁止数字值的数据丢失)

  • value < 0永远不会转换为unsigned类型
  • value需要x位,永远不会转换为更小的位范围(例如:value = 2000,需要16位,禁止转换为8位)
  • 允许从int到float再返回的精度损失
  • 允许字符串截断(字符串为单个字符)

5.2 示例

vi dany.cpp

#include "Poco/DynamicAny.h"
#include "Poco/Exception.h"
#include <iostream>
using Poco::DynamicAny;int main(int argc, char** argv)
{DynamicAny any(42);int i = any;std::string s(any.convert<std::string>());std::cout << "i = " << i << "; s = " << s << std::endl;any.convert(s); // or without the need to castconst int& ri(any.extract<int>());short ss = any;std::cout << "ri = " << ri << "; ss = " << ss << std::endl;try{short s = any.extract<short>(); // throws BadCastException}catch (Poco::BadCastException&){std::cout << "BadCastException" << std::endl;}return 0;
}

编译:

g++ dany.cpp -I ~/git/poco/install/include -L ~/git/poco/install/lib -lPocoFoundationd

输出:

i = 42; s = 42
ri = 42; ss = 42
BadCastException

6、异常

6.1 说明

所有POCO异常都是POCO::Exception的子类,Poco::Exception派生自std:: Exception。
头文件:#include “Poco/Exception.h”
比如:

  • Poco::LogicException :逻辑错误
  • Poco::RuntimeException:运行错误
  • Poco::ApplicationException:应用级错误

每个Poco::Exception都有一个name名字、message(描述异常的原因)、可选的嵌套异常

6.2 常用函数

  • const char* name() const :返回异常的名称
  • std::string& message() const:返回构造函数传递的消息文本
  • std::string displayText() const:返回名称和消息文本,以":"分隔
  • const Exception* nested() const:返回一个指向嵌套异常的指针,如果没有则返回0
  • Exception* clone() const:返回异常的精确副本
  • void rethrow() const:重新抛出异常

6.3 自定义异常

POCO_DECLARE_EXCEPTION:声明异常类
POCO_IMPLEMENT_EXCEPTION:实现异常类

// MyException.h
#include “Poco/Exception.h”
POCO_DECLARE_EXCEPTION(MyLib_API, MyException, Poco::Exception)

// MyException.cpp
#include “MyException.h”
POCO_IMPLEMENT_EXCEPTION(MyException, Poco::Exception, “Something really bad happened…”)

7、断言

运行时检查的宏

  • poco_assert(cond):如果cond≠true,抛出AssertionViolationException
  • poco_assert_dbg(cond):类似于poco_assert,但仅在调试版本中使用
  • poco_check_ptr(ptr):如果ptr为空,抛出NullPointerException
  • poco_bugcheck(), poco_bugcheck_msg(string):抛出BugcheckException

8、调试

1)在调试构建中,可以使用宏poco_debugger()和poco_debugger_msg(message)强制设置断点(如果代码在调试器的控制下运行)。
2)poco_assert、poco_check_ptr和poco_bugcheck在调试和发布版本中都是启用的。在调试版本中,如果调试器可用,则在抛出异常之前触发断点。
3)poco_assert_dbg和poco_debugger仅在调试版本中启用。
4)使用bool Debugger::isAvailable()检查是否在调试器下运行。
5)使用void Debugger::enter()强制一个断点。
6)使用void Debugger::message()将消息写入调试器日志或标准输出。

9、编译时获取系统信息

9.1 POCO_OS 平台相关的宏

头文件:Poco/Platform.h
POCO_OS宏可用于确定操作系统。它将有以下值之一:
POCO_OS_AIX
POCO_OS_LINUX
POCO_OS_SOLARIS
POCO_OS_CYGWIN
POCO_OS_MAC_OS_X
POCO_OS_TRU64
POCO_OS_FREE_BSD
POCO_OS_NET_BSD
POCO_OS_VMS
POCO_OS_HPUX
POCO_OS_OPEN_BSD
POCO_OS_VXWORKS
POCO_OS_IRIX
POCO_OS_QNX
POCO_OS_WINDOWS_NT

Windows平台:POCO_OS_FAMILY_WINDOWS
Unix平台:POCO_OS_FAMILY_UNIX

9.2 POCO_ARCH 硬件相关的宏

POCO_ARCH宏可用于确定硬件体系结构。它将有以下值之一:
POCO_ARCH_ALPHA
POCO_ARCH_IA64: Intel 64-bit
POCO_ARCH_AMD64
POCO_ARCH_MIPS
POCO_ARCH_ARM
POCO_ARCH_POWER
POCO_ARCH_HPPA
POCO_ARCH_PPC
POCO_ARCH_IA32 : Intel 32-bit
POCO_ARCH_SPARC

9.3 大小端

POCO_ARCH_LITTLE_ENDIAN:架构是小端序
POCO_ARCH_BIG_ENDIAN:架构是大端序

10、运行时的系统信息

Poco::Environment的静态函数,用于在运行时确定系统和环境信息。
头文件:#include “Poco/Environment.h”

  • std::string get(const Std::string& name):返回环境变量的值,如果变量未定义,抛出Poco::NotFoundException。
  • bool has(const std::string& name):检查是否定义了环境变量。
  • void set(const std::string& name, const std::string& value):设置环境变量的值。
  • std:: string osName ():返回操作系统的名称(uname)。
  • std::string osVersion():返回操作系统的版本(uname -r)。
  • std::string osArchitecture():返回描述硬件架构的字符串(uname -m)。
  • std::string nodeName():返回计算机名(uname -n)。类似Poco::DNS::hostName()
  • std:: string nodeId ():返回在系统上找到的第一个以太网适配器的以太网地址,格式为xx:xx:xx:xx:xx(如果没有以太网适配器,则返回全零)。
#include "Poco/Environment.h"
#include <iostream>
using Poco::Environment;
int main(int argc, char** argv)
{std::cout << "OS Name: " << Environment::osName() << std::endl<< "OS Version: " << Environment::osVersion() << std::endl<< "OS Arch: " << Environment::osArchitecture() << std::endl<< "Node Name: " << Environment::nodeName() << std::endl<< "Node ID: " << Environment::nodeId() << std::endl;if (Environment::has("HOME"))std::cout << "Home: " << Environment::get("HOME") << std::endl;Environment::set("POCO", "foo");return 0;
}

编译:

g++ e.cpp -I ~/git/poco/install/include -L ~/git/poco/install/lib -lPocoFoundationd

输出:

OS Name: Linux
OS Version: 6.2.0-37-generic
OS Arch: x86_64
Node Name: laoer-VirtualBox
Node ID: 08:00:27:ad:b1:7a
Home: /home/laoer

这篇关于【C++】POCO学习总结(十三):类型和字节序、错误处理和调试、获取系统信息的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++右移运算符的一个小坑及解决

《C++右移运算符的一个小坑及解决》文章指出右移运算符处理负数时左侧补1导致死循环,与除法行为不同,强调需注意补码机制以正确统计二进制1的个数... 目录我遇到了这么一个www.chinasem.cn函数由此可以看到也很好理解总结我遇到了这么一个函数template<typename T>unsigned

Java实现字节字符转bcd编码

《Java实现字节字符转bcd编码》BCD是一种将十进制数字编码为二进制的表示方式,常用于数字显示和存储,本文将介绍如何在Java中实现字节字符转BCD码的过程,需要的小伙伴可以了解下... 目录前言BCD码是什么Java实现字节转bcd编码方法补充总结前言BCD码(Binary-Coded Decima

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

Spring 依赖注入与循环依赖总结

《Spring依赖注入与循环依赖总结》这篇文章给大家介绍Spring依赖注入与循环依赖总结篇,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Spring 三级缓存解决循环依赖1. 创建UserService原始对象2. 将原始对象包装成工

Python中Json和其他类型相互转换的实现示例

《Python中Json和其他类型相互转换的实现示例》本文介绍了在Python中使用json模块实现json数据与dict、object之间的高效转换,包括loads(),load(),dumps()... 项目中经常会用到json格式转为object对象、dict字典格式等。在此做个记录,方便后续用到该方

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom