Puerto C++ de la famosa biblioteca de redes LiteNetLib escrita en C#
A partir de ahora, la biblioteca se puede crear con MSVC en Windows y con GCC en Linux. La compatibilidad con OS X está prevista en futuras versiones.
Para crear y ejecutar un proyecto de ejemplo, utilice los siguientes comandos en Powershell para Windows:
git clone [email protected]:Revan600/LiteNetLibPP.git
cd LiteNetLibPP
mkdir build
cd build
cmake ../
cmake --build .
.Debuglnl_example_server.exe
.Debuglnl_example_client.exe
O en bash para Linux:
git clone [email protected]:Revan600/LiteNetLibPP.git
cd LiteNetLibPP
mkdir build
cd build
cmake ../
make
./lnl_example_server
./lnl_example_client
Después de eso, debería poder conectarse al servidor de prueba a través de localhost:4499 (o mediante su IP pública)
Todas las funciones de LiteNetLib implementadas excepto aquellas:
Un ping-pong simple con 1000 clientes (evaluación del servidor): No se observaron caídas de paquetes o conexiones durante las pruebas (pero estoy seguro de que habrá algunos errores, así que no dudes en solucionar el problema)
A continuación se muestra un ejemplo sencillo de cliente y servidor que se utilizó en las pruebas de rendimiento. Se pueden encontrar más ejemplos aquí.
# include < lnl/lnl.h >
class my_listener : public lnl ::net_event_listener {
public:
void on_network_receive (std::shared_ptr<lnl::net_peer>& peer, lnl::net_data_reader& reader, uint8_t channelNumber,
lnl::DELIVERY_METHOD deliveryMethod) override {
static lnl::net_data_writer writer;
int32_t value;
if (!reader. try_read (value)) {
printf ( " cannot read value n " );
return ;
}
writer. reset ();
value++;
writer. write (value);
peer-> send (writer, lnl::DELIVERY_METHOD::RELIABLE_ORDERED);
}
void on_connection_request (std::shared_ptr<lnl::net_connection_request>& request) override {
request-> accept ();
}
};
int main () {
lnl::initialize ();
my_listener listener;
lnl::net_manager server (&listener);
server. start ( 4499 );
while (server. is_running ()) {
server. poll_events ();
}
return 0 ;
}
# include < lnl/lnl.h >
class my_listener : public lnl ::net_event_listener {
public:
void on_network_receive (std::shared_ptr<lnl::net_peer>& peer, lnl::net_data_reader& reader, uint8_t channelNumber,
lnl::DELIVERY_METHOD deliveryMethod) override {
static lnl::net_data_writer writer;
int32_t value;
if (!reader. try_read (value)) {
printf ( " cannot read value n " );
return ;
}
writer. reset ();
printf ( " %i n " , value);
value++;
writer. write (value);
peer-> send (writer, lnl::DELIVERY_METHOD::RELIABLE_ORDERED);
}
void on_connection_request (std::shared_ptr<lnl::net_connection_request>& request) override {
request-> accept ();
}
};
int main () {
lnl::initialize ();
my_listener listener;
lnl::net_manager client (&listener);
lnl::net_address address ( " localhost " , 4499 );
lnl::net_data_writer writer;
client. start ();
client. connect (address, writer);
while (client. is_running ()) {
client. poll_events ();
}
return 0 ;
}