ubuntu22.04安装使用 protobuf 23.3静态库

2024-02-13 10:20

本文主要是介绍ubuntu22.04安装使用 protobuf 23.3静态库,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

https://github.com/protocolbuffers/protobuf/

下载最新的release版本,23.3

必须需要依赖的第三方库 abseil,utf8_range

mkdir build

cd build

cmake -DCMAKE_BUILD_TYPE=DEBUG  -DCMAKE_INSTALL_PREFIX=/usr/local -Dprotobuf_BUILD_SHARED_LIBS=OFF -Dprotobuf_WITH_ZLIB=OFF -Dprotobuf_BUILD_TESTS=OFF ..

make

sudo make install

或直接修改CmakeList.txt 添加/修改以下内容

set(protobuf_VERBOSE ON) #debug信息
set(protobuf_BUILD_TESTS  OFF)#不编译test
set(protobuf_WITH_ZLIB  OFF)  #不使用zlib
set(protobuf_WITH_ZLIB_DEFAULT OFF)#不使用zlib
set(protobuf_BUILD_SHARED_LIBS  OFF)#静态库
set(protobuf_BUILD_SHARED_LIBS_DEFAULT  OFF)#静态库
set(CMAKE_INSTALL_PREFIX /usr/local)#安装路径

如果要建立动态库,依赖的abseil 最好也是动态库.

安装后使用的方法,在target_link_libraries里,需要先写protobuf,然后rtf8_range,最后才是absl。 顺序不可以改变,因为protobuf要依赖后两个,rtf8_range要依赖absl

目录结构

 cmakeList.txt

absl把所有的都一起贴上了

