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
Pato
Asked: 2025-04-15 14:10:50 +0800 CST

Semanas do calendário com a função to_char do Oracle

  • 5

no calendário, vejo que 30 e 31 de dezembro nos anos de 2025 e 2026 caem na mesma semana, mas usando a função to_char para criar o campo ano-semana, obterei semanas diferentes

select
    to_char(to_date('30-12-2025','dd-mm-yyyy'),'yyyy-ww')
    , to_char(to_date('31-12-2025','dd-mm-yyyy'),'yyyy-ww')
    , to_char(to_date('30-12-2026','dd-mm-yyyy'),'yyyy-ww')
    , to_char(to_date('31-12-2026','dd-mm-yyyy'),'yyyy-ww')
 from dual;

Temos pedidos no banco de dados com data de término 30-12-2025 e, às vezes, 31-12-2025. O problema pode ser que em outra tabela existam outros dados com base na semana, como 2025-01 a 2025-53. Se eu quiser juntá-los, pode acontecer que o pedido que termina em 30-12-2025 não seja unido ao de 2025-53, mas, na verdade, a data é a semana 53.

Por que o comportamento no Oracle é esse?

Não posso usar a semana ISO porque para o ano de 2026 e 31 de dezembro será 2026-53, como esperado, mas não para 31 de dezembro de 2025, porque será 2025-01, o que é incorreto.

Verifiquei o NLS nas configurações e tentei o idioma da data alemão, inglês, formato dd-mm-rr ou dd-mm-aaaa. continua o mesmo

sql
  • 1 respostas
  • 58 Views
Martin Hope
this.myself
Asked: 2025-04-15 13:35:32 +0800 CST

dotnet build -h e --help mostram opções diferentes. Qual é a diferença no comportamento e no conjunto de ferramentas?

  • 5

Eu sei que no mundo dos desenvolvedores da Microsoft o MSBuild ainda está por trás de tudo. Mas como pode ser que, em um Terminal Windows, os comandos dotnet build -he dotnet build -helpgerem resultados diferentes? A primeira versão com -has alternativas -?e --help, ao escrever, -helpmostra ajuda e opções totalmente diferentes:

PS C:\> dotnet build -h
Description:
  .NET-Generator

Nutzung:
  dotnet build [<PROJECT | SOLUTION>...] [options]

Argumente:
  <PROJECT | SOLUTION>  Das Projekt oder die Projektmappendatei, die verwendet werden soll. Wenn keine Datei angegeben ist, durchsucht der Befehl das aktuelle Verzeichnis nach einer Datei.

Optionen:
  --ucr, --use-current-runtime         Verwenden Sie die aktuelle Runtime als Zielruntime.
  ...

contra:

PS C:\> dotnet build -help
Syntax:              MSBuild.exe [Optionen] [Projektdatei | Verzeichnis]

Beschreibung:         ....

Optionen:            Beachten Sie, dass Sie Optionen über
                     "-option", "/option" und "--option" angeben können.
...

Como posso saber qual conjunto de ferramentas e versão o comando dotnet buildusa quando escrevo dotnet build mysolution.sln, o que parece adequado para ambas as variantes? Onde estão as diferenças e qual sistema de compilação o Visual Studio 2022 usa (ou como posso descobrir)? E, em seguida, como posso ter certeza de que as mesmas ferramentas estão sendo usadas no servidor de compilação?

visual-studio
  • 1 respostas
  • 22 Views
Martin Hope
timmy george
Asked: 2025-04-15 13:01:57 +0800 CST

A chamada ReadFile síncrona sobreposta para ler 1000 bytes de um arquivo de 88 bytes não aciona ERROR_HANDLE_EOF

  • 6

O conteúdo de um arquivo de texto chamado existingfile.txté o seguinte

The First Order Derivative of X2 is
2x. The derivative of sin is cos.
Math is the best

O código abaixo é de um arquivo chamado main.cppque está no mesmo diretório que existingfile.txt O exemplo mostra o processo de

  • abrindo uma alça paraexistingfile.txt
  • obtendo o tamanho deexistingfile.txt
  • lendo 1000 bytes deexistingfile.txt
  • gerando uma matriz de caracteres de 1000 bytes até o primeiro terminador nulo
#include <windows.h>
#include <cstdio>

int main(int, char**){
//Creating Synchronous File Handle
    HANDLE hFile = CreateFileW(
        L"existingfile.txt",
        GENERIC_READ,
        FILE_SHARE_READ | FILE_SHARE_WRITE,
        NULL,
        OPEN_ALWAYS,
        FILE_FLAG_SEQUENTIAL_SCAN,
        NULL
    );
    if (hFile == INVALID_HANDLE_VALUE) {
        printf("ERROR IN OPENING FILE %lu\n", GetLastError());
        return -1;
    }
    //Obtaining File Size
    {
        ULARGE_INTEGER FileSize;
        FileSize.LowPart = GetFileSize(hFile, &FileSize.HighPart);
        DWORD LastError = GetLastError();
        if (FileSize.LowPart == INVALID_FILE_SIZE && LastError != NO_ERROR){
            printf("FAILED TO OBTAIN FILE SIZE, ERROR %lu\n", LastError);
            return -1;
        }
        printf("FILE SIZE: %llu\n", FileSize.QuadPart);
    }
    //Reading To End Of the File
    {
        OVERLAPPED Overlapped = {};
        Overlapped.Offset = 15;
        Overlapped.OffsetHigh = 0;
        constexpr DWORD NumBytesToRead = 1000;
        char BytesRead[NumBytesToRead + 1] = {0};
        BOOL Successful = ReadFile(hFile, BytesRead, NumBytesToRead, NULL, &Overlapped);
        DWORD LastError = GetLastError();
        if (!Successful){
            if (LastError != ERROR_HANDLE_EOF){
                printf("ERROR IN OVERLAPPED SYNCHRONOUS READ TO EOF, ERROR %lu\n", LastError);
                return -1;
            }
            puts("EOF ENCOUNTERED IN OVERLAPPED SYNCHRONOUS READ TO EOF");
        }
        BytesRead[NumBytesToRead] = 0;
        printf("2: Information Read: '%s'\n", BytesRead); 
    }
    CloseHandle(hFile);
    return 0;
}

A saída que obtenho é

FILE SIZE: 88
2: Information Read: ' Derivative of X2 is
2x. The derivative of sin is cos.
Math is the best'

A saída que eu esperava era

FILE SIZE: 88
EOF ENCOUNTERED IN OVERLAPPED SYNCHRONOUS READ TO EOF
2: Information Read: ' Derivative of X2 is
2x. The derivative of sin is cos.
Math is the best'

porque está declarado na documentação do ReadFile

Considerações para trabalhar com identificadores de arquivo síncronos:

...

Se lpOverlapped não for NULL, quando uma operação de leitura síncrona atingir o final de um arquivo, ReadFile retornará FALSE e GetLastError retornará ERROR_HANDLE_EOF.

Eu ficaria muito grato se alguém pudesse explicar/descobrir a causa do porquê o comportamento esperado mencionado na documentação não está acontecendo.

c++
  • 1 respostas
  • 86 Views
Martin Hope
serena55
Asked: 2025-04-15 12:51:02 +0800 CST

Comparação de intervalo de valores numéricos de string SQL

  • 4

Tenho uma string como A18.30 e quero comparar se ela se enquadra nestes 2 valores mínimo e máximo: A17.0 e A19.0.

  1. A18.30 => A17.0 entre A19.0 [correto]
  2. P1A.5 => P1.0 entre A2.0 [Incorreto]

A expectativa é que a primeira letra precise ser comparada e os dígitos numéricos restantes, se estiverem no intervalo a ser comparado.

Tentei com substring, mas quero saber se existe uma maneira melhor de fazer a comparação com regex. Eu uso o snowflake db.

sql
  • 2 respostas
  • 80 Views
Martin Hope
JaydedCompanion
Asked: 2025-04-15 12:23:17 +0800 CST

Referência indefinida para variável em outro arquivo de cabeçalho, embora eu não possa defini-la antes do tempo de execução

  • 6

Estou tentando compilar um jogo Playdate que estou criando em C, mas estou recebendo erros em funções que usam as variáveis ​​de ponteiro pde pdsys, que declarei no meu global.harquivo (como extern const), mas às quais só posso atribuir um valor em um método executado quando a API do Playdate chama o evento de inicialização ( eventHandler()).

Parte do problema é que eu entendo por que você não pode usar uma variável sem defini-la, já que C precisa saber o tamanho da variável, mas não entendo por que haveria um erro de compilação ao usar um ponteiro de variável sem que ele seja definido, já que o ponteiro tem um tamanho fixo.

Pela pesquisa que fiz, esse erro de compilação é causado por um código que usa uma variável sem definição, embora eu não tenha certeza de como fazer isso além de declará-la global.he atribuir um valor a ela no meu eventHandler(). Acredito que isso não foi um problema quando declarei essas variáveis ​​dentro main.cde onde elas estão sendo usadas, mas conforme meu projeto cresceu em escopo, me vi precisando acessar essas variáveis ​​em praticamente todos os outros arquivos do projeto. Pensei que a melhor solução para isso seria ter um arquivo que incluísse todos os outros arquivos, que contivesse as declarações pde pdsys(e talvez até mais depois) para que pudessem ser acessadas de qualquer arquivo, mas se eu estiver enganado, agradeceria informações sobre a melhor forma de fazer isso!

Aqui estão o que acredito serem os trechos de código relevantes. O projeto contém mais, mas acredito que eles não fazem parte do problema e aumentariam ainda mais a questão se eu os incluísse:

main.c

#include "global.h"
#include "pd_api.h"

LCDSprite *pBall;
float crankTime;

int updateCallback(void *userdata) {
    crankTime += pdsys->getCrankChange() * (float)M_PI/180;
    pd->sprite->moveTo(pBall,
        sin(crankTime/1) * 16 + 400/2,
        sin(crankTime/2) * 32 + 240/2
        );
    // Updates and renders all LCDSprites
    pd->sprite->updateAndDrawSprites();
    return 1;
}

int eventHandler (PlaydateAPI *playdate, PDSystemEvent event, uint32_t arg) {

    switch (event) {

        // Game initialization!
        case kEventInit:
        pd = playdate;  //Store the playdate API struct in pd variable
        pdsys = playdate->system; //Store playdate system struct in pdsys variable
        break;

        // Default case to suppress warnings
        default:
        break;

    }
    
    playdate->system->logToConsole("eventHandler call received. %d", arg);
    return 0;
    
}

global.h

#ifndef GLOBAL_H
#define GLOBAL_H

#include "pd_api.h"

extern const PlaydateAPI* pd;
extern const struct playdate_sys* pdsys;

#endif //GLOBAL_H

O erro que recebo quando tento compilar o projeto é o seguinte:

====================[ Build | all ]=============================================
make --jobs=10 all
detected_OS is "Darwin"
mkdir -p build
mkdir -p build/dep
mkdir -p `dirname build/src/main.o`
clang -g -dynamiclib -rdynamic -lm -DTARGET_SIMULATOR=1 -DTARGET_EXTENSION=1 -I . -I /Users/JaydedCompanion//Developer/PlaydateSDK//C_API -o build/pdex.dylib src/main.c src/global.c src/jaydes_pd_utils.c src/game.c src/ball.c /Users/JaydedCompanion//Developer/PlaydateSDK//C_API/buildsupport/setup.c
/usr/local/bin/arm-none-eabi-gcc -g3 -c -mthumb -mcpu=cortex-m7 -mfloat-abi=hard -mfpu=fpv5-sp-d16 -D__FPU_USED=1 -O2 -falign-functions=16 -fomit-frame-pointer -gdwarf-2 -Wall -Wno-unused -Wstrict-prototypes -Wno-unknown-pragmas -fverbose-asm -Wdouble-promotion -mword-relocations -fno-common -ffunction-sections -fdata-sections -Wa,-ahlms=build/main.lst -DTARGET_PLAYDATE=1 -DTARGET_EXTENSION=1  -MD -MP -MF build/dep/main.o.d -I . -I . -I /Users/JaydedCompanion//Developer/PlaydateSDK//C_API src/main.c -o build/src/main.o
/usr/local/bin/arm-none-eabi-gcc -g3 build/src/main.o build/src/global.o build/src/jaydes_pd_utils.o build/src/game.o build/src/ball.o build//Users/JaydedCompanion//Developer/PlaydateSDK//C_API/buildsupport/setup.o -nostartfiles -mthumb -mcpu=cortex-m7 -mfloat-abi=hard -mfpu=fpv5-sp-d16 -D__FPU_USED=1 -T/Users/JaydedCompanion//Developer/PlaydateSDK//C_API/buildsupport/link_map.ld -Wl,-Map=build/pdex.map,--cref,--gc-sections,--no-warn-mismatch,--emit-relocs    -o build/pdex.elf
Undefined symbols for architecture x86_64:
  "_pd", referenced from:
      _updateCallback in main-b239cd.o
      _eventHandler in main-b239cd.o
      _ball in ball-c3812c.o
  "_pdsys", referenced from:
      _updateCallback in main-b239cd.o
      _eventHandler in main-b239cd.o
      _game_init in game-6fe6d9.o
ld: symbol(s) not found for architecture x86_64
clang: error: linker command failed with exit code 1 (use -v to see invocation)
make: *** [build/pdex.dylib] Error 1
make: *** Waiting for unfinished jobs....
/usr/local/playdate/gcc-arm-none-eabi-9-2019-q4-major/bin/../lib/gcc/arm-none-eabi/9.2.1/../../../../arm-none-eabi/bin/ld: build/src/main.o: in function `updateCallback':
/Users/JaydedCompanion/Documents/GitHub/PlaydateProject/src/main.c:24: undefined reference to `pdsys'
/usr/local/playdate/gcc-arm-none-eabi-9-2019-q4-major/bin/../lib/gcc/arm-none-eabi/9.2.1/../../../../arm-none-eabi/bin/ld: /Users/JaydedCompanion/Documents/GitHub/PlaydateProject/src/main.c:24: undefined reference to `pd'
/usr/local/playdate/gcc-arm-none-eabi-9-2019-q4-major/bin/../lib/gcc/arm-none-eabi/9.2.1/../../../../arm-none-eabi/bin/ld: build/src/main.o: in function `eventHandler':
/Users/JaydedCompanion/Documents/GitHub/PlaydateProject/src/main.c:55: undefined reference to `pd'
/usr/local/playdate/gcc-arm-none-eabi-9-2019-q4-major/bin/../lib/gcc/arm-none-eabi/9.2.1/../../../../arm-none-eabi/bin/ld: /Users/JaydedCompanion/Documents/GitHub/PlaydateProject/src/main.c:55: undefined reference to `pdsys'
collect2: error: ld returned 1 exit status
make: *** [build/pdex.elf] Error 1

Process finished with exit code 2

Não tenho certeza se o makefile faz parte do problema, então não o incluirei para não tornar esta pergunta ainda mais longa, mas posso confirmar que ele inclui os arquivos de origem relevantes e não tem sido um problema até agora. Admito que é um makefile que obtive dos projetos de exemplo incluídos na API C do Playdate, pois tenho pouquíssima experiência trabalhando com C e ainda menos experiência usando makefiles. Além disso, a documentação da API C do Playdate praticamente não contém informações sobre como escrever um makefile para projetos do Playdate e sugere que as pessoas simplesmente usem os makefiles de exemplo, como eu fiz. Se for provável que esta seja uma informação pertinente, no entanto, terei prazer em editar esta publicação para incluí-la.

c
  • 2 respostas
  • 85 Views
Martin Hope
hoa tran
Asked: 2025-04-15 11:47:36 +0800 CST

Como retornar um valor com base em outro valor

  • 6

Tenho dados de exemplo como abaixo:

Filial conquistas1 ponto1
UM 10 1
B 20 2
C 30 3
Filial conquistas2 ponto2
UM 30 3
B 20 2
C 10 1

Então, preciso de uma tabela cujo ponto seja o máximo point1e, point2em seguida, retorne as respectivas conquistas para esse ponto. Abaixo está minha saída esperada.

Filial conquistas ponto_máx.
UM 30 3
B 20 2
C 30 3

O que devo fazer neste caso? Obrigado.

excel
  • 5 respostas
  • 81 Views
Martin Hope
dwjohnston
Asked: 2025-04-15 11:33:04 +0800 CST

Required<T> não funciona para tipos de pesquisa secundários

  • 5

Se eu tiver algum código como:

type Bravo = {
  b?: string; 
}

type Charlie = {
  c:Bravo['b']
}

function acceptsCharlie(value: Charlie){
  //'value.c' is possibly 'undefined'.(18048)
  value.c.split('');
}

Isso faz sentido - o tipo Charlieherda a string opcional de Bravo.

Podemos resolver isso usando o Requiredtipo de utilitário:

type Bravo = {
  b?: string; 
}

type Charlie = {
  //  👇
  c:Required<Bravo>['b']
}

function acceptsCharlie(value: Charlie){
  // no error here 
  value.c.split('');
}

Fácil.

Entretanto, se eu adicionar mais uma camada de pesquisa de digitação:

type Alpha = {
  a?: string; 
}

type Bravo = {
  b: Alpha['a']; 
}

type Charlie = {
  c: Required<Bravo>['b']
}

function acceptsCharlie(value: Charlie){
  //'value.c' is possibly 'undefined'.(18048)
  value.c.split('');
}

Isso Requirednão resolve mais o problema para mim.

O que acontece?

typescript
  • 2 respostas
  • 36 Views
Martin Hope
FaniX
Asked: 2025-04-15 11:04:19 +0800 CST

Como fazer uma cópia de uma função?

  • 6

Em javascript, quero fazer uma cópia (superficial) de um Function, para que as propriedades do novo objeto não sejam afetadas pelo objeto original:

function func(...) { ... } // to say, function func(x, y) { return [x,y] }
func.a = 1
let func1 = func       // without copy, func1 and func IS the same object
let func2 = copy(func) // need to be implemented

func.a = 2
func1.a        // becomes 2
func2.a        // shall still be 1
func2("abc")   // shall return the same result as func("abc")

É possível?


A melhor maneira que encontrei no momento é definir uma função wrapper:

function f0(x, y) { return [x,y] }
f0.a = 1

function copy(fn){
  function wrapper(){
    return fn.apply(wrapper, arguments)
  }
  Object.assign(wrapper,fn)
  return wrapper
}

let f2 = copy(f0)

f0.a = 2
f2.a        // is still 1
f0.length   // gives 2
f2.length   // gives 0

Entretanto, há alguns problemas com esta solução:

  1. A aplicação em cadeia de copylevará a vários níveis de wrapper. por exemplo, copy(copy(copy(fn)))retornará uma função com três wrappers.
  2. a lengthfunção de origem é perdida, wrapper.lengthé sempre 0.
javascript
  • 2 respostas
  • 107 Views
Martin Hope
rzlvmp
Asked: 2025-04-15 10:49:18 +0800 CST

Como criar um caminho dinâmico que será representado como lista no servidor aiohttp?

  • 5

Digamos que eu tenha um código de exemplo:

from aiohttp import web

async def example(r):
    a = r.match_info.get('a')
    b = r.match_info.get('b')
    c = r.match_info.get('c')
    return web.Response(text=f'[{a}, {b}, {c}]')

app = web.Application()
app.add_routes([web.get('/args/{a}/{b}/{c}', example)])

web.run_app(app)

E agora depois de acessar

http://localhost:8080/args/A/B/C

Estou conseguindo

[A, B, C]

resposta. A questão é: qual é a sintaxe correta para uma lista (ou tupla) como path?

Em outras palavras, quero acessar uma URL com um número aleatório de argumentos como

http://localhost:8080/args/r/a/n/d/o/m/1/2/3

e obter uma lista ou tupla de

('r', 'a', 'n', 'd', 'o', 'm', '1', '2', '3')

elementos

python
  • 1 respostas
  • 39 Views
Martin Hope
Wang chan
Asked: 2025-04-15 10:36:17 +0800 CST

O React Native não roda em um emulador

  • 5

Acabei de criar um novo projeto React Native no Ubuntu LTS com o comando npx @react-native-community/cli init e o projeto foi criado perfeitamente. Depois de terminar o projeto, entrei na pasta do projeto com o CD e executei o npx react-native run-android. A mensagem de erro que me aparece é Android/Sdk/ndk/27.1.12297006 não tinha um arquivo source.properties

reactjs
  • 1 respostas
  • 24 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