AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / coding / 问题

All perguntas(coding)

Martin Hope
Adrian McCarthy
Asked: 2025-04-20 09:02:47 +0800 CST

O vinculador remove globais (e seus construtores) da biblioteca estática

  • 7

Tenho um registro singleton que mapeia nomes para ponteiros de função. Também tenho um objeto registrador cujo construtor registra um ponteiro de função.

Meu objetivo é ter as funções e o registro em uma biblioteca estática, mas descobri que o vinculador omite os registros quando construído dessa forma.

Aqui está uma ilustração simplificada. Para resumir, substituí os ponteiros de função por ponteiros para inteiros globais e o contêiner associativo do registro por um vetor.

// registry.h
#include <vector>
std::vector<int const *> &GetRegistry();
// registry.cpp
#include "registry.h"

std::vector<int const *> &GetRegistry() {
    static std::vector<int const *> registry;
    return registry;
}
// thingadder.h
#include "registry.h"

class ThingAdder {
    public:
        explicit ThingAdder(int const *thing) {
            GetRegistry().push_back(thing);
        }
};
// things.cpp
#include "thingadder.h"

int g_thing1 = 1;
ThingAdder g_adder1(&g_thing1);
// main.cpp
#include "registry.h"
#include <print>
#include <vector>

int main() {
    std::print("registry size: {}\n", GetRegistry().size());
    return 0;
}

Se todos os arquivos forem compilados e vinculados como um único projeto, g_adder1o construtor de adiciona g_global1o endereço de ao registro, e o programa informa que o tamanho do registro é 1.

Mas quando tudo, exceto main.cpp, é criado em uma biblioteca estática, e então main.cpp é compilado e vinculado a essa biblioteca, o tamanho do registro relatado é 0. Parece que os globais em things.cpp foram omitidos pelo link.

Eu meio que entendo por que isso está acontecendo: nada fora de things.cpp faz referência direta ao objeto global nem ao seu registrador. Mas isso é verdade mesmo quando construído como um monolito. Eu não esperaria que incluir essa parte em uma biblioteca estática mudasse o comportamento.

Soluções?

A única solução que encontrei foi fazer com que main.cpp faça referência a um símbolo definido na unidade de tradução things.cpp. Na biblioteca em si, haverá mais arquivos de objetos a serem registrados, e não quero que cada usuário da biblioteca adicione uma referência a um símbolo para cada um deles.

c++
  • 1 respostas
  • 86 Views
Martin Hope
chris11jed
Asked: 2025-04-20 07:47:25 +0800 CST

Recebi um erro System.Management.Managementexception: 'Consulta inválida' ao tentar obter descritores de porta COM no Visual Studio 2022

  • 7

Usando o Visual Studio 2022 Community no Windows 10, seguindo um tutorial em C# no qual um projeto "Aplicativo Windows Forms (.NET Framework)" lista todas as portas COM e suas descrições, como seriam vistas/encontradas no Gerenciador de Dispositivos do Windows. Gerenciador de Dispositivos - Portas (COM e LPT)

No aplicativo de formulários, há uma caixa de texto que exibe a lista de portas COM e suas descrições quando iniciada. E também um botão para sair do programa.

Quando eu construo e inicio o depurador, um erro é gerado no Visual Studio específico para esta linha de código (a parte que reúne as descrições da porta COM):

var ports = searcher.Get()
                    .Cast<ManagementBaseObject>()
                    .ToList()
                    .Select(p => p["Caption"].ToString());

O erro mostrado é este:

Exceção não tratada: System.Management.ManagementException: 'Consulta inválida'

Não sei por que esse erro é gerado, pois o código é o que está no tutorial.

Além disso, não sei como diagnosticar e corrigir o problema.

Este é o código do tutorial:

using System;
using System.Collections.Generic;
using System.Data;
using System.IO.Ports;
using System.Linq;
using System.Management;
using System.Windows.Forms;

namespace Device_Manager_COMS_searcher
{
    public partial class Form1 : Form
    {
        List<string> portnames = new List<string>();

        public Form1()
        {
            InitializeComponent();

            portnames = GetPorts();

            foreach (string port in portnames)
            {
                textBox1.AppendText(port + "\r\n");
            }
        }

        public List<string> GetPorts()
        {
            // This searches all the properties of the Plug and Play devices
            // (using "Win32_PnPEntity"). The "caption" is the text description of
            // the COM port object.

            // Search all Plug n Play entities where the Caption has "(COM" plus
            // any number of leading and lagging characters.
            using (var searcher = new ManagementObjectSearcher("SELECT * FROM" + "Win32_PnpEntity WHERE Caption like '%(COM%'"))
            {
                // This gets the simple port names, such as "COM4"
                string[] portnames = SerialPort.GetPortNames();

                // This gets the caption/description of the found ports 
                // Throws the error: System.Management.Managementexception: 'invalid query'
                var ports = searcher.Get().Cast<ManagementBaseObject>().ToList().Select(p => p["Caption"].ToString());

                // Append the description of each port to the corresponding port name
                // and add to the list
                List<string> portList = portnames.Select(n => n + " - " + ports.FirstOrDefault(s => s.Contains(n))).ToList();
                
                return portList;
            }
        }

        private void button1_Click(object sender, EventArgs e)
        {
            Application.Exit();
        }
    }
}

No Visual Studio, adicionei a referência System.Managementpor meio do Gerenciador de Referências.

Também tentei adicionar a mesma referência via NuGet, mas ambos não corrigiram o problema.

Por motivos de segurança, eu queria ver se o programa/aplicativo conseguiria iniciar e encontrar as portas COM sem as descrições. Então, alterei o design do formulário para adicionar mais um botão, "OBTER COMS", que, ao ser clicado, buscaria apenas as portas COM e seus números, mas não a descrição.

Assim:

using System;
using System.Collections.Generic;
using System.Data;
using System.IO.Ports;
using System.Linq;
using System.Management;
using System.Windows.Forms;

namespace Device_Manager_COMS_searcher
{
    public partial class Form1 : Form
    {
        List<string> portnames = new List<string>();

        public Form1()
        {
            InitializeComponent();
        }

        public List<string> GetPorts()
        {
            // This searches all the properties of the Plug and Play devices
            // (using "Win32_PnPEntity"). The "caption" is the text description of
            // the COM port object.

            // Search all Plug n Play entities where the Caption has "(COM" plus
            // any number of leading and lagging characters.
            using (var searcher = new ManagementObjectSearcher("SELECT * FROM" + "Win32_PnpEntity WHERE Caption like '%(COM%'"))
            {
                // This gets the simple port names, such as "COM4"
                string[] portnames = SerialPort.GetPortNames();

                // Append the description of each port to the corresponding port name
                // and add to the list
                List<string> portList = portnames.Select(n => n).ToList();
                
                return portList;
            }
        }

        private void button1_Click(object sender, EventArgs e)
        {
            Application.Exit();
        }

        private void button2_Click(object sender, EventArgs e)
        {
            portnames = GetPorts();
            foreach (string port in portnames)
            {
                textBox1.AppendText(port + "\r\n");
            }
        }
    }
}

Depois de compilado e iniciado, o depurador funciona. Clico no botão "GET COMS" e ele exibe as portas COM com os itens conectados, assim:

Exemplo prático menos descritores para portas COM

Mas, novamente, se eu alterar o código para a GetPorts()seção que adiciona um descritor, assim:

public List<string> GetPorts()
{
    // This searches all the properties of the Plug and Play devices
    // (using "Win32_PnPEntity"). The "caption" is the text description of
    // the COM port object.

    // Search all Plug n Play entities where the Caption has "(COM" plus
    // any number of leading and lagging characters.
    using (var searcher = new ManagementObjectSearcher("SELECT * FROM" + "Win32_PnpEntity WHERE Caption like '%(COM%'"))
    {
        // This gets the simple port names, such as "COM4"
        string[] portnames = SerialPort.GetPortNames();

        // This gets the caption/description of the found ports 
        // Throws error: System.Management.Managementexception: 'invalid query'
        var ports = searcher.Get().Cast<ManagementBaseObject>().ToList().Select(p => p["Caption"].ToString());

        // Append the description of each port to the corresponding port name
        // and add to the list
        List<string> portList = portnames.Select(n => n + " - " + ports.FirstOrDefault(s => s.Contains(n))).ToList();
        
        return portList;
    }
}

Entendi o erro.

Precisa de ajuda para consertar isso, por favor

c#
  • 1 respostas
  • 58 Views
Martin Hope
Lusiiky
Asked: 2025-04-20 07:36:16 +0800 CST

Como faço para reorientar um script do Powershell após um Start-Process?

  • 6

Tenho um script Pwsh com um menu que executa diversas operações diferentes para me ajudar no dia a dia.

Para uma das operações, eu inicio um processo com Start-Process, exceto que ele focaliza a janela iniciada, mas para facilitar eu gostaria que o script fosse focalizado novamente após o lançamento e não o processo iniciado.

Não quero usar os argumentos “PassThru” ou “NoNewWindow” porque não quero que o processo iniciado seja iniciado no script, nem “WindowStyle” com Minimized porque isso focaliza o processo iniciado de qualquer maneira, nem Hidden porque ainda preciso ver a janela do processo em algum lugar.

Eu tentei esse método que parece funcionar melhor:

Start-Process -FilePath "MyProcessPath"

Start-Sleep -Seconds 1

Add-Type @"
using System;
using System.Runtime.InteropServices;
public class WinAp {
 [DllImport("user32.dll")]
 [return: MarshalAs(UnmanagedType.Bool)]
 public static extern bool SetForegroundWindow(IntPtr hWnd);

 [DllImport("user32.dll")]
 [return: MarshalAs(UnmanagedType.Bool)]
 public static extern bool ShowWindow(IntPtr hWnd, int nCmdShow);
}
"@

$p = Get-Process | Where-Object { $_.MainWindowTitle -like "*ScriptTitle*" -and $_.ProcessName -eq "powershell" }

$h = $p.MainWindowHandle
[void] [WinAp]::SetForegroundWindow($h)
[void] [WinAp]::ShowWindow($h, 1)

Mas, infelizmente, não funciona. Parece que faz alguma coisa na janela, pois ela pisca na barra de tarefas, mas não foca. Parece que, embora o script seja executado como administrador, ele não funciona para focar uma janela de administrador como essa?

Entretanto, para outra parte do meu script, fiz isso:

$tempPath = [System.IO.Path]::GetTempFileName().Replace(".tmp", ".vbs")
$code = @'
Set WshShell = WScript.CreateObject("WScript.Shell")
WshShell.AppActivate "App.exe"
WScript.Sleep 250
WshShell.SendKeys "{ENTER}"
'@

$code | Out-File $tempPath -Encoding ASCII
Start-Process "wscript.exe" $tempPath -Wait
Remove-Item $tempPath

E funciona bem... ele foca a janela e, em seguida, pressiona a tecla solicitada (embora essa parte não seja necessária no meu problema atual). Tentei com o meu script, mas... nada. Principalmente porque o aplicativo é iniciado com o script, então como administrador também, eu acho? Então, não entendo por que funciona, mas não para o script em si.

Obrigado!

powershell
  • 3 respostas
  • 113 Views
Martin Hope
Дима Ощепков
Asked: 2025-04-20 06:46:16 +0800 CST

Por que os pacotes não são instalados na minha compilação do Docker de vários estágios usando pip?

  • 8

Estou trabalhando em um projeto Python com uma compilação Docker de vários estágios e estou tendo um problema em que o pydantic (apenas um exemplo) não está instalado, embora o pip esteja presente e funcionando na imagem final.

Aqui está a estrutura do meu projeto:

project-root/
├── docker-compose.yml
├── vector_db_service/
│   ├── app/
│   │   └── __init__.py
│   ├── Dockerfile
│   ├── pyproject.toml
│   ├── .env

docker-compose.yml:

services:
  vector_db_service:
    container_name: vector_db_service
    build:
      context: ./vector_db_service
      dockerfile: Dockerfile
    command: tail -f /dev/null
    env_file:
      - ./vector_db_service/.env

Arquivo Docker:

# Build stage
FROM python:3.13-slim AS compile-image

RUN python -m venv /opt/venv
ENV PATH="/opt/venv/bin:$PATH"

RUN pip install --no-cache-dir --upgrade pip

# Final image
FROM python:3.13-slim

COPY --from=compile-image /opt/venv /opt/venv

WORKDIR /app
ENV HOME=/app
ENV PATH="/opt/venv/bin:$PATH"

RUN addgroup --system app && adduser --system --group app

COPY . .

RUN chown -R app:app $HOME
RUN chown -R app:app "/opt/venv/"

USER app

RUN pip install -e pydantic

A última linha, RUN pip install -e pydantic, não instala nada. A compilação é concluída com sucesso, mas o pacote não é instalado. Confirmei que o pip está instalado na imagem final.

Tentei outras variações como RUN pip install pydantic ou RUN pip install -e ., mas elas não alteraram o resultado.

Meu pyproject.toml lista o pydantic como uma dependência. Preciso instalar a partir da raiz do projeto ou estou esquecendo de algo no processo de compilação?

Qualquer ajuda será muito apreciada. Agradeço desde já!

python
  • 3 respostas
  • 83 Views
Martin Hope
nickC
Asked: 2025-04-20 06:26:57 +0800 CST

Encontre a diferença de dias entre duas datas do Reino Unido no formulário de usuário VBA

  • 8

Essas datas são produzidas pelo calendário de Trevor Eyre no formato dos EUA, então converti para o Reino Unido para meus usuários. No entanto, acho que é por isso que não consigo encontrar a diferença de data, já que não é mais um número. Existe uma maneira?

Private Sub TextBox6_Enter()
'CALENDAR arrival date
    Dim dateVariable As Date
    dateVariable = CalendarForm.GetDate
    Dim sDate As String 'changes format from USA for UK users
    sDate = Format(dateVariable, "dd-mmm-yy")
    TextBox6.value = sDate
End Sub
Private Sub TextBox7_Enter()
'CALENDAR date leave
    Dim dateVariable As Date
    dateVariable = CalendarForm.GetDate
    Dim sDate As String
'changes format from USA to UK
    sDate = Format(dateVariable, "dd-mmm-yy")
    TextBox7.value = sDate
End Sub
  Private Sub TextBox20_change()
'Number of NIGHTS
     TextBox20.value = DateDiff("d", DateValue(TextBox6.value), TextBox7.value)
End Sub

Depois de vários dias, percebi que sDate estava repetido nas caixas de texto 6 e 7. Com 77, meu cérebro está confuso. Agora funciona perfeitamente. Obrigado `Private Sub TextBox6_Enter() ' CALENDAR data de chegada

Dim dateVariable As Date
dateVariable = CalendarForm.GetDate
TextBox6.value = dateVariable

sDate = Format(dateVariable, "dd/mm/aaaa") 'muda o formato dos EUA para o Reino Unido TextBox6.value = sDate 'entrada na caixa de texto End Sub

Private Sub TextBox7_Enter() 'Data de saída do CALENDÁRIO

Dim dateVariable As Date
dateVariable = CalendarForm.GetDate
TextBox7.value = dateVariable

tDate = Format(dateVariable, "dd/mm/aaaa") 'altera o formato dos EUA para o Reino Unido TextBox7.value = tDate

TextBox20.Text = DateDiff("d", TextBox6.value, TextBox7.value) Fim do Sub```

vba
  • 3 respostas
  • 73 Views
Martin Hope
mysynaje_navucannie
Asked: 2025-04-20 05:31:54 +0800 CST

O servidor Python MCP com transporte STDIO lança um 'Erro: conexão SSE não estabelecida' ao tentar conectar via MCP Inspector

  • 5

Estou tentando executar um exemplo do repositório oficial do Model Context Protocol para Python ( https://github.com/modelcontextprotocol/python-sdk ). Mas ele continua me dando Error in /message route: Error: SSE connection not established"erro quando clico no botão "Conectar" na página do Inspetor MCP. O problema é que nem estou tentando usar a conexão SSE, então estou realmente confuso com o erro e os logs.

Aqui está o código (localizado na pasta src/) :

# server.py
from mcp.server.fastmcp import FastMCP

# Create an MCP server
mcp = FastMCP("Demo")


# Add an addition tool
@mcp.tool()
def add(a: int, b: int) -> int:
    """Add two numbers"""
    return a + b


# Add a dynamic greeting resource
@mcp.resource("greeting://{name}")
def get_greeting(name: str) -> str:
    """Get a personalized greeting"""
    return f"Hello, {name}!"

Foi assim que preparei o projeto : inicializei uvo ambiente virtual na pasta raiz. Instalei as dependências do projeto com uv add "mcp[cli]", como indicado no guia do repositório. Informações sobre as versões do programa:

  • Node.js v22.14.0
  • [email protected]
  • C:\Usuários...\AppData\Roaming\npm ├── @modelcontextprotocol/ [email protected] ├── @modelcontextprotocol/ [email protected] ├── @modelcontextprotocol/ [email protected] └── @modelcontextprotocol/ [email protected]

Minhas ações para executar o servidor são :

  1. mcp dev src/server.pyno Powershell enquanto estiver no diretório raiz do projeto.
  2. Então eu vejo
⚙️ Proxy server listening on port 6277
🔍 MCP Inspector is up and running at http://127.0.0.1:6274 🚀

No console, acesse a página http://127.0.0.1:6274 . 3. Na página, o método de transporte STDIO já está definido. Há também um comando uvcom argumentos run --with mcp mcp run src/server.py(veja a captura de tela em anexo), então clico no botão "Conectar". Nada acontece na interface, mas nos logs do console, vejo

New SSE connection
Query parameters: [Object: null prototype] {
  transportType: 'stdio',
  command: 'uv',
  args: 'run --with mcp mcp run src/server.py',
  env: '{ ... # all my env variables, PATH and etc.}'
}
Stdio transport: command=C:\Users\...\.local\bin\uv.exe, args=run,--with,mcp,mcp,run,src/server.py
Spawned stdio transport
Connected MCP client to backing server transport
Created web app transport
Created web app transport
Set up MCP proxy
  1. Clico no botão "Conectar" novamente (veja a captura de tela anexada) e vejo a mensagem "Erro de conexão, seu servidor MCP está em execução?" na interface do usuário e o seguinte nos logs:
New SSE connection
Query parameters: [Object: null prototype] {
  transportType: 'stdio',
  command: 'uv',
  args: 'run --with mcp mcp run src/server.py',
  env: '{...}'
}
Stdio transport: command=C:\Users\...\.local\bin\uv.exe, args=run,--with,mcp,mcp,run,src/server.py
Spawned stdio transport
Connected MCP client to backing server transport
Created web app transport
Created web app transport
Set up MCP proxy
Received message for sessionId 5ed68d2c-6c0f-47e7-9972-3fe99c43a630
Error in /message route: Error: SSE connection not established
    at SSEServerTransport.handlePostMessage (file:///C:/Users/.../AppData/Roaming/npm/node_modules/@modelcontextprotocol/inspector/node_modules/@modelcontextprotocol/sdk/dist/esm/server/sse.js:61:19)
    at file:///C:/Users/.../AppData/Roaming/npm/node_modules/@modelcontextprotocol/inspector/server/build/index.js:130:25
    at Layer.handleRequest (C:\Users\...\AppData\Roaming\npm\node_modules\@modelcontextprotocol\inspector\node_modules\router\lib\layer.js:152:17)
    at next (C:\Users\...\AppData\Roaming\npm\node_modules\@modelcontextprotocol\inspector\node_modules\router\lib\route.js:157:13)
    at Route.dispatch (C:\Users\...\AppData\Roaming\npm\node_modules\@modelcontextprotocol\inspector\node_modules\router\lib\route.js:117:3)
    at handle (C:\Users\...\AppData\Roaming\npm\node_modules\@modelcontextprotocol\inspector\node_modules\router\index.js:435:11) 
    at Layer.handleRequest (C:\Users\...\AppData\Roaming\npm\node_modules\@modelcontextprotocol\inspector\node_modules\router\lib\layer.js:152:17)
    at C:\Users\...\AppData\Roaming\npm\node_modules\@modelcontextprotocol\inspector\node_modules\router\index.js:295:15
    at processParams (C:\Users\...\AppData\Roaming\npm\node_modules\@modelcontextprotocol\inspector\node_modules\router\index.js:582:12)
    at next (C:\Users\...\AppData\Roaming\npm\node_modules\@modelcontextprotocol\inspector\node_modules\router\index.js:291:5)    
Error [ERR_HTTP_HEADERS_SENT]: Cannot set headers after they are sent to the client
    at ServerResponse.setHeader (node:_http_outgoing:699:11)
    at ServerResponse.header (C:\Users\...\AppData\Roaming\npm\node_modules\@modelcontextprotocol\inspector\node_modules\express\lib\response.js:684:10)
    at ServerResponse.json (C:\Users\...\AppData\Roaming\npm\node_modules\@modelcontextprotocol\inspector\node_modules\express\lib\response.js:247:10)
    at file:///C:/Users/.../AppData/Roaming/npm/node_modules/@modelcontextprotocol/inspector/server/build/index.js:134:25
    at process.processTicksAndRejections (node:internal/process/task_queues:105:5)

PS Eu tentei adicionar

if __name__ == "__main__":
    mcp.run(transport='stdio')

No final do server.py, como alguns exemplos propõem, mas não afetou nada.

Qualquer ajuda é bem-vinda! Obrigado!

Captura de tela da página da interface do usuário do MCP Inspector

python
  • 2 respostas
  • 234 Views
Martin Hope
G.M
Asked: 2025-04-20 05:12:47 +0800 CST

c++ maneira correta de fazer downcast de tipos int

  • 9

Primeiro, suponha que eu tenha

int16_t a;
int8_t b;

. Gostaria de fazer isso b=a;descartando todos os MSBs, incluindo o bit de sinal, que anão se encaixam em b. Qual seria uma maneira correta de fazer isso?

Não consigo encontrar nenhuma informação útil e recente sobre este tópico. Este link diz que a conversão de estreitamento de sinal depende do compilador, mas isso acontece em C, não em C++. Também não quero comportamentos dependentes do compilador. Aqui diz que a conversão de estreitamento deveria ser um erro. Estou bastante confuso sobre o que fazer.

Segundo, se ambos ae bfossem suas contrapartes sem sinal, então seria b=a;uma abordagem adequada? De acordo com o primeiro link, isso é definido pelo menos em C.

c++
  • 1 respostas
  • 127 Views
Martin Hope
Samuel
Asked: 2025-04-20 04:07:35 +0800 CST

O estado não está persistindo em popup.html por meio do armazenamento do Chrome

  • 4

Eu esperava o seguinte

  • Para handleLogs()armazenar { site: 'https://google.com' }no estado dos sites e armazenar no armazenamento local do Chrome
  • Para useEffecto gancho pegar o array de sites e salvar no estado do site sempre que o pop-up for aberto

O problema atual é que sempre que abro o pop-up, o site[] está sempre vazio. Consigo ver, através das ferramentas de desenvolvimento, que o site é adicionado ao estado e ao armazenamento no armazenamento local na interação inicial com a entrada. Mas, em aberturas subsequentes, sem interação com a entrada, aparece um array de sites vazio no estado e no armazenamento local. Por quê?

Abaixo está uma versão simplificada real do código que tenho em app.jsxarquivo

const App = () => {
    const [sites, setSites] = useState([]);

    useEffect(() => {
        chrome.storage.local.get(['sites'], (res) => {
            setSites(res.sites);
            console.log(res);
        });
    }, []);

    function handleLogs(event) {
        setSites((prevSites) => [...prevSites, { site: 'https://google.com' }]);
        chrome.storage.local.set({ sites });
    }

    return <input type="checkbox" onClick={() => handleLogs(event)} />;
};
javascript
  • 1 respostas
  • 47 Views
Martin Hope
Gene Knight
Asked: 2025-04-20 03:13:23 +0800 CST

React Hooks e Eventos [duplicado]

  • 6
Esta pergunta já tem respostas aqui :
Estado não atualiza ao usar o gancho de estado do React dentro do setInterval (16 respostas)
Fechado há 3 dias .
  var [testVar,setTestVar]=useState(0)

  var showTestVar=()=>{
    console.log(testVar)
  }

  var effectTest=()=>{
    setTestVar(1)
    setInterval(showTestVar,1000)
  }

Quero ter uma função chamada showTestVar que seja chamada sempre que um evento ocorrer. Disparando a partir de setInterval neste caso. Quero que ela seja chamada independentemente de testVar ter sido alterado ou não, mas em todos os eventos. Como faço isso com Hooks?

Assim, o log mostra 3 saídas a cada segundo, 1 zero e 2 uns.

reactjs
  • 1 respostas
  • 34 Views
Martin Hope
Alexei
Asked: 2025-04-20 02:42:00 +0800 CST

@Antes que o conselho não seja chamado

  • 5

Java 8

package com.myproject.javatestmavenbom.module1.aop;

public class Main {
  public static void main(String[] args) {
    UserService userService = new UserService();
    userService.createUser("create new user john", 21);
    userService.deleteUser("john");
  }
}
package com.myproject.javatestmavenbom.module1.aop;

public class UserService {
  public void createUser(String name, int age) {
    System.out.println("UserService: Request to create user: " + name + " | age: " + age);
  }

  public void deleteUser(String name) {
    System.out.println("UserService: Request to delete user: " + name);
  }
}
package com.myproject.javatestmavenbom.module1.aop;

import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;

@Aspect
public class MyAspect {
  // Before calling any method in the com.myproject.javatestmavenbom.module1.aop.UserService
  @Before("call(* com.myproject.javatestmavenbom.module1.aop.*(..))")
  public void beforeUserServiceMethodCall(JoinPoint joinPoint) {
    System.out.println("MyAspect: Calling a UserService method: " + joinPoint.getSignature().toShortString());
  }
}

Mas quando inicio o aplicativo, obtenho o seguinte resultado:

UserService: Request to create user: create new user john | age: 21
UserService: Request to delete user: john

Então, por que o método beforeUserServiceMethodCallnão chama antes de createUser/ deleteUser?

MyAspect: Calling a UserService method:
aspectj
  • 1 respostas
  • 32 Views
Prev
Próximo

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Reformatar números, inserindo separadores em posições fixas

    • 6 respostas
  • Marko Smith

    Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não?

    • 2 respostas
  • Marko Smith

    Problema com extensão desinstalada automaticamente do VScode (tema Material)

    • 2 respostas
  • Marko Smith

    Vue 3: Erro na criação "Identificador esperado, mas encontrado 'import'" [duplicado]

    • 1 respostas
  • Marko Smith

    Qual é o propósito de `enum class` com um tipo subjacente especificado, mas sem enumeradores?

    • 1 respostas
  • Marko Smith

    Como faço para corrigir um erro MODULE_NOT_FOUND para um módulo que não importei manualmente?

    • 6 respostas
  • Marko Smith

    `(expression, lvalue) = rvalue` é uma atribuição válida em C ou C++? Por que alguns compiladores aceitam/rejeitam isso?

    • 3 respostas
  • Marko Smith

    Um programa vazio que não faz nada em C++ precisa de um heap de 204 KB, mas não em C

    • 1 respostas
  • Marko Smith

    PowerBI atualmente quebrado com BigQuery: problema de driver Simba com atualização do Windows

    • 2 respostas
  • Marko Smith

    AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos

    • 1 respostas
  • Martin Hope
    Fantastic Mr Fox Somente o tipo copiável não é aceito na implementação std::vector do MSVC 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant Encontre o próximo dia da semana usando o cronógrafo 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor O inicializador de membro do construtor pode incluir a inicialização de outro membro? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul O C++20 mudou para permitir a conversão de `type(&)[N]` de matriz de limites conhecidos para `type(&)[]` de matriz de limites desconhecidos? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann Como/por que {2,3,10} e {x,3,10} com x=2 são ordenados de forma diferente? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller O ponto e vírgula agora é opcional em condicionais bash com [[ .. ]] na versão 5.2? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench Por que um traço duplo (--) faz com que esta cláusula MariaDB seja avaliada como verdadeira? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng Por que `dict(id=1, **{'id': 2})` às vezes gera `KeyError: 'id'` em vez de um TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos 2024-03-20 03:12:31 +0800 CST

Hot tag

python javascript c++ c# java typescript sql reactjs html

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve