Linux进程间通信——so共享库的使用学习笔记

共享库so的认识:
即使不同进程调用同一个so文件,通过共享库并不能实现不同进程间的通信,因为同一个so被不同进程加载到不同的内存空间。这类似windows下的dll动态库。

下面以一个实例来介绍linux下so共享库的使用方法:
1、实现一个so库文件名称为listupper.so,so文件中实现一个函数,函数名为void upper(const char *src, char *desc),调用update后将参数src所指向的字符串中所有字符转化为大写字母,结果放入desc字符串中。分别用C语言编写一个程序test1,调用libupper.so中的upper函数,用C++语言编写一个程序test2,调用libupper.so中的upper函数。

第一步:生成so共享库文件
1、so文件不要有main函数,即使有也不会被执行。
2、编译:gcc要加上-fPIC选项,这可以使gcc产生与位置无关的代码。
3、链接:gcc要加上-shared选项,指示生成共享库文件。
4、共享库文件名要以lib开头,扩展名为.so
编译出so文件还需要头文件,头文件包含各函数的申明。

.SUFFIXES: .c .o

CC=gcc

SRCS=upper.c

OBJS=$(SRCS:.c=.o)
EXEC=libupper.so

all: $(OBJS)
    $(CC) -shared -o $(EXEC) $(OBJS)
    @echo '-------------ok--------------'

.c.o: 
    $(CC) -Wall -g -fPIC -o $@ -c $<

clean:
    rm -f $(OBJS)
    rm -f core*

/* upper.h*/

#ifndef UPPER_H_
#define UPPER_H_

#ifdef __cplusplus
extern "C"
{
#endif

void upper(const char *src, char *desc);

#ifdef __cplusplus
}
#endif

#endif /* UPPER_H_ */
/* upper.c */

#include 
#include 
#include

void upper(const char *src, char *desc)
{
    if ((src==NULL)|(desc==NULL))
    {
        return;
    }
    int i=0;
    char buf[1024];
    memset(buf,0,sizeof(buf));
    strcpy(buf,src);
    int len=strlen(buf);
    while(buf[i]!='\0')
    {
        if((buf[i]>='a')&&(buf[i]<='z'))
        {
            buf[i]=buf[i]-('a'-'A');
        }
        i++;
    }
    strcpy(desc,buf);
    desc[len]='\0';
}

生成libupper.so
这里写图片描述

第二步:如何使用.so文件(配置环境)
1、cd 回到宿主目录
2、vi .bash_profile 修改.bash_profile文件
3、添加 export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:. 添加当前路径
4、. .bash_profile 重新运行bash_profile文件
5、链接:gcc -L. -lupper -o a a.o
其中-L.意思为在当前路径寻找so文件
-lupper 意思是链接libupper.so这个库文件

.SUFFIXES: .c .o

CC=g++

SRCS=test2.cpp

OBJS=$(SRCS:.cpp=.o)
EXEC=test2

all: $(OBJS)
    $(CC) -L. -lupper -o $(EXEC) $(OBJS)
    @echo '-------------ok--------------'

.c.o: 
    $(CC) -Wall -g -o $@ -c $<

clean:
    rm -f $(OBJS)
    rm -f core*

c语言版运行结果
这里写图片描述
cpp版运行结果
这里写图片描述

你可能感兴趣的:(linux进程间通信)