cmake_minimum_required(VERSION 3.19)
project(protobut_demo)set(CMAKE_CXX_STANDARD 17)include_directories(/usr/local/include)
#------------------------------------------------------------------
find_package(Protobuf REQUIRED)
include_directories(${Protobuf_INCLUDE_DIRS})
#${Protobuf_LIBRARIES}
#检查是否有值
MESSAGE("Protobuf lib path :" ${Protobuf_LIBRARIES})
MESSAGE("Protobuf include path:" ${Protobuf_INCLUDE_DIRS})
MESSAGE("Protobuf exetuable path:" ${PROTOBUF_PROTOC_EXECUTABLE})# proto源文件位置
SET(PROTO_SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/proto)# proto 文件生成位置,包含.pb.cc 和 .pb.h
SET(PROTO_OUTPUT_DIR ${CMAKE_CURRENT_SOURCE_DIR}/proto_output)# proto 文件
file(GLOB proto_files${CMAKE_CURRENT_SOURCE_DIR}/proto/*.proto)
# 生成文件
FOREACH(PROTO_FILE ${proto_files})EXECUTE_PROCESS(COMMAND ${PROTOBUF_PROTOC_EXECUTABLE} -I${PROTO_SOURCE_DIR} --cpp_out=${PROTO_OUTPUT_DIR} ${PROTO_FILE})
ENDFOREACH()
#---------------------------------------------------------------------------------------------
include_directories(${PROTO_OUTPUT_DIR})#生成的头文件路径# 将proto生成的.pb.cc 和 .pb.h分类file(GLOB contacts_All${PROTO_OUTPUT_DIR}/*.pb.h${PROTO_OUTPUT_DIR}/*.pb.cc)
find_package(absl)
find_package(utf8_range)add_executable(proto_test src/proto_test.cpp ${contacts_All})
target_link_libraries(proto_test${Protobuf_LIBRARIES}/usr/local/lib/libutf8_range.a/usr/local/lib/libutf8_validity.aabsl::bad_any_cast_implabsl::bad_optional_accessabsl::bad_variant_accessabsl::baseabsl::cityabsl::civil_timeabsl::cordabsl::cord_internalabsl::cordz_functionsabsl::cordz_handleabsl::cordz_infoabsl::cordz_sample_tokenabsl::crc32cabsl::crc_cord_stateabsl::crc_cpu_detectabsl::crc_internalabsl::debugging_internalabsl::demangle_internalabsl::die_if_nullabsl::examine_stackabsl::exponential_biasedabsl::failure_signal_handlerabsl::flagsabsl::flags_commandlineflagabsl::flags_commandlineflag_internalabsl::flags_configabsl::flags_internalabsl::flags_marshallingabsl::flags_parseabsl::flags_private_handle_accessorabsl::flags_program_nameabsl::flags_reflectionabsl::flags_usageabsl::flags_usage_internalabsl::graphcycles_internalabsl::hashabsl::hashtablez_samplerabsl::int128absl::kernel_timeout_internalabsl::leak_checkabsl::log_entryabsl::log_flagsabsl::log_globalsabsl::log_initializeabsl::log_internal_check_opabsl::log_internal_conditionsabsl::log_internal_formatabsl::log_internal_globalsabsl::log_internal_log_sink_setabsl::log_internal_messageabsl::log_internal_nullguardabsl::log_internal_protoabsl::log_severityabsl::log_sinkabsl::low_level_hashabsl::malloc_internalabsl::periodic_samplerabsl::random_distributionsabsl::random_internal_distribution_test_utilabsl::random_internal_platformabsl::random_internal_pool_urbgabsl::random_internal_randenabsl::random_internal_randen_hwaesabsl::random_internal_randen_hwaes_implabsl::random_internal_randen_slowabsl::random_internal_seed_materialabsl::random_seed_gen_exceptionabsl::random_seed_sequencesabsl::raw_hash_setabsl::raw_logging_internalabsl::scoped_set_envabsl::spinlock_waitabsl::stacktraceabsl::statusabsl::statusorabsl::strerrorabsl::str_format_internalabsl::stringsabsl::strings_internalabsl::symbolizeabsl::synchronizationabsl::throw_delegateabsl::timeabsl::time_zone)

student.proto

syntax = "proto3";
package student;// 定义联系人message
message StudentInfo {string name = 1;bool isMale = 2;int32 age = 3;
}

student.pb.cc和student.pb.h 是用cmake生成的

proto_test.cpp

#include <iostream>
#include "student.pb.h"#include <google/protobuf/compiler/plugin.h>int main(int argc,char** argv) {std::string data_str;{
//         使⽤ PB 进⾏序列化,并将结果打印出来。student::StudentInfo _student;_student.set_name("小豪豪");_student.set_ismale(true);_student.set_age(20);if (!_student.SerializeToString(&data_str)) {std::cerr << "序列化_student失败!" << std::endl;return -1;}std::cout << "序列化_student成功,结果:" << data_str << std::endl;}{// 使⽤ PB 进⾏反序列,解析出联系⼈信息并打印出来。student::StudentInfo _student;if (!_student.ParseFromString(data_str)) {std::cerr << "反序列化失败!" << std::endl;return -1;}std::cout << "反序列化成功!" << std::endl;std::cout << "name:" << _student.name() << std::endl;std::cout << "ismale:" << _student.ismale() << std::endl;std::cout << "age:" << _student.age() << std::endl;}return 0;
} //
// Created by hao on 2023/6/26.
//

这篇关于ubuntu22.04安装使用 protobuf 23.3静态库的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

Centos7安装Mongodb4

1、下载源码包 curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-4.2.1.tgz 2、解压 放到 /usr/local/ 目录下 tar -zxvf mongodb-linux-x86_64-rhel70-4.2.1.tgzmv mongodb-linux-x86_64-rhel70-4.2.1/

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

Centos7安装JDK1.8保姆版

工欲善其事,必先利其器。这句话同样适用于学习Java编程。在开始Java的学习旅程之前,我们必须首先配置好适合的开发环境。 通过事先准备好这些工具和配置,我们可以避免在学习过程中遇到因环境问题导致的代码异常或错误。一个稳定、高效的开发环境能够让我们更加专注于代码的学习和编写,提升学习效率,减少不必要的困扰和挫折感。因此,在学习Java之初,投入一些时间和精力来配置好开发环境是非常值得的。这将为我

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma