【Socket网络编程】传参时char* 类型转 unsigned short 类型和 const char *类型

【Socket网络编程】传参时char* 类型转 unsigned short 类型和 const char *类型

一、问题

Linux操作系统下,实现客户端向服务器端发消息的过程,为了方便的快速构建一个客户端,会把客户端写成一个函数。函数需要传递的参数有三种:无符号短型的端口,常量字符型指针的服务器IP号以及需要传递的字符类型的数组。

为了不在程序里就把服务器的IP和端口号写死了,Linux g++编译代码之后我们可以手动传参给可执行文件的main接口。可以实现手动输入的目标服务器socket建立通信。
但是在定义mian函数传参的时候,传递的参数为字符指针数组char * argv[],这时候就会涉及到char* 类型转 unsigned short 类型和 const char *类型。

二、解决

需要传递的参数有port和server_ip,而send_buf[]是在调用客户端程序之前就写好了的可以先不用管。
在这里聚焦于argv的类型到port的类型和server_ip的类型的转换。

  int main(int argc, char *argv[])
 void clientmain(unsigned short port, const char *server_ip,char send_buf[])

通过下面的代码就可以看到转换的一个过程。

//test.cpp
#include <stdio.h>
#include <stdlib.h>
#include <string.h>						
#include <unistd.h>
#include<typeinfo>
#include<sstream>
#include <iostream>
using namespace std;

int main(int argc, char *argv[])	//用于传参的主函数
{
	//cout<<argv[0]<<endl;	//显示argv[0]的值
	
	//记录了参数port的值
	char* unsignedshorttemp = argv[1];	
	cout<<typeid(unsignedshorttemp).name()<<" -unsignedshorttemp- "<<unsignedshorttemp<<endl;	//显示当前port的类型和值
	
	//char *类型向unsigned short类型的转换
	//实现方式1,直接atoi之后赋值
	unsigned short port1 = atoi(unsignedshorttemp);
	cout<<typeid(port1).name()<<" -port1- "<<port1<<endl;	//显示当前port1的类型和值
	
	//实现方式2,char *转成string,string转char* ,char* 转 unsigned short
	//绕了一圈又到实现方式1,但是这个过程可以看到char *转成string,string转char*的实现。
	//char *类型转成string类型
	string str;
	stringstream stream;
	stream << unsignedshorttemp;
	str = stream.str();
	//string类型转char*类型,char* a = (char*)str.c_str();
	unsigned short port2 ;
	port2 = atoi((char*)str.c_str());	//char *类型转unsigned short类型
	cout<<typeid(port2).name()<<"-port2-"<<port2<<endl;	//显示当前port2的类型和值
	
	//记录了参数server_ip的类型
	char* constchartemp = argv[2];	
	cout<<typeid(constchartemp).name()<<" -constchartemp- "<<constchartemp<<endl;	//显示当前server_ip的类型和值
	
	//char *类型向const char*类型的转换
	//实现方法1,间接赋值
	const char* server_ip1;
	server_ip1=constchartemp;
	cout<<typeid(server_ip1).name()<<" -server_ip1- "<<server_ip1<<endl;	//显示当前server_ip1的类型和值
	//实现方法2,直接赋值
	const char* server_ip2=constchartemp;
	cout<<typeid(server_ip2).name()<<" -server_ip2- "<<server_ip2<<endl;	//显示当前server_ip2的类型和值
}

上述代码首先进行编译:

g++ test.cpp -o test

传参运行的命令行:

./test 8017 10.2.25.137

Linux将命令行参数传递给main函数

回忆一下main函数的定义:

int main(int argc, char *argv[])

在这里通过main函数穿的参数为8017和10.2.25.137这两个数据。而这两个值的位置对应的在argv[1]和argv[2]上。argv[0]为./test,可以把第一行的注释取消看到。
传参会把命令行的输入按照空格隔开来存入argv[]数组中,argc对应的值为argv[]数组的元素个数。比如在上面的传参命令中,操作系统为main传递的参数 argc 值为3。

三、typeid().name() 返回值

typeid(变量名).name() 是可以查看当前变量的类型。
有的编译器需要加上typeid的头文件:

#include<typeinfo>	//typeid需要的头文件

上述程序输出的运行结果每行的开头都会出现 typeid(变量名).name() 的返回值,这个返回值就是变量的类型表示形式。

返回值的输出格式为: [指针][名称空间][类型][模板]
[指针]:若是指针则输出P,const 指针为PK。
[名称空间]:若是std则输出St,若是自定义的名称空间则输出字符数及它的名字,并在开头加N,在结尾加E。
[类型]:若是自定义的名称空间则输出字符数及它的名字,若内建类型输出如下:

类型 返回值
bool b
char c
signed char a
unsigned char h
(signed) short (int) s
unsigned short (int) t
(signed) (int) i
unsigned (int) j
(signed) long (int) l
unsigned long (int) m
(signed) long long (int) x
unsigned long long (int) y
float f
double d
long double e

[模板] :类型模板以I开头,以E结尾;常数模板以L开头,以E结尾。只有整型变量(int、char之类的)才能做为常数模板,浮点数不行。

具体参考链接: typeid().name() 返回值

四、运行结果

运行结果如下图:
在这里插入图片描述
从运行结果可以看到:
unsignedshorttemp 为 char* 类型的变量(Pc);
port1和port2为unsigned short类型的变量(t);
constchartemp 为 char* 类型的变量(Pc);
server_ip1和server_ip2为const char*类型的变量(PKc);

通过上述代码可以实现char型向unsigned short类型的转换,char类型向const char*类型的转换。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章